Search for projections given extent and (optional) auth_name returns TABLE(auth_name, auth_srid, srtext, proj4text, point_sw, point_ne)
701 FuncCallContext *funcctx;
702 MemoryContext oldcontext;
712 if (SRF_IS_FIRSTCALL())
716 text *auth_name = PG_GETARG_TEXT_P(1);
718 funcctx = SRF_FIRSTCALL_INIT();
719 oldcontext = MemoryContextSwitchTo(funcctx->multi_call_memory_ctx);
736 if (get_call_result_type(fcinfo, 0, &funcctx->tuple_desc) != TYPEFUNC_COMPOSITE)
738 ereport(ERROR, (errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
739 errmsg(
"%s called with incompatible return type", __func__)));
742 BlessTupleDesc(funcctx->tuple_desc);
743 funcctx->user_fctx = state;
744 MemoryContextSwitchTo(oldcontext);
748 funcctx = SRF_PERCALL_SETUP();
749 state = funcctx->user_fctx;
755 SRF_RETURN_DONE(funcctx);
761 funcctx->tuple_desc);
764 SRF_RETURN_NEXT(funcctx,
result);
767 SRF_RETURN_DONE(funcctx);
char result[OUT_DOUBLE_BUFFER_SIZE]
LWGEOM * lwgeom_from_gserialized(const GSERIALIZED *g)
Allocate a new LWGEOM from a GSERIALIZED.
static struct srs_data * srs_state_init()
static Datum srs_tuple_from_entry(const struct srs_entry *entry, TupleDesc tuple_desc)
static void srs_find_planar(const char *auth_name, const LWGEOM *bounds, struct srs_data *state)
struct srs_entry * entries