mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-01-26 03:47:24 +08:00
a61d228b76
format. It is targeted at 32 bit microcontrollers, but is also fit for other embedded systems with tight (2-10 kB ROM, <1 kB RAM) memory constraints.(http://koti.kapsi.fi/jpa/nanopb/) How to use the example: 1. move examples/nanopb to bsp/xxxx/ 2. enable macro RT_USING_NANOPB in rtconfig.h 3. regenerate the project file (scons --target=xxxx) 4. rebuild the project
43 lines
1.4 KiB
C
43 lines
1.4 KiB
C
/* pb_common.h: Common support functions for pb_encode.c and pb_decode.c.
|
|
* These functions are rarely needed by applications directly.
|
|
*/
|
|
|
|
#ifndef PB_COMMON_H_INCLUDED
|
|
#define PB_COMMON_H_INCLUDED
|
|
|
|
#include "pb.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/* Iterator for pb_field_t list */
|
|
struct pb_field_iter_s {
|
|
const pb_field_t *start; /* Start of the pb_field_t array */
|
|
const pb_field_t *pos; /* Current position of the iterator */
|
|
unsigned required_field_index; /* Zero-based index that counts only the required fields */
|
|
void *dest_struct; /* Pointer to start of the structure */
|
|
void *pData; /* Pointer to current field value */
|
|
void *pSize; /* Pointer to count/has field */
|
|
};
|
|
typedef struct pb_field_iter_s pb_field_iter_t;
|
|
|
|
/* Initialize the field iterator structure to beginning.
|
|
* Returns false if the message type is empty. */
|
|
bool pb_field_iter_begin(pb_field_iter_t *iter, const pb_field_t *fields, void *dest_struct);
|
|
|
|
/* Advance the iterator to the next field.
|
|
* Returns false when the iterator wraps back to the first field. */
|
|
bool pb_field_iter_next(pb_field_iter_t *iter);
|
|
|
|
/* Advance the iterator until it points at a field with the given tag.
|
|
* Returns false if no such field exists. */
|
|
bool pb_field_iter_find(pb_field_iter_t *iter, uint32_t tag);
|
|
|
|
#ifdef __cplusplus
|
|
} /* extern "C" */
|
|
#endif
|
|
|
|
#endif
|
|
|