PostGIS  2.2.8dev-r@@SVN_REVISION@@

◆ LWGEOM_force_3dz()

Datum LWGEOM_force_3dz ( PG_FUNCTION_ARGS  )

Definition at line 369 of file lwgeom_functions_basic.c.

References geometry_serialize(), gserialized_has_z(), gserialized_ndims(), LWGEOM_force_3dm(), lwgeom_force_3dz(), lwgeom_free(), lwgeom_from_gserialized(), and PG_FUNCTION_INFO_V1().

Referenced by LWGEOM_force_2d().

370 {
371  GSERIALIZED *pg_geom_in = PG_GETARG_GSERIALIZED_P(0);
372  GSERIALIZED *pg_geom_out;
373  LWGEOM *lwg_in, *lwg_out;
374 
375  /* already 3d */
376  if ( gserialized_ndims(pg_geom_in) == 3 && gserialized_has_z(pg_geom_in) )
377  PG_RETURN_POINTER(pg_geom_in);
378 
379  lwg_in = lwgeom_from_gserialized(pg_geom_in);
380  lwg_out = lwgeom_force_3dz(lwg_in);
381  pg_geom_out = geometry_serialize(lwg_out);
382  lwgeom_free(lwg_out);
383  lwgeom_free(lwg_in);
384 
385  PG_FREE_IF_COPY(pg_geom_in, 0);
386  PG_RETURN_POINTER(pg_geom_out);
387 }
LWGEOM * lwgeom_from_gserialized(const GSERIALIZED *g)
Allocate a new LWGEOM from a GSERIALIZED.
LWGEOM * lwgeom_force_3dz(const LWGEOM *geom)
Definition: lwgeom.c:696
void lwgeom_free(LWGEOM *geom)
Definition: lwgeom.c:1050
int gserialized_ndims(const GSERIALIZED *gser)
Return the number of dimensions (2, 3, 4) in a geometry.
Definition: g_serialized.c:39
int gserialized_has_z(const GSERIALIZED *gser)
Check if a GSERIALIZED has a Z ordinate.
Definition: g_serialized.c:24
GSERIALIZED * geometry_serialize(LWGEOM *lwgeom)
Here is the call graph for this function:
Here is the caller graph for this function: