PostGIS  3.2.2dev-r@@SVN_REVISION@@

◆ ST_Split()

Datum ST_Split ( PG_FUNCTION_ARGS  )

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

3273 {
3274  GSERIALIZED *in, *blade_in, *out;
3275  LWGEOM *lwgeom_in, *lwblade_in, *lwgeom_out;
3276 
3277  in = PG_GETARG_GSERIALIZED_P(0);
3278  blade_in = PG_GETARG_GSERIALIZED_P(1);
3279  gserialized_error_if_srid_mismatch(in, blade_in, __func__);
3280 
3281  lwgeom_in = lwgeom_from_gserialized(in);
3282  lwblade_in = lwgeom_from_gserialized(blade_in);
3283 
3284  if (!lwgeom_isfinite(lwgeom_in))
3285  {
3286  lwpgerror("Input Geometry contains invalid coordinates");
3287  PG_RETURN_NULL();
3288  }
3289 
3290  if (!lwgeom_isfinite(lwblade_in))
3291  {
3292  lwpgerror("Blade Geometry contains invalid coordinates");
3293  PG_RETURN_NULL();
3294  }
3295 
3296 
3297  lwgeom_out = lwgeom_split(lwgeom_in, lwblade_in);
3298  lwgeom_free(lwgeom_in);
3299  lwgeom_free(lwblade_in);
3300 
3301  if ( ! lwgeom_out )
3302  {
3303  PG_FREE_IF_COPY(in, 0); /* possibly referenced by lwgeom_out */
3304  PG_FREE_IF_COPY(blade_in, 1);
3305  PG_RETURN_NULL();
3306  }
3307 
3308  out = geometry_serialize(lwgeom_out);
3309  lwgeom_free(lwgeom_out);
3310  PG_FREE_IF_COPY(in, 0); /* possibly referenced by lwgeom_out */
3311  PG_FREE_IF_COPY(blade_in, 1);
3312 
3313  PG_RETURN_POINTER(out);
3314 }
void gserialized_error_if_srid_mismatch(const GSERIALIZED *g1, const GSERIALIZED *g2, const char *funcname)
Definition: gserialized.c:404
LWGEOM * lwgeom_from_gserialized(const GSERIALIZED *g)
Allocate a new LWGEOM from a GSERIALIZED.
Definition: gserialized.c:239
void lwgeom_free(LWGEOM *geom)
Definition: lwgeom.c:1138
LWGEOM * lwgeom_split(const LWGEOM *lwgeom_in, const LWGEOM *blade_in)
int lwgeom_isfinite(const LWGEOM *lwgeom)
Check if a LWGEOM has any non-finite (NaN or Inf) coordinates.
Definition: lwgeom.c:2690

References gserialized_error_if_srid_mismatch(), lwgeom_free(), lwgeom_from_gserialized(), lwgeom_isfinite(), and lwgeom_split().

Here is the call graph for this function: