PostGIS 3.0.6dev-r@@SVN_REVISION@@
Loading...
Searching...
No Matches

◆ asgml3_poly_buf()

static size_t asgml3_poly_buf ( const LWPOLY poly,
const char *  srs,
char *  output,
int  precision,
int  opts,
int  is_patch,
const char *  prefix,
const char *  id 
)
static

Definition at line 1014 of file lwout_gml.c.

1015{
1016 uint32_t i;
1017 char *ptr=output;
1018 int dimension=2;
1019
1020 if (FLAGS_GET_Z(poly->flags)) dimension = 3;
1021 if (is_patch)
1022 {
1023 ptr += sprintf(ptr, "<%sPolygonPatch", prefix);
1024
1025 }
1026 else
1027 {
1028 ptr += sprintf(ptr, "<%sPolygon", prefix);
1029 }
1030
1031 if (srs) ptr += sprintf(ptr, " srsName=\"%s\"", srs);
1032 if (id) ptr += sprintf(ptr, " %sid=\"%s\"", prefix, id);
1033
1034 if ( lwpoly_is_empty(poly) )
1035 {
1036 ptr += sprintf(ptr, "/>");
1037 return (ptr-output);
1038 }
1039 ptr += sprintf(ptr, ">");
1040
1041 ptr += sprintf(ptr, "<%sexterior><%sLinearRing>", prefix, prefix);
1042 if (IS_DIMS(opts)) ptr += sprintf(ptr, "<%sposList srsDimension=\"%d\">", prefix, dimension);
1043 else ptr += sprintf(ptr, "<%sposList>", prefix);
1044
1045 ptr += pointArray_toGML3(poly->rings[0], ptr, precision, opts);
1046 ptr += sprintf(ptr, "</%sposList></%sLinearRing></%sexterior>",
1047 prefix, prefix, prefix);
1048 for (i=1; i<poly->nrings; i++)
1049 {
1050 ptr += sprintf(ptr, "<%sinterior><%sLinearRing>", prefix, prefix);
1051 if (IS_DIMS(opts)) ptr += sprintf(ptr, "<%sposList srsDimension=\"%d\">", prefix, dimension);
1052 else ptr += sprintf(ptr, "<%sposList>", prefix);
1053 ptr += pointArray_toGML3(poly->rings[i], ptr, precision, opts);
1054 ptr += sprintf(ptr, "</%sposList></%sLinearRing></%sinterior>",
1055 prefix, prefix, prefix);
1056 }
1057 if (is_patch) ptr += sprintf(ptr, "</%sPolygonPatch>", prefix);
1058 else ptr += sprintf(ptr, "</%sPolygon>", prefix);
1059
1060 return (ptr-output);
1061}
static uint8_t precision
Definition cu_in_twkb.c:25
#define IS_DIMS(x)
Definition liblwgeom.h:1657
#define FLAGS_GET_Z(flags)
Definition liblwgeom.h:179
int lwpoly_is_empty(const LWPOLY *poly)
static size_t pointArray_toGML3(POINTARRAY *pa, char *buf, int precision, int opts)
Definition lwout_gml.c:1889
POINTARRAY ** rings
Definition liblwgeom.h:505
uint32_t nrings
Definition liblwgeom.h:510
lwflags_t flags
Definition liblwgeom.h:507

References LWPOLY::flags, FLAGS_GET_Z, IS_DIMS, lwpoly_is_empty(), LWPOLY::nrings, pointArray_toGML3(), precision, and LWPOLY::rings.

Referenced by asgml3_collection_buf(), asgml3_multi_buf(), asgml3_multisurface_buf(), asgml3_poly(), and asgml3_psurface_buf().

Here is the call graph for this function:
Here is the caller graph for this function: