PostGIS  3.3.9dev-r@@SVN_REVISION@@

◆ LWGEOM_force_sfs()

Datum LWGEOM_force_sfs ( PG_FUNCTION_ARGS  )

Definition at line 576 of file lwgeom_functions_basic.c.

577 {
578  GSERIALIZED *geom = PG_GETARG_GSERIALIZED_P(0);
580  LWGEOM *lwgeom;
581  LWGEOM *ogeom;
582  text *ver;
583  int version = 110; /* default version is SFS 1.1 */
584 
585  POSTGIS_DEBUG(2, "LWGEOM_force_sfs called");
586 
587  /* If user specified version, respect it */
588  if ((PG_NARGS() > 1) && (!PG_ARGISNULL(1)))
589  {
590  ver = PG_GETARG_TEXT_P(1);
591 
592  if (!strncmp(VARDATA(ver), "1.2", 3))
593  {
594  version = 120;
595  }
596  }
597 
598  lwgeom = lwgeom_from_gserialized(geom);
599  ogeom = lwgeom_force_sfs(lwgeom, version);
600 
601  result = geometry_serialize(ogeom);
602 
603  PG_FREE_IF_COPY(geom, 0);
604 
605  PG_RETURN_POINTER(result);
606 }
char result[OUT_DOUBLE_BUFFER_SIZE]
Definition: cu_print.c:267
LWGEOM * lwgeom_from_gserialized(const GSERIALIZED *g)
Allocate a new LWGEOM from a GSERIALIZED.
Definition: gserialized.c:239
LWGEOM * lwgeom_force_sfs(LWGEOM *geom, int version)
Definition: lwgeom.c:849

References lwgeom_force_sfs(), lwgeom_from_gserialized(), and result.

Here is the call graph for this function: