2358{
2360 LWGEOM *lwgeom_in, *lwblade_in, *lwgeom_out;
2361
2362 in = PG_GETARG_GSERIALIZED_P(0);
2363 blade_in = PG_GETARG_GSERIALIZED_P(1);
2365
2368
2370 {
2371 lwpgerror("Input Geometry contains invalid coordinates");
2372 PG_RETURN_NULL();
2373 }
2374
2376 {
2377 lwpgerror("Blade Geometry contains invalid coordinates");
2378 PG_RETURN_NULL();
2379 }
2380
2381
2385
2386 if ( ! lwgeom_out )
2387 {
2388 PG_FREE_IF_COPY(in, 0);
2389 PG_FREE_IF_COPY(blade_in, 1);
2390 PG_RETURN_NULL();
2391 }
2392
2393 out = geometry_serialize(lwgeom_out);
2395 PG_FREE_IF_COPY(in, 0);
2396 PG_FREE_IF_COPY(blade_in, 1);
2397
2398 PG_RETURN_POINTER(out);
2399}
void gserialized_error_if_srid_mismatch(const GSERIALIZED *g1, const GSERIALIZED *g2, const char *funcname)
LWGEOM * lwgeom_from_gserialized(const GSERIALIZED *g)
Allocate a new LWGEOM from a GSERIALIZED.
LWGEOM * lwgeom_split(const LWGEOM *lwgeom_in, const LWGEOM *blade_in)
void lwgeom_free(LWGEOM *geom)
int lwgeom_isfinite(const LWGEOM *lwgeom)
Check if a LWGEOM has any non-finite (NaN or Inf) coordinates.