PostGIS  3.7.0dev-r@@SVN_REVISION@@

◆ ST_Snap()

Datum ST_Snap ( PG_FUNCTION_ARGS  )

Definition at line 2305 of file postgis/lwgeom_geos.c.

2306 {
2307  GSERIALIZED *geom1, *geom2, *result;
2308  LWGEOM *lwgeom1, *lwgeom2, *lwresult;
2309  double tolerance;
2310 
2311  geom1 = PG_GETARG_GSERIALIZED_P(0);
2312  geom2 = PG_GETARG_GSERIALIZED_P(1);
2313  tolerance = PG_GETARG_FLOAT8(2);
2314 
2315  lwgeom1 = lwgeom_from_gserialized(geom1);
2316  lwgeom2 = lwgeom_from_gserialized(geom2);
2317 
2318  lwresult = lwgeom_snap(lwgeom1, lwgeom2, tolerance);
2319  lwgeom_free(lwgeom1);
2320  lwgeom_free(lwgeom2);
2321  PG_FREE_IF_COPY(geom1, 0);
2322  PG_FREE_IF_COPY(geom2, 1);
2323 
2324  result = geometry_serialize(lwresult);
2325  lwgeom_free(lwresult);
2326 
2327  PG_RETURN_POINTER(result);
2328 }
char result[OUT_DOUBLE_BUFFER_SIZE]
Definition: cu_print.c:267
LWGEOM * lwgeom_from_gserialized(const GSERIALIZED *g)
Allocate a new LWGEOM from a GSERIALIZED.
Definition: gserialized.c:268
void lwgeom_free(LWGEOM *geom)
Definition: lwgeom.c:1218
LWGEOM * lwgeom_snap(const LWGEOM *geom1, const LWGEOM *geom2, double tolerance)
Snap vertices and segments of a geometry to another using a given tolerance.

References lwgeom_free(), lwgeom_from_gserialized(), lwgeom_snap(), and result.

Here is the call graph for this function: