1015{
1016 uint32_t i;
1017 char *ptr=output;
1018 int dimension=2;
1019
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
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
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);
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}
#define FLAGS_GET_Z(flags)
int lwpoly_is_empty(const LWPOLY *poly)
static size_t pointArray_toGML3(POINTARRAY *pa, char *buf, int precision, int opts)