PostGIS  3.4.0dev-r@@SVN_REVISION@@

◆ LWGEOM_force_sfs()

Datum LWGEOM_force_sfs ( PG_FUNCTION_ARGS  )

Definition at line 579 of file lwgeom_functions_basic.c.

580 {
581  GSERIALIZED *geom = PG_GETARG_GSERIALIZED_P(0);
583  LWGEOM *lwgeom;
584  LWGEOM *ogeom;
585  text *ver;
586  int version = 110; /* default version is SFS 1.1 */
587 
588  POSTGIS_DEBUG(2, "LWGEOM_force_sfs called");
589 
590  /* If user specified version, respect it */
591  if ((PG_NARGS() > 1) && (!PG_ARGISNULL(1)))
592  {
593  ver = PG_GETARG_TEXT_P(1);
594 
595  if (!strncmp(VARDATA(ver), "1.2", 3))
596  {
597  version = 120;
598  }
599  }
600 
601  lwgeom = lwgeom_from_gserialized(geom);
602  ogeom = lwgeom_force_sfs(lwgeom, version);
603 
604  result = geometry_serialize(ogeom);
605 
606  PG_FREE_IF_COPY(geom, 0);
607 
608  PG_RETURN_POINTER(result);
609 }
char result[OUT_DOUBLE_BUFFER_SIZE]
Definition: cu_print.c:262
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: