692{
693 StringInfo buf = (StringInfo) PG_GETARG_POINTER(0);
694 int32 geom_typmod = -1;
697
698 if ( (PG_NARGS()>2) && (!PG_ARGISNULL(2)) ) {
699 geom_typmod = PG_GETARG_INT32(2);
700 }
701
703 if ( !lwgeom )
704 {
705 ereport(ERROR,(errmsg("recv error - invalid geometry")));
706 PG_RETURN_NULL();
707 }
708
711
712
713 buf->cursor = buf->len;
714
715 geom = geometry_serialize(lwgeom);
717
718 if ( geom_typmod >= 0 )
719 {
721 POSTGIS_DEBUG(3, "typmod and geometry were consistent");
722 }
723 else
724 {
725 POSTGIS_DEBUG(3, "typmod was -1");
726 }
727
728
729 PG_RETURN_POINTER(geom);
730}
GSERIALIZED * postgis_valid_typmod(GSERIALIZED *gser, int32_t typmod)
Check the consistency of the metadata we want to enforce in the typmod: srid, type and dimensionality...
#define LW_PARSER_CHECK_ALL
void lwgeom_free(LWGEOM *geom)
int lwgeom_needs_bbox(const LWGEOM *geom)
Check whether or not a lwgeom is big enough to warrant a bounding box.
LWGEOM * lwgeom_from_wkb(const uint8_t *wkb, const size_t wkb_size, const char check)
WKB inputs must have a declared size, to prevent malformed WKB from reading off the end of the memory...
void lwgeom_add_bbox(LWGEOM *lwgeom)
Compute a bbox if not already computed.