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;
 
  350                 double gridSize = -1;
 
  353                 funcctx = SRF_FIRSTCALL_INIT();
 
  358                 oldcontext = MemoryContextSwitchTo(funcctx->multi_call_memory_ctx);
 
  363                 gser = PG_GETARG_GSERIALIZED_P(0);
 
  369                 if ( PG_NARGS() > 1 && ! PG_ARGISNULL(1) )
 
  370                         maxvertices = PG_GETARG_INT32(1);
 
  375                 if ( PG_NARGS() > 2 && ! PG_ARGISNULL(2) )
 
  376                         gridSize = PG_GETARG_FLOAT8(2);
 
  384                         SRF_RETURN_DONE(funcctx);
 
  387                 fctx = (collection_fctx *) palloc(
sizeof(collection_fctx));
 
  391                 fctx->numgeoms = col->
ngeoms;
 
  395                 funcctx->user_fctx = fctx;
 
  396                 MemoryContextSwitchTo(oldcontext);
 
  400         funcctx = SRF_PERCALL_SETUP();
 
  401         fctx = funcctx->user_fctx;
 
  403         if (fctx->nextgeom < fctx->numgeoms)
 
  405                 GSERIALIZED *gpart = geometry_serialize(fctx->col->geoms[fctx->nextgeom]);
 
  407                 SRF_RETURN_NEXT(funcctx, PointerGetDatum(gpart));
 
  412                 SRF_RETURN_DONE(funcctx);
 
char result[OUT_DOUBLE_BUFFER_SIZE]
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)
char * lwgeom_to_hexwkb_buffer(const LWGEOM *geom, uint8_t variant)
int lwgeom_is_collection(const LWGEOM *lwgeom)
Determine whether a LWGEOM can contain sub-geometries or not.
void * lwalloc(size_t size)
LWPOLY * lwgeom_as_lwpoly(const LWGEOM *lwgeom)
LWCOLLECTION * lwgeom_subdivide_prec(const LWGEOM *geom, uint32_t maxvertices, double gridSize)
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)
GEOMDUMPNODE * stack[MAXDEPTH]