summaryrefslogtreecommitdiffstats
path: root/CAN-binder/libs/nanopb/tests/basic_stream
diff options
context:
space:
mode:
authorRomain Forlot <romain.forlot@iot.bzh>2017-06-20 10:24:05 +0000
committerRomain Forlot <romain.forlot@iot.bzh>2017-06-20 10:24:05 +0000
commit32e25cbca210a359b09768537b6f443fe90a3070 (patch)
tree3309794c15d8a8f8e9c1c08cad072ee1378813ba /CAN-binder/libs/nanopb/tests/basic_stream
parent76c43dec62b2e21cd6446360c00d4fe6b437533f (diff)
Separation Generator to a dedicated repo
Change-Id: Id94831651c3266861435272a6e36c7884bef2c45 Signed-off-by: Romain Forlot <romain.forlot@iot.bzh>
Diffstat (limited to 'CAN-binder/libs/nanopb/tests/basic_stream')
-rw-r--r--CAN-binder/libs/nanopb/tests/basic_stream/SConscript12
-rw-r--r--CAN-binder/libs/nanopb/tests/basic_stream/decode_stream.c84
-rw-r--r--CAN-binder/libs/nanopb/tests/basic_stream/encode_stream.c40
3 files changed, 0 insertions, 136 deletions
diff --git a/CAN-binder/libs/nanopb/tests/basic_stream/SConscript b/CAN-binder/libs/nanopb/tests/basic_stream/SConscript
deleted file mode 100644
index 7d66856..0000000
--- a/CAN-binder/libs/nanopb/tests/basic_stream/SConscript
+++ /dev/null
@@ -1,12 +0,0 @@
-# Build and run a basic round-trip test using direct stream encoding.
-
-Import("env")
-
-enc = env.Program(["encode_stream.c", "$COMMON/person.pb.c", "$COMMON/pb_encode.o", "$COMMON/pb_common.o"])
-dec = env.Program(["decode_stream.c", "$COMMON/person.pb.c", "$COMMON/pb_decode.o", "$COMMON/pb_common.o"])
-
-env.RunTest(enc)
-env.RunTest([dec, "encode_stream.output"])
-env.Decode(["encode_stream.output", "$COMMON/person.proto"], MESSAGE = "Person")
-env.Compare(["decode_stream.output", "encode_stream.decoded"])
-
diff --git a/CAN-binder/libs/nanopb/tests/basic_stream/decode_stream.c b/CAN-binder/libs/nanopb/tests/basic_stream/decode_stream.c
deleted file mode 100644
index 798dcc5..0000000
--- a/CAN-binder/libs/nanopb/tests/basic_stream/decode_stream.c
+++ /dev/null
@@ -1,84 +0,0 @@
-/* Same as test_decode1 but reads from stdin directly.
- */
-
-#include <stdio.h>
-#include <pb_decode.h>
-#include "person.pb.h"
-#include "test_helpers.h"
-
-/* This function is called once from main(), it handles
- the decoding and printing.
- Ugly copy-paste from test_decode1.c. */
-bool print_person(pb_istream_t *stream)
-{
- int i;
- Person person = Person_init_zero;
-
- if (!pb_decode(stream, Person_fields, &person))
- return false;
-
- /* Now the decoding is done, rest is just to print stuff out. */
-
- printf("name: \"%s\"\n", person.name);
- printf("id: %ld\n", (long)person.id);
-
- if (person.has_email)
- printf("email: \"%s\"\n", person.email);
-
- for (i = 0; i < person.phone_count; i++)
- {
- Person_PhoneNumber *phone = &person.phone[i];
- printf("phone {\n");
- printf(" number: \"%s\"\n", phone->number);
-
- if (phone->has_type)
- {
- switch (phone->type)
- {
- case Person_PhoneType_WORK:
- printf(" type: WORK\n");
- break;
-
- case Person_PhoneType_HOME:
- printf(" type: HOME\n");
- break;
-
- case Person_PhoneType_MOBILE:
- printf(" type: MOBILE\n");
- break;
- }
- }
- printf("}\n");
- }
-
- return true;
-}
-
-/* This binds the pb_istream_t to stdin */
-bool callback(pb_istream_t *stream, uint8_t *buf, size_t count)
-{
- FILE *file = (FILE*)stream->state;
- bool status;
-
- status = (fread(buf, 1, count, file) == count);
-
- if (feof(file))
- stream->bytes_left = 0;
-
- return status;
-}
-
-int main()
-{
- pb_istream_t stream = {&callback, NULL, SIZE_MAX};
- stream.state = stdin;
- SET_BINARY_MODE(stdin);
-
- if (!print_person(&stream))
- {
- printf("Parsing failed: %s\n", PB_GET_ERROR(&stream));
- return 1;
- } else {
- return 0;
- }
-}
diff --git a/CAN-binder/libs/nanopb/tests/basic_stream/encode_stream.c b/CAN-binder/libs/nanopb/tests/basic_stream/encode_stream.c
deleted file mode 100644
index 7f571c4..0000000
--- a/CAN-binder/libs/nanopb/tests/basic_stream/encode_stream.c
+++ /dev/null
@@ -1,40 +0,0 @@
-/* Same as test_encode1.c, except writes directly to stdout.
- */
-
-#include <stdio.h>
-#include <pb_encode.h>
-#include "person.pb.h"
-#include "test_helpers.h"
-
-/* This binds the pb_ostream_t into the stdout stream */
-bool streamcallback(pb_ostream_t *stream, const uint8_t *buf, size_t count)
-{
- FILE *file = (FILE*) stream->state;
- return fwrite(buf, 1, count, file) == count;
-}
-
-int main()
-{
- /* Initialize the structure with constants */
- Person person = {"Test Person 99", 99, true, "test@person.com",
- 3, {{"555-12345678", true, Person_PhoneType_MOBILE},
- {"99-2342", false, 0},
- {"1234-5678", true, Person_PhoneType_WORK},
- }};
-
- /* Prepare the stream, output goes directly to stdout */
- pb_ostream_t stream = {&streamcallback, NULL, SIZE_MAX, 0};
- stream.state = stdout;
- SET_BINARY_MODE(stdout);
-
- /* Now encode it and check if we succeeded. */
- if (pb_encode(&stream, Person_fields, &person))
- {
- return 0; /* Success */
- }
- else
- {
- fprintf(stderr, "Encoding failed: %s\n", PB_GET_ERROR(&stream));
- return 1; /* Failure */
- }
-}