aboutsummaryrefslogtreecommitdiffstats
path: root/tests/basic_stream/encode_stream.c
diff options
context:
space:
mode:
authorPetteri Aimonen <jpa@git.mail.kapsi.fi>2013-09-11 16:13:19 +0300
committerPetteri Aimonen <jpa@git.mail.kapsi.fi>2013-09-11 16:13:19 +0300
commit61ad04afd5236e2a6a0d4b4f2caa3bab4a820c99 (patch)
treebeea1aa405bb022927fc0eb5b8f4982083b68458 /tests/basic_stream/encode_stream.c
parent5b9ad17dc2014d7506a7dde92281d8c36a1433e4 (diff)
parent9f93d39f728c3e87b0ab482aa604c5cad4b1c86e (diff)
Merge branch 'dev_tests_using_scons'
Diffstat (limited to 'tests/basic_stream/encode_stream.c')
-rw-r--r--tests/basic_stream/encode_stream.c40
1 files changed, 40 insertions, 0 deletions
diff --git a/tests/basic_stream/encode_stream.c b/tests/basic_stream/encode_stream.c
new file mode 100644
index 00000000..7f571c41
--- /dev/null
+++ b/tests/basic_stream/encode_stream.c
@@ -0,0 +1,40 @@
+/* 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 */
+ }
+}