485 if ( PG_ARGISNULL(0) ) PG_RETURN_NULL();
487 geom = PG_GETARG_GSERIALIZED_P(0);
493 if ( PG_NARGS() > 1 && ! PG_ARGISNULL(1) )
494 sp.precision_xy = PG_GETARG_INT32(1);
497 if ( PG_NARGS() > 2 && ! PG_ARGISNULL(2) )
498 sp.precision_z = PG_GETARG_INT32(2);
501 if ( PG_NARGS() > 3 && ! PG_ARGISNULL(3) )
502 sp.precision_m = PG_GETARG_INT32(3);
508 if ( PG_NARGS() > 4 && ! PG_ARGISNULL(4) && PG_GETARG_BOOL(4) )
512 if ( PG_NARGS() > 5 && ! PG_ARGISNULL(5) && PG_GETARG_BOOL(5) )
520 result = palloc(twkb_size + VARHDRSZ);
521 memcpy(VARDATA(result), twkb, twkb_size);
522 SET_VARSIZE(result, twkb_size + VARHDRSZ);
524 PG_RETURN_BYTEA_P(result);
int32_t gserialized_get_srid(const GSERIALIZED *g)
Extract the SRID from the serialized form (it is packed into three bytes so this is a handy function)...
LWGEOM * lwgeom_from_gserialized(const GSERIALIZED *g)
Allocate a new LWGEOM from a GSERIALIZED.
#define TWKB_DEFAULT_PRECISION
uint8_t * lwgeom_to_twkb(const LWGEOM *geom, uint8_t variant, int8_t precision_xy, int8_t precision_z, int8_t precision_m, size_t *twkb_size)