PostGIS  2.4.9dev-r@@SVN_REVISION@@

◆ sfcgal_difference3D()

Datum sfcgal_difference3D ( PG_FUNCTION_ARGS  )

Definition at line 557 of file postgis/lwgeom_sfcgal.c.

References gserialized_get_srid(), PG_FUNCTION_INFO_V1(), POSTGIS2SFCGALGeometry(), sfcgal_postgis_init(), sfcgal_union(), and SFCGALGeometry2POSTGIS().

Referenced by sfcgal_difference().

558 {
559  GSERIALIZED *input0, *input1, *output;
560  sfcgal_geometry_t *geom0, *geom1;
561  sfcgal_geometry_t *result;
562  srid_t srid;
563 
565 
566  input0 = (GSERIALIZED*) PG_DETOAST_DATUM(PG_GETARG_DATUM(0));
567  srid = gserialized_get_srid(input0);
568  input1 = (GSERIALIZED*) PG_DETOAST_DATUM(PG_GETARG_DATUM(1));
569  geom0 = POSTGIS2SFCGALGeometry(input0);
570  PG_FREE_IF_COPY(input0, 0);
571  geom1 = POSTGIS2SFCGALGeometry(input1);
572  PG_FREE_IF_COPY(input1, 1);
573 
574  result = sfcgal_geometry_difference_3d(geom0, geom1);
575  sfcgal_geometry_delete(geom0);
576  sfcgal_geometry_delete(geom1);
577 
578  output = SFCGALGeometry2POSTGIS(result, 0, srid);
579  sfcgal_geometry_delete(result);
580 
581  PG_RETURN_POINTER(output);
582 }
sfcgal_geometry_t * POSTGIS2SFCGALGeometry(GSERIALIZED *pglwgeom)
GSERIALIZED * SFCGALGeometry2POSTGIS(const sfcgal_geometry_t *geom, int force3D, int SRID)
void sfcgal_postgis_init(void)
int32_t gserialized_get_srid(const GSERIALIZED *s)
Extract the SRID from the serialized form (it is packed into three bytes so this is a handy function)...
Definition: g_serialized.c:100
Here is the call graph for this function:
Here is the caller graph for this function: