PostGIS  2.1.10dev-r@@SVN_REVISION@@
Datum sfcgal_intersection3D ( PG_FUNCTION_ARGS  )

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

References gserialized_get_srid(), POSTGIS2SFCGALGeometry(), result, sfcgal_postgis_init(), and SFCGALGeometry2POSTGIS().

451 {
452  GSERIALIZED *input0, *input1, *output;
453  sfcgal_geometry_t *geom0, *geom1;
454  sfcgal_geometry_t *result;
455  srid_t srid;
456 
458 
459  input0 = (GSERIALIZED*) PG_DETOAST_DATUM(PG_GETARG_DATUM(0));
460  srid = gserialized_get_srid(input0);
461  input1 = (GSERIALIZED*) PG_DETOAST_DATUM(PG_GETARG_DATUM(1));
462  geom0 = POSTGIS2SFCGALGeometry(input0);
463  PG_FREE_IF_COPY(input0, 0);
464  geom1 = POSTGIS2SFCGALGeometry(input1);
465  PG_FREE_IF_COPY(input1, 1);
466 
467  result = sfcgal_geometry_intersection_3d(geom0, geom1);
468  sfcgal_geometry_delete(geom0);
469  sfcgal_geometry_delete(geom1);
470 
471  output = SFCGALGeometry2POSTGIS(result, 0, srid);
472  sfcgal_geometry_delete(result);
473 
474  PG_RETURN_POINTER(output);
475 }
sfcgal_geometry_t * POSTGIS2SFCGALGeometry(GSERIALIZED *pglwgeom)
GSERIALIZED * SFCGALGeometry2POSTGIS(const sfcgal_geometry_t *geom, int force3D, int SRID)
char ** result
Definition: liblwgeom.h:218
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:70

Here is the call graph for this function: