Zephyr API Documentation
2.7.0-rc2
A Scalable Open Source RTOS
|
Go to the source code of this file.
Data Structures | |
struct | json_obj_descr |
Macros | |
#define | JSON_OBJ_DESCR_PRIM(struct_, field_name_, type_) |
Helper macro to declare a descriptor for supported primitive values. More... | |
#define | JSON_OBJ_DESCR_OBJECT(struct_, field_name_, sub_descr_) |
Helper macro to declare a descriptor for an object value. More... | |
#define | JSON_OBJ_DESCR_ARRAY(struct_, field_name_, max_len_, len_field_, elem_type_) |
Helper macro to declare a descriptor for an array of primitives. More... | |
#define | JSON_OBJ_DESCR_OBJ_ARRAY(struct_, field_name_, max_len_, len_field_, elem_descr_, elem_descr_len_) |
Helper macro to declare a descriptor for an array of objects. More... | |
#define | JSON_OBJ_DESCR_ARRAY_ARRAY(struct_, field_name_, max_len_, len_field_, elem_descr_, elem_descr_len_) |
Helper macro to declare a descriptor for an array of array. More... | |
#define | JSON_OBJ_DESCR_PRIM_NAMED(struct_, json_field_name_, struct_field_name_, type_) |
Variant of JSON_OBJ_DESCR_PRIM that can be used when the structure and JSON field names differ. More... | |
#define | JSON_OBJ_DESCR_OBJECT_NAMED(struct_, json_field_name_, struct_field_name_, sub_descr_) |
Variant of JSON_OBJ_DESCR_OBJECT that can be used when the structure and JSON field names differ. More... | |
#define | JSON_OBJ_DESCR_ARRAY_NAMED(struct_, json_field_name_, struct_field_name_, max_len_, len_field_, elem_type_) |
Variant of JSON_OBJ_DESCR_ARRAY that can be used when the structure and JSON field names differ. More... | |
#define | JSON_OBJ_DESCR_OBJ_ARRAY_NAMED(struct_, json_field_name_, struct_field_name_, max_len_, len_field_, elem_descr_, elem_descr_len_) |
Variant of JSON_OBJ_DESCR_OBJ_ARRAY that can be used when the structure and JSON field names differ. More... | |
Typedefs | |
typedef int(* | json_append_bytes_t) (const char *bytes, size_t len, void *data) |
Function pointer type to append bytes to a buffer while encoding JSON data. More... | |
Enumerations | |
enum | json_tokens { JSON_TOK_NONE = '_' , JSON_TOK_OBJECT_START = '{' , JSON_TOK_OBJECT_END = '}' , JSON_TOK_LIST_START = '[' , JSON_TOK_LIST_END = ']' , JSON_TOK_STRING = '"' , JSON_TOK_COLON = ':' , JSON_TOK_COMMA = ',' , JSON_TOK_NUMBER = '0' , JSON_TOK_TRUE = 't' , JSON_TOK_FALSE = 'f' , JSON_TOK_NULL = 'n' , JSON_TOK_ERROR = '!' , JSON_TOK_EOF = '\0' } |
Functions | |
int | json_obj_parse (char *json, size_t len, const struct json_obj_descr *descr, size_t descr_len, void *val) |
Parses the JSON-encoded object pointer to by json, with size len, according to the descriptor pointed to by descr. Values are stored in a struct pointed to by val. Set up the descriptor like this: More... | |
ssize_t | json_escape (char *str, size_t *len, size_t buf_size) |
Escapes the string so it can be used to encode JSON objects. More... | |
size_t | json_calc_escaped_len (const char *str, size_t len) |
Calculates the JSON-escaped string length. More... | |
ssize_t | json_calc_encoded_len (const struct json_obj_descr *descr, size_t descr_len, const void *val) |
Calculates the string length to fully encode an object. More... | |
int | json_obj_encode_buf (const struct json_obj_descr *descr, size_t descr_len, const void *val, char *buffer, size_t buf_size) |
Encodes an object in a contiguous memory location. More... | |
int | json_arr_encode_buf (const struct json_obj_descr *descr, const void *val, char *buffer, size_t buf_size) |
Encodes an array in a contiguous memory location. More... | |
int | json_obj_encode (const struct json_obj_descr *descr, size_t descr_len, const void *val, json_append_bytes_t append_bytes, void *data) |
Encodes an object using an arbitrary writer function. More... | |
int | json_arr_encode (const struct json_obj_descr *descr, const void *val, json_append_bytes_t append_bytes, void *data) |
Encodes an array using an arbitrary writer function. More... | |