333{
335 if (!poObjGeoms)
336 {
337 lwerror(
"Unable to find 'geometries' in GeoJSON string");
338 return NULL;
339 }
341
342 if (json_type_array == json_object_get_type(poObjGeoms))
343 {
344 const int nGeoms = json_object_array_length(poObjGeoms);
345 for (int i = 0; i < nGeoms; ++i)
346 {
347 json_object *poObjGeom = json_object_array_get_idx(poObjGeoms, i);
349 if (t)
351 else
352 {
354 return NULL;
355 }
356 }
357 }
358
359 return geom;
360}
void lwgeom_free(LWGEOM *geom)
LWCOLLECTION * lwcollection_construct_empty(uint8_t type, int32_t srid, char hasz, char hasm)
LWCOLLECTION * lwcollection_add_lwgeom(LWCOLLECTION *col, const LWGEOM *geom)
Appends geom to the collection managed by col.
void void lwerror(const char *fmt,...) __attribute__((format(printf
Write a notice out to the error handler.
static LWGEOM * parse_geojson(json_object *geojson, int *hasz)
static json_object * findMemberByName(json_object *poObj, const char *pszName)