#include #include #include #include "geographic_area.h" OpenAPI_geographic_area_t *OpenAPI_geographic_area_create( OpenAPI_supported_gad_shapes_t *shape, OpenAPI_geographical_coordinates_t *point, float uncertainty, OpenAPI_uncertainty_ellipse_t *uncertainty_ellipse, int confidence, OpenAPI_list_t *point_list, double altitude, float uncertainty_altitude, int inner_radius, float uncertainty_radius, int offset_angle, int included_angle ) { OpenAPI_geographic_area_t *geographic_area_local_var = ogs_malloc(sizeof(OpenAPI_geographic_area_t)); ogs_assert(geographic_area_local_var); geographic_area_local_var->shape = shape; geographic_area_local_var->point = point; geographic_area_local_var->uncertainty = uncertainty; geographic_area_local_var->uncertainty_ellipse = uncertainty_ellipse; geographic_area_local_var->confidence = confidence; geographic_area_local_var->point_list = point_list; geographic_area_local_var->altitude = altitude; geographic_area_local_var->uncertainty_altitude = uncertainty_altitude; geographic_area_local_var->inner_radius = inner_radius; geographic_area_local_var->uncertainty_radius = uncertainty_radius; geographic_area_local_var->offset_angle = offset_angle; geographic_area_local_var->included_angle = included_angle; return geographic_area_local_var; } void OpenAPI_geographic_area_free(OpenAPI_geographic_area_t *geographic_area) { OpenAPI_lnode_t *node = NULL; if (NULL == geographic_area) { return; } if (geographic_area->shape) { OpenAPI_supported_gad_shapes_free(geographic_area->shape); geographic_area->shape = NULL; } if (geographic_area->point) { OpenAPI_geographical_coordinates_free(geographic_area->point); geographic_area->point = NULL; } if (geographic_area->uncertainty_ellipse) { OpenAPI_uncertainty_ellipse_free(geographic_area->uncertainty_ellipse); geographic_area->uncertainty_ellipse = NULL; } if (geographic_area->point_list) { OpenAPI_list_for_each(geographic_area->point_list, node) { OpenAPI_geographical_coordinates_free(node->data); } OpenAPI_list_free(geographic_area->point_list); geographic_area->point_list = NULL; } ogs_free(geographic_area); } cJSON *OpenAPI_geographic_area_convertToJSON(OpenAPI_geographic_area_t *geographic_area) { cJSON *item = NULL; OpenAPI_lnode_t *node = NULL; if (geographic_area == NULL) { ogs_error("OpenAPI_geographic_area_convertToJSON() failed [GeographicArea]"); return NULL; } item = cJSON_CreateObject(); if (!geographic_area->shape) { ogs_error("OpenAPI_geographic_area_convertToJSON() failed [shape]"); return NULL; } cJSON *shape_local_JSON = OpenAPI_supported_gad_shapes_convertToJSON(geographic_area->shape); if (shape_local_JSON == NULL) { ogs_error("OpenAPI_geographic_area_convertToJSON() failed [shape]"); goto end; } cJSON_AddItemToObject(item, "shape", shape_local_JSON); if (item->child == NULL) { ogs_error("OpenAPI_geographic_area_convertToJSON() failed [shape]"); goto end; } if (!geographic_area->point) { ogs_error("OpenAPI_geographic_area_convertToJSON() failed [point]"); return NULL; } cJSON *point_local_JSON = OpenAPI_geographical_coordinates_convertToJSON(geographic_area->point); if (point_local_JSON == NULL) { ogs_error("OpenAPI_geographic_area_convertToJSON() failed [point]"); goto end; } cJSON_AddItemToObject(item, "point", point_local_JSON); if (item->child == NULL) { ogs_error("OpenAPI_geographic_area_convertToJSON() failed [point]"); goto end; } if (cJSON_AddNumberToObject(item, "uncertainty", geographic_area->uncertainty) == NULL) { ogs_error("OpenAPI_geographic_area_convertToJSON() failed [uncertainty]"); goto end; } if (!geographic_area->uncertainty_ellipse) { ogs_error("OpenAPI_geographic_area_convertToJSON() failed [uncertainty_ellipse]"); return NULL; } cJSON *uncertainty_ellipse_local_JSON = OpenAPI_uncertainty_ellipse_convertToJSON(geographic_area->uncertainty_ellipse); if (uncertainty_ellipse_local_JSON == NULL) { ogs_error("OpenAPI_geographic_area_convertToJSON() failed [uncertainty_ellipse]"); goto end; } cJSON_AddItemToObject(item, "uncertaintyEllipse", uncertainty_ellipse_local_JSON); if (item->child == NULL) { ogs_error("OpenAPI_geographic_area_convertToJSON() failed [uncertainty_ellipse]"); goto end; } if (cJSON_AddNumberToObject(item, "confidence", geographic_area->confidence) == NULL) { ogs_error("OpenAPI_geographic_area_convertToJSON() failed [confidence]"); goto end; } if (!geographic_area->point_list) { ogs_error("OpenAPI_geographic_area_convertToJSON() failed [point_list]"); return NULL; } cJSON *point_listList = cJSON_AddArrayToObject(item, "pointList"); if (point_listList == NULL) { ogs_error("OpenAPI_geographic_area_convertToJSON() failed [point_list]"); goto end; } OpenAPI_list_for_each(geographic_area->point_list, node) { cJSON *itemLocal = OpenAPI_geographical_coordinates_convertToJSON(node->data); if (itemLocal == NULL) { ogs_error("OpenAPI_geographic_area_convertToJSON() failed [point_list]"); goto end; } cJSON_AddItemToArray(point_listList, itemLocal); } if (cJSON_AddNumberToObject(item, "altitude", geographic_area->altitude) == NULL) { ogs_error("OpenAPI_geographic_area_convertToJSON() failed [altitude]"); goto end; } if (cJSON_AddNumberToObject(item, "uncertaintyAltitude", geographic_area->uncertainty_altitude) == NULL) { ogs_error("OpenAPI_geographic_area_convertToJSON() failed [uncertainty_altitude]"); goto end; } if (cJSON_AddNumberToObject(item, "innerRadius", geographic_area->inner_radius) == NULL) { ogs_error("OpenAPI_geographic_area_convertToJSON() failed [inner_radius]"); goto end; } if (cJSON_AddNumberToObject(item, "uncertaintyRadius", geographic_area->uncertainty_radius) == NULL) { ogs_error("OpenAPI_geographic_area_convertToJSON() failed [uncertainty_radius]"); goto end; } if (cJSON_AddNumberToObject(item, "offsetAngle", geographic_area->offset_angle) == NULL) { ogs_error("OpenAPI_geographic_area_convertToJSON() failed [offset_angle]"); goto end; } if (cJSON_AddNumberToObject(item, "includedAngle", geographic_area->included_angle) == NULL) { ogs_error("OpenAPI_geographic_area_convertToJSON() failed [included_angle]"); goto end; } end: return item; } OpenAPI_geographic_area_t *OpenAPI_geographic_area_parseFromJSON(cJSON *geographic_areaJSON) { OpenAPI_geographic_area_t *geographic_area_local_var = NULL; OpenAPI_lnode_t *node = NULL; cJSON *shape = NULL; OpenAPI_supported_gad_shapes_t *shape_local_nonprim = NULL; cJSON *point = NULL; OpenAPI_geographical_coordinates_t *point_local_nonprim = NULL; cJSON *uncertainty = NULL; cJSON *uncertainty_ellipse = NULL; OpenAPI_uncertainty_ellipse_t *uncertainty_ellipse_local_nonprim = NULL; cJSON *confidence = NULL; cJSON *point_list = NULL; OpenAPI_list_t *point_listList = NULL; cJSON *altitude = NULL; cJSON *uncertainty_altitude = NULL; cJSON *inner_radius = NULL; cJSON *uncertainty_radius = NULL; cJSON *offset_angle = NULL; cJSON *included_angle = NULL; shape = cJSON_GetObjectItemCaseSensitive(geographic_areaJSON, "shape"); if (!shape) { ogs_error("OpenAPI_geographic_area_parseFromJSON() failed [shape]"); goto end; } shape_local_nonprim = OpenAPI_supported_gad_shapes_parseFromJSON(shape); if (!shape_local_nonprim) { ogs_error("OpenAPI_supported_gad_shapes_parseFromJSON failed [shape]"); goto end; } point = cJSON_GetObjectItemCaseSensitive(geographic_areaJSON, "point"); if (!point) { ogs_error("OpenAPI_geographic_area_parseFromJSON() failed [point]"); goto end; } point_local_nonprim = OpenAPI_geographical_coordinates_parseFromJSON(point); if (!point_local_nonprim) { ogs_error("OpenAPI_geographical_coordinates_parseFromJSON failed [point]"); goto end; } uncertainty = cJSON_GetObjectItemCaseSensitive(geographic_areaJSON, "uncertainty"); if (!uncertainty) { ogs_error("OpenAPI_geographic_area_parseFromJSON() failed [uncertainty]"); goto end; } if (!cJSON_IsNumber(uncertainty)) { ogs_error("OpenAPI_geographic_area_parseFromJSON() failed [uncertainty]"); goto end; } uncertainty_ellipse = cJSON_GetObjectItemCaseSensitive(geographic_areaJSON, "uncertaintyEllipse"); if (!uncertainty_ellipse) { ogs_error("OpenAPI_geographic_area_parseFromJSON() failed [uncertainty_ellipse]"); goto end; } uncertainty_ellipse_local_nonprim = OpenAPI_uncertainty_ellipse_parseFromJSON(uncertainty_ellipse); if (!uncertainty_ellipse_local_nonprim) { ogs_error("OpenAPI_uncertainty_ellipse_parseFromJSON failed [uncertainty_ellipse]"); goto end; } confidence = cJSON_GetObjectItemCaseSensitive(geographic_areaJSON, "confidence"); if (!confidence) { ogs_error("OpenAPI_geographic_area_parseFromJSON() failed [confidence]"); goto end; } if (!cJSON_IsNumber(confidence)) { ogs_error("OpenAPI_geographic_area_parseFromJSON() failed [confidence]"); goto end; } point_list = cJSON_GetObjectItemCaseSensitive(geographic_areaJSON, "pointList"); if (!point_list) { ogs_error("OpenAPI_geographic_area_parseFromJSON() failed [point_list]"); goto end; } cJSON *point_list_local = NULL; if (!cJSON_IsArray(point_list)) { ogs_error("OpenAPI_geographic_area_parseFromJSON() failed [point_list]"); goto end; } point_listList = OpenAPI_list_create(); cJSON_ArrayForEach(point_list_local, point_list) { if (!cJSON_IsObject(point_list_local)) { ogs_error("OpenAPI_geographic_area_parseFromJSON() failed [point_list]"); goto end; } OpenAPI_geographical_coordinates_t *point_listItem = OpenAPI_geographical_coordinates_parseFromJSON(point_list_local); if (!point_listItem) { ogs_error("No point_listItem"); goto end; } OpenAPI_list_add(point_listList, point_listItem); } altitude = cJSON_GetObjectItemCaseSensitive(geographic_areaJSON, "altitude"); if (!altitude) { ogs_error("OpenAPI_geographic_area_parseFromJSON() failed [altitude]"); goto end; } if (!cJSON_IsNumber(altitude)) { ogs_error("OpenAPI_geographic_area_parseFromJSON() failed [altitude]"); goto end; } uncertainty_altitude = cJSON_GetObjectItemCaseSensitive(geographic_areaJSON, "uncertaintyAltitude"); if (!uncertainty_altitude) { ogs_error("OpenAPI_geographic_area_parseFromJSON() failed [uncertainty_altitude]"); goto end; } if (!cJSON_IsNumber(uncertainty_altitude)) { ogs_error("OpenAPI_geographic_area_parseFromJSON() failed [uncertainty_altitude]"); goto end; } inner_radius = cJSON_GetObjectItemCaseSensitive(geographic_areaJSON, "innerRadius"); if (!inner_radius) { ogs_error("OpenAPI_geographic_area_parseFromJSON() failed [inner_radius]"); goto end; } if (!cJSON_IsNumber(inner_radius)) { ogs_error("OpenAPI_geographic_area_parseFromJSON() failed [inner_radius]"); goto end; } uncertainty_radius = cJSON_GetObjectItemCaseSensitive(geographic_areaJSON, "uncertaintyRadius"); if (!uncertainty_radius) { ogs_error("OpenAPI_geographic_area_parseFromJSON() failed [uncertainty_radius]"); goto end; } if (!cJSON_IsNumber(uncertainty_radius)) { ogs_error("OpenAPI_geographic_area_parseFromJSON() failed [uncertainty_radius]"); goto end; } offset_angle = cJSON_GetObjectItemCaseSensitive(geographic_areaJSON, "offsetAngle"); if (!offset_angle) { ogs_error("OpenAPI_geographic_area_parseFromJSON() failed [offset_angle]"); goto end; } if (!cJSON_IsNumber(offset_angle)) { ogs_error("OpenAPI_geographic_area_parseFromJSON() failed [offset_angle]"); goto end; } included_angle = cJSON_GetObjectItemCaseSensitive(geographic_areaJSON, "includedAngle"); if (!included_angle) { ogs_error("OpenAPI_geographic_area_parseFromJSON() failed [included_angle]"); goto end; } if (!cJSON_IsNumber(included_angle)) { ogs_error("OpenAPI_geographic_area_parseFromJSON() failed [included_angle]"); goto end; } geographic_area_local_var = OpenAPI_geographic_area_create ( shape_local_nonprim, point_local_nonprim, uncertainty->valuedouble, uncertainty_ellipse_local_nonprim, confidence->valuedouble, point_listList, altitude->valuedouble, uncertainty_altitude->valuedouble, inner_radius->valuedouble, uncertainty_radius->valuedouble, offset_angle->valuedouble, included_angle->valuedouble ); return geographic_area_local_var; end: if (shape_local_nonprim) { OpenAPI_supported_gad_shapes_free(shape_local_nonprim); shape_local_nonprim = NULL; } if (point_local_nonprim) { OpenAPI_geographical_coordinates_free(point_local_nonprim); point_local_nonprim = NULL; } if (uncertainty_ellipse_local_nonprim) { OpenAPI_uncertainty_ellipse_free(uncertainty_ellipse_local_nonprim); uncertainty_ellipse_local_nonprim = NULL; } if (point_listList) { OpenAPI_list_for_each(point_listList, node) { OpenAPI_geographical_coordinates_free(node->data); } OpenAPI_list_free(point_listList); point_listList = NULL; } return NULL; } OpenAPI_geographic_area_t *OpenAPI_geographic_area_copy(OpenAPI_geographic_area_t *dst, OpenAPI_geographic_area_t *src) { cJSON *item = NULL; char *content = NULL; ogs_assert(src); item = OpenAPI_geographic_area_convertToJSON(src); if (!item) { ogs_error("OpenAPI_geographic_area_convertToJSON() failed"); return NULL; } content = cJSON_Print(item); cJSON_Delete(item); if (!content) { ogs_error("cJSON_Print() failed"); return NULL; } item = cJSON_Parse(content); ogs_free(content); if (!item) { ogs_error("cJSON_Parse() failed"); return NULL; } OpenAPI_geographic_area_free(dst); dst = OpenAPI_geographic_area_parseFromJSON(item); cJSON_Delete(item); return dst; }