478 if ( PG_ARGISNULL(0) ) PG_RETURN_NULL();
480 geom = PG_GETARG_GSERIALIZED_P(0);
486 if ( PG_NARGS() > 1 && ! PG_ARGISNULL(1) )
487 sp.precision_xy = PG_GETARG_INT32(1);
490 if ( PG_NARGS() > 2 && ! PG_ARGISNULL(2) )
491 sp.precision_z = PG_GETARG_INT32(2);
494 if ( PG_NARGS() > 3 && ! PG_ARGISNULL(3) )
495 sp.precision_m = PG_GETARG_INT32(3);
501 if ( PG_NARGS() > 4 && ! PG_ARGISNULL(4) && PG_GETARG_BOOL(4) )
505 if ( PG_NARGS() > 5 && ! PG_ARGISNULL(5) && PG_GETARG_BOOL(5) )
513 result = palloc(twkb_size + VARHDRSZ);
514 memcpy(VARDATA(result), twkb, twkb_size);
515 SET_VARSIZE(result, twkb_size + VARHDRSZ);
517 PG_RETURN_BYTEA_P(result);
int32_t gserialized_get_srid(const GSERIALIZED *s)
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)