759{
760 StringInfo buf = (StringInfo) PG_GETARG_POINTER(0);
761 int32 geom_typmod = -1;
764
765 if ( (PG_NARGS()>2) && (!PG_ARGISNULL(2)) ) {
766 geom_typmod = PG_GETARG_INT32(2);
767 }
768
770 if ( !lwgeom )
771 {
772 ereport(ERROR,(errmsg("recv error - invalid geometry")));
773 PG_RETURN_NULL();
774 }
775
778
779
780 buf->cursor = buf->len;
781
784
785 if ( geom_typmod >= 0 )
786 {
788 POSTGIS_DEBUG(3, "typmod and geometry were consistent");
789 }
790 else
791 {
792 POSTGIS_DEBUG(3, "typmod was -1");
793 }
794
795
796 PG_RETURN_POINTER(geom);
797}
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.
GSERIALIZED * geometry_serialize(LWGEOM *lwgeom)