a/util: Make JSON reading more robust.

We were missing some null checks.
This commit is contained in:
Ryan Pavlik 2021-04-23 17:31:07 -05:00 committed by Christoph Haag
parent cfbb81cb71
commit 23c73e145b
2 changed files with 14 additions and 1 deletions

View file

@ -0,0 +1 @@
Make config file reading more robust.

View file

@ -97,6 +97,9 @@ get_obj(cJSON *json, const char *name)
XRT_MAYBE_UNUSED static bool XRT_MAYBE_UNUSED static bool
get_obj_bool(cJSON *json, const char *name, bool *out_bool) get_obj_bool(cJSON *json, const char *name, bool *out_bool)
{ {
if (json == NULL) {
return false;
}
cJSON *item = get_obj(json, name); cJSON *item = get_obj(json, name);
if (item == NULL) { if (item == NULL) {
return false; return false;
@ -113,6 +116,9 @@ get_obj_bool(cJSON *json, const char *name, bool *out_bool)
static bool static bool
get_obj_int(cJSON *json, const char *name, int *out_int) get_obj_int(cJSON *json, const char *name, int *out_int)
{ {
if (json == NULL) {
return false;
}
cJSON *item = get_obj(json, name); cJSON *item = get_obj(json, name);
if (item == NULL) { if (item == NULL) {
return false; return false;
@ -129,6 +135,9 @@ get_obj_int(cJSON *json, const char *name, int *out_int)
static bool static bool
get_obj_float(cJSON *json, const char *name, float *out_float) get_obj_float(cJSON *json, const char *name, float *out_float)
{ {
if (json == NULL) {
return false;
}
cJSON *item = get_obj(json, name); cJSON *item = get_obj(json, name);
if (item == NULL) { if (item == NULL) {
return false; return false;
@ -145,6 +154,9 @@ get_obj_float(cJSON *json, const char *name, float *out_float)
static bool static bool
get_obj_str(cJSON *json, const char *name, char *array, size_t array_size) get_obj_str(cJSON *json, const char *name, char *array, size_t array_size)
{ {
if (json == NULL) {
return false;
}
cJSON *item = get_obj(json, name); cJSON *item = get_obj(json, name);
if (item == NULL) { if (item == NULL) {
return false; return false;
@ -318,7 +330,7 @@ u_config_json_get_tracking_overrides(struct u_config_json *json,
o->offset.orientation.w = 1; o->offset.orientation.w = 1;
} }
char input_name[512]; char input_name[512] = {'\0'};
get_obj_str(override, "xrt_input_name", input_name, 512); get_obj_str(override, "xrt_input_name", input_name, 512);
o->input_name = xrt_input_name_enum(input_name); o->input_name = xrt_input_name_enum(input_name);