1838{
1840 double dist;
1841 LWGEOM *inlwgeom, *outlwgeom;
1843
1844 POSTGIS_DEBUG(2, "LWGEOM_segmentize2d called");
1845
1846 ingeom = PG_GETARG_GSERIALIZED_P(0);
1847 dist = PG_GETARG_FLOAT8(1);
1849
1850
1853 {
1854 PG_RETURN_POINTER(ingeom);
1855 }
1856
1857 if (dist <= 0)
1858 {
1859
1860
1861 elog(ERROR, "ST_Segmentize: invalid max_distance %g (must be >= 0)", dist);
1862 PG_RETURN_NULL();
1863 }
1864
1865 LWGEOM_INIT();
1866
1869 {
1870
1872 PG_RETURN_POINTER(ingeom);
1873 }
1874
1876 if (!outlwgeom)
1877 {
1878
1879 PG_FREE_IF_COPY(ingeom, 0);
1880 PG_RETURN_NULL();
1881 }
1882
1883
1886
1887 outgeom = geometry_serialize(outlwgeom);
1888
1889
1891
1892 PG_FREE_IF_COPY(ingeom, 0);
1893
1894 PG_RETURN_POINTER(outgeom);
1895}
GBOX * gbox_copy(const GBOX *box)
Return a copy of the GBOX, based on dimensionality of flags.
LWGEOM * lwgeom_from_gserialized(const GSERIALIZED *g)
Allocate a new LWGEOM from a GSERIALIZED.
uint32_t gserialized_get_type(const GSERIALIZED *g)
Extract the geometry type from the serialized form (it hides in the anonymous data area,...
void lwgeom_free(LWGEOM *geom)
#define POINTTYPE
LWTYPE numbers, used internally by PostGIS.
#define POLYHEDRALSURFACETYPE
LWGEOM * lwgeom_segmentize2d(const LWGEOM *line, double dist)
static int lwgeom_is_empty(const LWGEOM *geom)
Return true or false depending on whether a geometry is an "empty" geometry (no vertices members)