Search for projections given extent and (optional) auth_name returns TABLE(auth_name, auth_srid, srtext, proj4text, point_sw, point_ne)
704 FuncCallContext *funcctx;
705 MemoryContext oldcontext;
715 if (SRF_IS_FIRSTCALL())
719 text *auth_name = PG_GETARG_TEXT_P(1);
721 funcctx = SRF_FIRSTCALL_INIT();
722 oldcontext = MemoryContextSwitchTo(funcctx->multi_call_memory_ctx);
739 if (get_call_result_type(fcinfo, 0, &funcctx->tuple_desc) != TYPEFUNC_COMPOSITE)
741 ereport(ERROR, (errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
742 errmsg(
"%s called with incompatible return type", __func__)));
745 BlessTupleDesc(funcctx->tuple_desc);
746 funcctx->user_fctx = state;
747 MemoryContextSwitchTo(oldcontext);
751 funcctx = SRF_PERCALL_SETUP();
752 state = funcctx->user_fctx;
758 SRF_RETURN_DONE(funcctx);
764 funcctx->tuple_desc);
767 SRF_RETURN_NEXT(funcctx,
result);
770 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