77         FuncCallContext *funcctx;
 
   78         MemoryContext oldcontext, newcontext;
 
   88         bool isnull[2] = {0,0}; 
 
   91         if (SRF_IS_FIRSTCALL()) {
 
   92                 funcctx = SRF_FIRSTCALL_INIT();
 
   94                 newcontext = funcctx->multi_call_memory_ctx;
 
   95                 oldcontext = MemoryContextSwitchTo(newcontext);
 
   98                 pglwgeom = PG_GETARG_GSERIALIZED_P_COPY(0);
 
  103                         MemoryContextSwitchTo(oldcontext);
 
  104                         funcctx = SRF_PERCALL_SETUP();
 
  105                         SRF_RETURN_DONE(funcctx);
 
  109                 state = 
lwalloc(
sizeof *state);
 
  110                 state->
root = lwgeom;
 
  116                 funcctx->user_fctx = state;
 
  129                 if (get_call_result_type(fcinfo, 0, &funcctx->tuple_desc) != TYPEFUNC_COMPOSITE) {
 
  130                         ereport(ERROR, (errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
 
  131                                 errmsg(
"set-valued function called in context that cannot accept a set")));
 
  134                 BlessTupleDesc(funcctx->tuple_desc);
 
  137                 get_typlenbyvalalign(INT4OID, &state->
typlen, &state->
byval, &state->
align);
 
  139                 MemoryContextSwitchTo(oldcontext);
 
  143         funcctx = SRF_PERCALL_SETUP();
 
  144         newcontext = funcctx->multi_call_memory_ctx;
 
  147         state = funcctx->user_fctx;
 
  172                                 switch(lwgeom->
type) {
 
  175                                                 if (state->
pt == 0) {
 
  178                                                 if (state->
pt <= 3) {
 
  236                                                 ereport(ERROR, (errcode(ERRCODE_DATA_EXCEPTION),
 
  237                                                         errmsg(
"Invalid Geometry type %d passed to ST_DumpPoints()", lwgeom->
type)));
 
  252                                 if (--state->
stacklen == 0) SRF_RETURN_DONE(funcctx);
 
  260                                 pathpt[0] = PointerGetDatum(construct_array(state->
path, state->
pathlen+1,
 
  263                                 pathpt[1] = PointerGetDatum(geometry_serialize((
LWGEOM*)lwpoint));
 
  265                                 tuple = heap_form_tuple(funcctx->tuple_desc, pathpt, isnull);
 
  266                                 result = HeapTupleGetDatum(tuple);
 
  267                                 SRF_RETURN_NEXT(funcctx, 
result);
 
  276                         lwgeom = lwcoll->
geoms[node->
idx++];
 
  291                 if (--state->
stacklen == 0) SRF_RETURN_DONE(funcctx);
 
char result[OUT_DOUBLE_BUFFER_SIZE]
LWGEOM * lwgeom_from_gserialized(const GSERIALIZED *g)
Allocate a new LWGEOM from a GSERIALIZED.
LWLINE * lwgeom_as_lwline(const LWGEOM *lwgeom)
LWPOINT * lwcircstring_get_lwpoint(const LWCIRCSTRING *circ, uint32_t where)
int lwgeom_has_z(const LWGEOM *geom)
Return LW_TRUE if geometry has Z ordinates.
#define POINTTYPE
LWTYPE numbers, used internally by PostGIS.
LWTRIANGLE * lwgeom_as_lwtriangle(const LWGEOM *lwgeom)
int lwgeom_is_collection(const LWGEOM *lwgeom)
Determine whether a LWGEOM can contain sub-geometries or not.
int getPoint4d_p(const POINTARRAY *pa, uint32_t n, POINT4D *point)
void * lwalloc(size_t size)
LWCIRCSTRING * lwgeom_as_lwcircstring(const LWGEOM *lwgeom)
LWPOLY * lwgeom_as_lwpoly(const LWGEOM *lwgeom)
int lwgeom_has_m(const LWGEOM *geom)
Return LW_TRUE if geometry has M ordinates.
LWPOINT * lwpoint_make(int32_t srid, int hasz, int hasm, const POINT4D *p)
LWPOINT * lwline_get_lwpoint(const LWLINE *line, uint32_t where)
Returns freshly allocated LWPOINT that corresponds to the index where.
static int lwgeom_is_empty(const LWGEOM *geom)
Return true or false depending on whether a geometry is an "empty" geometry (no vertices members)
static LWPOINT * lwgeom_as_lwpoint(const LWGEOM *lwgeom)
struct dumpnode stack[MAXDEPTH]