PostGIS  3.3.9dev-r@@SVN_REVISION@@

◆ LWGEOM_segmentize2d()

Datum LWGEOM_segmentize2d ( PG_FUNCTION_ARGS  )

Definition at line 1868 of file lwgeom_functions_basic.c.

1869 {
1870  GSERIALIZED *outgeom, *ingeom;
1871  double dist;
1872  LWGEOM *inlwgeom, *outlwgeom;
1873  int type;
1874 
1875  POSTGIS_DEBUG(2, "LWGEOM_segmentize2d called");
1876 
1877  ingeom = PG_GETARG_GSERIALIZED_P(0);
1878  dist = PG_GETARG_FLOAT8(1);
1879  type = gserialized_get_type(ingeom);
1880 
1881  /* Avoid types we cannot segmentize. */
1882  if ((type == POINTTYPE) || (type == MULTIPOINTTYPE) || (type == TRIANGLETYPE) || (type == TINTYPE) ||
1884  {
1885  PG_RETURN_POINTER(ingeom);
1886  }
1887 
1888  if (dist <= 0)
1889  {
1890  /* Protect from knowingly infinite loops, see #1799 */
1891  /* Note that we'll end out of memory anyway for other small distances */
1892  elog(ERROR, "ST_Segmentize: invalid max_distance %g (must be >= 0)", dist);
1893  PG_RETURN_NULL();
1894  }
1895 
1896  LWGEOM_INIT();
1897 
1898  inlwgeom = lwgeom_from_gserialized(ingeom);
1899  if (lwgeom_is_empty(inlwgeom))
1900  {
1901  /* Should only happen on interruption */
1902  lwgeom_free(inlwgeom);
1903  PG_RETURN_POINTER(ingeom);
1904  }
1905 
1906  outlwgeom = lwgeom_segmentize2d(inlwgeom, dist);
1907  if (!outlwgeom)
1908  {
1909  /* Should only happen on interruption */
1910  PG_FREE_IF_COPY(ingeom, 0);
1911  PG_RETURN_NULL();
1912  }
1913 
1914  /* Copy input bounding box if any */
1915  if (inlwgeom->bbox)
1916  outlwgeom->bbox = gbox_copy(inlwgeom->bbox);
1917 
1918  outgeom = geometry_serialize(outlwgeom);
1919 
1920  // lwgeom_free(outlwgeom); /* TODO fix lwgeom_clone / ptarray_clone_deep for consistent semantics */
1921  lwgeom_free(inlwgeom);
1922 
1923  PG_FREE_IF_COPY(ingeom, 0);
1924 
1925  PG_RETURN_POINTER(outgeom);
1926 }
GBOX * gbox_copy(const GBOX *box)
Return a copy of the GBOX, based on dimensionality of flags.
Definition: gbox.c:426
LWGEOM * lwgeom_from_gserialized(const GSERIALIZED *g)
Allocate a new LWGEOM from a GSERIALIZED.
Definition: gserialized.c:239
uint32_t gserialized_get_type(const GSERIALIZED *g)
Extract the geometry type from the serialized form (it hides in the anonymous data area,...
Definition: gserialized.c:89
void lwgeom_free(LWGEOM *geom)
Definition: lwgeom.c:1155
LWGEOM * lwgeom_segmentize2d(const LWGEOM *line, double dist)
Definition: lwgeom.c:771
#define MULTIPOINTTYPE
Definition: liblwgeom.h:120
#define POINTTYPE
LWTYPE numbers, used internally by PostGIS.
Definition: liblwgeom.h:117
#define TINTYPE
Definition: liblwgeom.h:131
#define POLYHEDRALSURFACETYPE
Definition: liblwgeom.h:129
#define TRIANGLETYPE
Definition: liblwgeom.h:130
static int lwgeom_is_empty(const LWGEOM *geom)
Return true or false depending on whether a geometry is an "empty" geometry (no vertices members)
Definition: lwinline.h:203
type
Definition: ovdump.py:42
GBOX * bbox
Definition: liblwgeom.h:473

References LWGEOM::bbox, gbox_copy(), gserialized_get_type(), lwgeom_free(), lwgeom_from_gserialized(), lwgeom_is_empty(), lwgeom_segmentize2d(), MULTIPOINTTYPE, POINTTYPE, POLYHEDRALSURFACETYPE, TINTYPE, TRIANGLETYPE, and ovdump::type.

Here is the call graph for this function: