diff options
author | Petteri Aimonen <jpa@npb.mail.kapsi.fi> | 2011-07-31 12:55:09 +0000 |
---|---|---|
committer | Petteri Aimonen <jpa@npb.mail.kapsi.fi> | 2011-07-31 12:55:09 +0000 |
commit | 3959290bc77ae26772bc107128b0a4edd3930361 (patch) | |
tree | fefcf27423aeb7fd100b52802f5c519def3a8cc7 /tests/test_decode1.c | |
parent | f8364310d3ca85d2cf59019bb4bc5e9ff4c52dc3 (diff) |
First version of header generator
git-svn-id: https://svn.kapsi.fi/jpa/nanopb@950 e3a754e5-d11d-0410-8d38-ebb782a927b9
Diffstat (limited to 'tests/test_decode1.c')
-rw-r--r-- | tests/test_decode1.c | 73 |
1 files changed, 3 insertions, 70 deletions
diff --git a/tests/test_decode1.c b/tests/test_decode1.c index 4b34022f..362c404a 100644 --- a/tests/test_decode1.c +++ b/tests/test_decode1.c @@ -1,75 +1,8 @@ #include <stdio.h> #include <string.h> #include <stddef.h> -#include "pb_decode.h" - -/* Structures for "Person" message */ - -typedef enum { - Person_PhoneType_MOBILE = 0, - Person_PhoneType_HOME = 1, - Person_PhoneType_WORK = 2 -} Person_PhoneType; - -typedef struct { - char number[40]; - bool has_type; - Person_PhoneType type; -} Person_PhoneNumber; - -typedef struct { - char name[40]; - int32_t id; - bool has_email; - char email[40]; - size_t phone_size; - Person_PhoneNumber phone[5]; -} Person; - -/* Field descriptions */ - - -const Person_PhoneType Person_PhoneNumber_type_default = Person_PhoneType_HOME; - -const pb_field_t Person_PhoneNumber_fields[] = { - {1, PB_HTYPE_REQUIRED | PB_LTYPE_STRING, - offsetof(Person_PhoneNumber, number), 0, - pb_membersize(Person_PhoneNumber, number), 0, 0}, - - {2, PB_HTYPE_OPTIONAL | PB_LTYPE_VARINT, - pb_delta(Person_PhoneNumber, type, number), - pb_delta(Person_PhoneNumber, has_type, type), - pb_membersize(Person_PhoneNumber, type), 0, - &Person_PhoneNumber_type_default}, - - PB_LAST_FIELD -}; - -const pb_field_t Person_fields[] = { - {1, PB_HTYPE_REQUIRED | PB_LTYPE_STRING, - offsetof(Person, name), 0, - pb_membersize(Person, name), 0, 0}, - - {2, PB_HTYPE_REQUIRED | PB_LTYPE_VARINT, - pb_delta(Person, id, name), 0, - pb_membersize(Person, id), 0, 0}, - - {3, PB_HTYPE_OPTIONAL | PB_LTYPE_STRING, - offsetof(Person, email) - offsetof(Person, id), - pb_delta(Person, has_email, email), - pb_membersize(Person, email), 0, 0}, - - {4, PB_HTYPE_ARRAY | PB_LTYPE_SUBMESSAGE, - offsetof(Person, phone) - offsetof(Person, email), - pb_delta(Person, phone_size, phone), - pb_membersize(Person, phone[0]), - pb_arraysize(Person, phone), - Person_PhoneNumber_fields}, - - PB_LAST_FIELD -}; - -/* And now, the actual test program */ +#include <pb_decode.h> +#include "person.h" bool print_person(pb_istream_t *stream) { @@ -81,7 +14,7 @@ bool print_person(pb_istream_t *stream) printf("Person: name '%s' id '%d' email '%s'\n", person.name, person.id, person.email); - for (i = 0; i < person.phone_size; i++) + for (i = 0; i < person.phone_count; i++) { Person_PhoneNumber *phone = &person.phone[i]; printf("PhoneNumber: number '%s' type '%d'\n", phone->number, phone->type); |