33 #define CHECK_LWGEOM_ZM 1
46 #ifdef CHECK_LWGEOM_ZM
51 LWDEBUGF(2,
"lwcollection_construct called with %d, %d, %p, %d, %p.",
type, srid, bbox, ngeoms, geoms);
54 lwerror(
"Non-collection type specified in collection constructor!");
62 #ifdef CHECK_LWGEOM_ZM
65 LWDEBUGF(3,
"lwcollection_construct type[0]=%d", geoms[0]->
type);
67 for (i=1; i<ngeoms; i++)
69 LWDEBUGF(3,
"lwcollection_construct type=[%d]=%d", i, geoms[i]->
type);
72 lwerror(
"lwcollection_construct: mixed dimension geometries: %d/%d", zm,
FLAGS_GET_ZM(geoms[i]->flags));
97 lwerror(
"Non-collection type specified in collection constructor!");
132 for (i=0; i<g->
ngeoms; i++)
158 for (i=0; i<g->
ngeoms; i++)
177 if ( ngeoms <= col->maxgeoms )
return;
190 if (!col || !geom)
return NULL;
194 lwerror(
"Collection is in inconsistent state. Null memory but non-zero collection counts.");
215 #if PARANOIA_LEVEL > 1
220 for (i = 0; i < col->
ngeoms; i++)
222 if (col->
geoms[i] == geom)
224 lwerror(
"%s [%d] found duplicate geometry in collection %p == %p", __FILE__, __LINE__, col->
geoms[i], geom);
244 if (!col1 || !col2)
return NULL;
245 for (i = 0; i < col2->
ngeoms; i++)
259 for (i = 0; i < col->
ngeoms; i++)
264 for (j = 0; j < i; j++)
283 LWDEBUG(2,
"lwcollection_same called");
288 for ( i = 0; i < c1->
ngeoms; i++ )
326 lwerror(
"Null input geometry.");
330 for ( i = 0; i < col->
ngeoms; i++ )
366 for ( i = 0; i < col->
ngeoms; i++ )
392 int geomlistsize = 16;
396 if (!col)
return NULL;
411 "Only POLYGON, LINESTRING and POINT are supported by "
412 "lwcollection_extract. %s requested.",
420 for (i = 0; i < col->
ngeoms; i++)
430 if (geomlistlen == geomlistsize)
434 geomlist,
sizeof(
LWGEOM*) * geomlistsize);
445 for (j = 0; j < tmpcol->
ngeoms; j++)
449 if (geomlistlen == geomlistsize)
456 geomlist[geomlistlen] = tmpcol->
geoms[j];
469 outtype, col->
srid, NULL, geomlistlen, geomlist);
500 for( i = 0; i < col->
ngeoms; i++ )
515 for ( i = 0; i < col->
ngeoms; i++ )
551 if ( collectiontype ==
TINTYPE &&
GBOX * gbox_copy(const GBOX *box)
Return a copy of the GBOX, based on dimensionality of flags.
char lwgeom_same(const LWGEOM *lwgeom1, const LWGEOM *lwgeom2)
geom1 same as geom2 iff
LWGEOM * lwcollection_as_lwgeom(const LWCOLLECTION *obj)
int lwgeom_startpoint(const LWGEOM *lwgeom, POINT4D *pt)
void lwgeom_free(LWGEOM *geom)
LWGEOM * lwgeom_segmentize2d(const LWGEOM *line, double dist)
#define FLAGS_SET_BBOX(flags, value)
LWGEOM * lwgeom_clone_deep(const LWGEOM *lwgeom)
Deep clone an LWGEOM, everything is copied.
int lwtype_is_collection(uint8_t type)
Determine whether a type number is a collection or not.
#define POINTTYPE
LWTYPE numbers, used internally by PostGIS.
#define FLAGS_GET_Z(flags)
uint32_t lwgeom_count_vertices(const LWGEOM *geom)
Count the total number of vertices in any LWGEOM.
void * lwrealloc(void *mem, size_t size)
#define POLYHEDRALSURFACETYPE
const char * lwtype_name(uint8_t type)
Return the type name string associated with a type number (e.g.
#define FLAGS_GET_M(flags)
#define FLAGS_GET_ZM(flags)
LWGEOM * lwgeom_clone(const LWGEOM *lwgeom)
Clone LWGEOM object.
int lwgeom_calculate_gbox(const LWGEOM *lwgeom, GBOX *gbox)
Calculate bounding box of a geometry, automatically taking into account whether it is cartesian or ge...
void * lwalloc(size_t size)
lwflags_t lwflags(int hasz, int hasm, int geodetic)
Construct a new flags bitmask.
#define LW_TRUE
Return types for functions with status returns.
void lwgeom_release(LWGEOM *lwgeom)
Free the containing LWGEOM and the associated BOX.
LWGEOM * lwgeom_force_dims(const LWGEOM *lwgeom, int hasz, int hasm)
int lwcollection_is_empty(const LWCOLLECTION *col)
LWCOLLECTION * lwcollection_clone(const LWCOLLECTION *g)
Clone LWCOLLECTION object.
char lwcollection_same(const LWCOLLECTION *c1, const LWCOLLECTION *c2)
check for same geometry composition
LWCOLLECTION * lwcollection_force_dims(const LWCOLLECTION *col, int hasz, int hasm)
LWCOLLECTION * lwcollection_segmentize2d(const LWCOLLECTION *col, double dist)
LWGEOM * lwcollection_getsubgeom(LWCOLLECTION *col, int gnum)
int lwcollection_startpoint(const LWCOLLECTION *col, POINT4D *pt)
void lwcollection_release(LWCOLLECTION *lwcollection)
LWCOLLECTION * lwcollection_construct_empty(uint8_t type, int32_t srid, char hasz, char hasm)
void lwcollection_free(LWCOLLECTION *col)
int lwcollection_ngeoms(const LWCOLLECTION *col)
LWCOLLECTION * lwcollection_concat_in_place(LWCOLLECTION *col1, const LWCOLLECTION *col2)
Appends all geometries from col2 to col1 in place.
void lwcollection_reserve(LWCOLLECTION *col, uint32_t ngeoms)
Ensure the collection can hold up at least ngeoms.
LWCOLLECTION * lwcollection_extract(LWCOLLECTION *col, int type)
Takes a potentially heterogeneous collection and returns a homogeneous collection consisting only of ...
LWCOLLECTION * lwcollection_add_lwgeom(LWCOLLECTION *col, const LWGEOM *geom)
Appends geom to the collection managed by col.
LWCOLLECTION * lwcollection_construct(uint8_t type, int32_t srid, GBOX *bbox, uint32_t ngeoms, LWGEOM **geoms)
uint32_t lwcollection_count_vertices(LWCOLLECTION *col)
int lwcollection_allows_subtype(int collectiontype, int subtype)
Check if subtype is allowed in collectiontype.
LWCOLLECTION * lwcollection_clone_deep(const LWCOLLECTION *g)
Deep clone LWCOLLECTION object.
#define LWDEBUG(level, msg)
#define LWDEBUGF(level, msg,...)
void lwerror(const char *fmt,...)
Write a notice out to the error handler.
static int lwgeom_is_empty(const LWGEOM *geom)
Return true or false depending on whether a geometry is an "empty" geometry (no vertices members)