34 #include "utils/elog.h"
35 #include "utils/array.h"
36 #include "utils/geo_decls.h"
39 #include "../postgis_config.h"
41 #include "lwgeom_pg.h"
64 #define PUSH(x,y) ((x)->stack[(x)->stacklen++]=(y))
65 #define LAST(x) ((x)->stack[(x)->stacklen-1])
66 #define POP(x) (--((x)->stacklen))
75 FuncCallContext *funcctx;
80 AttInMetadata *attinmeta;
81 MemoryContext oldcontext, newcontext;
88 if (SRF_IS_FIRSTCALL())
90 funcctx = SRF_FIRSTCALL_INIT();
91 newcontext = funcctx->multi_call_memory_ctx;
93 oldcontext = MemoryContextSwitchTo(newcontext);
95 pglwgeom = PG_GETARG_GSERIALIZED_P_COPY(0);
100 state->
root = lwgeom;
114 funcctx->user_fctx = state;
120 get_call_result_type(fcinfo, 0, &tupdesc);
121 BlessTupleDesc(tupdesc);
127 attinmeta = TupleDescGetAttInMetadata(tupdesc);
128 funcctx->attinmeta = attinmeta;
130 MemoryContextSwitchTo(oldcontext);
134 funcctx = SRF_PERCALL_SETUP();
135 newcontext = funcctx->multi_call_memory_ctx;
138 state = funcctx->user_fctx;
141 if ( ! state->
root ) SRF_RETURN_DONE(funcctx);
148 tuple = BuildTupleFromCStrings(funcctx->attinmeta, values);
149 result = HeapTupleGetDatum(tuple);
152 SRF_RETURN_NEXT(funcctx, result);
170 if ( i ) ptr += sprintf(ptr,
",");
171 ptr += sprintf(ptr,
"%d", state->
stack[i]->
idx+1);
185 oldcontext = MemoryContextSwitchTo(newcontext);
192 MemoryContextSwitchTo(oldcontext);
197 if ( !
POP(state) ) SRF_RETURN_DONE(funcctx);
205 tuple = BuildTupleFromCStrings(funcctx->attinmeta, values);
206 result = TupleGetDatum(funcctx->slot, tuple);
208 SRF_RETURN_NEXT(funcctx, result);
222 FuncCallContext *funcctx;
226 AttInMetadata *attinmeta;
227 MemoryContext oldcontext, newcontext;
232 if (SRF_IS_FIRSTCALL())
234 funcctx = SRF_FIRSTCALL_INIT();
235 newcontext = funcctx->multi_call_memory_ctx;
237 oldcontext = MemoryContextSwitchTo(newcontext);
239 pglwgeom = PG_GETARG_GSERIALIZED_P_COPY(0);
242 elog(ERROR,
"Input is not a polygon");
250 assert (state->
poly);
253 funcctx->user_fctx = state;
259 get_call_result_type(fcinfo, 0, &tupdesc);
260 BlessTupleDesc(tupdesc);
266 attinmeta = TupleDescGetAttInMetadata(tupdesc);
267 funcctx->attinmeta = attinmeta;
269 MemoryContextSwitchTo(oldcontext);
273 funcctx = SRF_PERCALL_SETUP();
274 newcontext = funcctx->multi_call_memory_ctx;
277 state = funcctx->user_fctx;
288 oldcontext = MemoryContextSwitchTo(newcontext);
301 sprintf(address,
"{%d}", state->
ringnum);
306 MemoryContextSwitchTo(oldcontext);
308 tuple = BuildTupleFromCStrings(funcctx->attinmeta, values);
309 result = HeapTupleGetDatum(tuple);
311 SRF_RETURN_NEXT(funcctx, result);
314 SRF_RETURN_DONE(funcctx);
338 FuncCallContext *funcctx;
339 collection_fctx *fctx;
340 MemoryContext oldcontext;
343 if (SRF_IS_FIRSTCALL())
349 int maxvertices = 128;
352 funcctx = SRF_FIRSTCALL_INIT();
357 oldcontext = MemoryContextSwitchTo(funcctx->multi_call_memory_ctx);
362 gser = PG_GETARG_GSERIALIZED_P(0);
368 if ( PG_NARGS() > 1 && ! PG_ARGISNULL(1) )
369 maxvertices = PG_GETARG_INT32(1);
377 SRF_RETURN_DONE(funcctx);
380 fctx = (collection_fctx *) palloc(
sizeof(collection_fctx));
384 fctx->numgeoms = col->
ngeoms;
388 funcctx->user_fctx = fctx;
389 MemoryContextSwitchTo(oldcontext);
393 funcctx = SRF_PERCALL_SETUP();
394 fctx = funcctx->user_fctx;
396 if (fctx->nextgeom < fctx->numgeoms)
400 SRF_RETURN_NEXT(funcctx, PointerGetDatum(gpart));
405 SRF_RETURN_DONE(funcctx);
LWGEOM * lwgeom_from_gserialized(const GSERIALIZED *g)
Allocate a new LWGEOM from a GSERIALIZED.
uint32_t gserialized_get_type(const GSERIALIZED *g)
Extract the geometry type from the serialized form (it hides in the anonymous data area,...
POINTARRAY * ptarray_clone_deep(const POINTARRAY *ptarray)
Deep clone a pointarray (also clones serialized pointlist)
LWCOLLECTION * lwgeom_subdivide(const LWGEOM *geom, uint32_t maxvertices)
int lwgeom_is_collection(const LWGEOM *lwgeom)
Determine whether a LWGEOM can contain sub-geometries or not.
char * lwgeom_to_hexwkb(const LWGEOM *geom, uint8_t variant, size_t *size_out)
void * lwalloc(size_t size)
LWPOLY * lwgeom_as_lwpoly(const LWGEOM *lwgeom)
LWPOLY * lwpoly_construct(int32_t srid, GBOX *bbox, uint32_t nrings, POINTARRAY **points)
This library is the generic geometry handling section of PostGIS.
Datum ST_Subdivide(PG_FUNCTION_ARGS)
struct GEOMDUMPNODE_T GEOMDUMPNODE
Datum LWGEOM_dump_rings(PG_FUNCTION_ARGS)
struct GEOMDUMPSTATE GEOMDUMPSTATE
PG_FUNCTION_INFO_V1(LWGEOM_dump)
Datum LWGEOM_dump(PG_FUNCTION_ARGS)
static int lwgeom_is_empty(const LWGEOM *geom)
Return true or false depending on whether a geometry is an "empty" geometry (no vertices members)
GSERIALIZED * geometry_serialize(LWGEOM *lwgeom)
GEOMDUMPNODE * stack[MAXDEPTH]