15 #include "CUnit/Basic.h"
61 "POINT(1.1111111111111 1.1111111111111)",
62 "<Point><coordinates>1,1</coordinates></Point>",
67 "POINT(1.1111111111111 1.1111111111111)",
68 "<Point><coordinates>1.111,1.111</coordinates></Point>",
73 "POINT(1.2345678901234 1.2345678901234)",
74 "<Point><coordinates>1.23456789,1.23456789</coordinates></Point>",
79 "POINT(1E300 -1E300)",
80 "<Point><coordinates>1e+300,-1e+300</coordinates></Point>",
90 "<Point><coordinates>0,1,2</coordinates></Point>",
96 "<Point><coordinates>0,1</coordinates></Point>",
102 "<Point><coordinates>0,1,2</coordinates></Point>",
111 "LINESTRING(0 1,2 3,4 5)",
112 "<LineString><coordinates>0,1 2,3 4,5</coordinates></LineString>",
117 "POLYGON((0 1,2 3,4 5,0 1))",
118 "<Polygon><outerBoundaryIs><LinearRing><coordinates>0,1 2,3 4,5 0,1</coordinates></LinearRing></outerBoundaryIs></Polygon>",
123 "POLYGON((0 1,2 3,4 5,0 1),(6 7,8 9,10 11,6 7))",
124 "<Polygon><outerBoundaryIs><LinearRing><coordinates>0,1 2,3 4,5 0,1</coordinates></LinearRing></outerBoundaryIs><innerBoundaryIs><LinearRing><coordinates>6,7 8,9 10,11 6,7</coordinates></LinearRing></innerBoundaryIs></Polygon>",
129 "MULTIPOINT(0 1,2 3)",
130 "<MultiGeometry><Point><coordinates>0,1</coordinates></Point><Point><coordinates>2,3</coordinates></Point></MultiGeometry>",
135 "MULTILINESTRING((0 1,2 3,4 5),(6 7,8 9,10 11))",
136 "<MultiGeometry><LineString><coordinates>0,1 2,3 4,5</coordinates></LineString><LineString><coordinates>6,7 8,9 10,11</coordinates></LineString></MultiGeometry>",
141 "MULTIPOLYGON(((0 1,2 3,4 5,0 1)),((6 7,8 9,10 11,6 7)))",
142 "<MultiGeometry><Polygon><outerBoundaryIs><LinearRing><coordinates>0,1 2,3 4,5 0,1</coordinates></LinearRing></outerBoundaryIs></Polygon><Polygon><outerBoundaryIs><LinearRing><coordinates>6,7 8,9 10,11 6,7</coordinates></LinearRing></outerBoundaryIs></Polygon></MultiGeometry>",
147 "GEOMETRYCOLLECTION(POINT(0 1))",
148 "lwgeom_to_kml2: 'GeometryCollection' geometry type not supported");
152 "CIRCULARSTRING(-2 0,0 2,2 0,0 2,2 4)",
153 "lwgeom_to_kml2: 'CircularString' geometry type not supported");
157 "COMPOUNDCURVE(CIRCULARSTRING(0 0,1 1,1 0),(1 0,0 1))",
158 "lwgeom_to_kml2: 'CompoundCurve' geometry type not supported");
162 "CURVEPOLYGON(CIRCULARSTRING(-2 0,-1 -1,0 0,1 -1,2 0,0 2,-2 0),(-1 0,0 0.5,1 0,0 1,-1 0))",
163 "lwgeom_to_kml2: 'CurvePolygon' geometry type not supported");
167 "MULTICURVE((5 5,3 5,3 3,0 3),CIRCULARSTRING(0 0,2 1,2 2))",
168 "lwgeom_to_kml2: 'MultiCurve' geometry type not supported");
172 "MULTISURFACE(CURVEPOLYGON(CIRCULARSTRING(-2 0,-1 -1,0 0,1 -1,2 0,0 2,-2 0),(-1 0,0 0.5,1 0,0 1,-1 0)),((7 8,10 10,6 14,4 11,7 8)))",
173 "lwgeom_to_kml2: 'MultiSurface' geometry type not supported");
180 "LINESTRING(0 1,2 3,4 5)",
181 "<kml:LineString><kml:coordinates>0,1 2,3 4,5</kml:coordinates></kml:LineString>",
186 "POLYGON((0 1,2 3,4 5,0 1))",
187 "<kml:Polygon><kml:outerBoundaryIs><kml:LinearRing><kml:coordinates>0,1 2,3 4,5 0,1</kml:coordinates></kml:LinearRing></kml:outerBoundaryIs></kml:Polygon>",
192 "POLYGON((0 1,2 3,4 5,0 1),(6 7,8 9,10 11,6 7))",
193 "<kml:Polygon><kml:outerBoundaryIs><kml:LinearRing><kml:coordinates>0,1 2,3 4,5 0,1</kml:coordinates></kml:LinearRing></kml:outerBoundaryIs><kml:innerBoundaryIs><kml:LinearRing><kml:coordinates>6,7 8,9 10,11 6,7</kml:coordinates></kml:LinearRing></kml:innerBoundaryIs></kml:Polygon>",
198 "MULTIPOINT(0 1,2 3)",
199 "<kml:MultiGeometry><kml:Point><kml:coordinates>0,1</kml:coordinates></kml:Point><kml:Point><kml:coordinates>2,3</kml:coordinates></kml:Point></kml:MultiGeometry>",
204 "MULTILINESTRING((0 1,2 3,4 5),(6 7,8 9,10 11))",
205 "<kml:MultiGeometry><kml:LineString><kml:coordinates>0,1 2,3 4,5</kml:coordinates></kml:LineString><kml:LineString><kml:coordinates>6,7 8,9 10,11</kml:coordinates></kml:LineString></kml:MultiGeometry>",
210 "MULTIPOLYGON(((0 1,2 3,4 5,0 1)),((6 7,8 9,10 11,6 7)))",
211 "<kml:MultiGeometry><kml:Polygon><kml:outerBoundaryIs><kml:LinearRing><kml:coordinates>0,1 2,3 4,5 0,1</kml:coordinates></kml:LinearRing></kml:outerBoundaryIs></kml:Polygon><kml:Polygon><kml:outerBoundaryIs><kml:LinearRing><kml:coordinates>6,7 8,9 10,11 6,7</kml:coordinates></kml:LinearRing></kml:outerBoundaryIs></kml:Polygon></kml:MultiGeometry>",
221 CU_pSuite suite = CU_add_suite(
"kml_output", NULL, NULL);
static void out_kml_test_dims(void)
static void out_kml_test_prefix(void)
static void do_kml_test(char *in, char *out, int precision)
static void out_kml_test_precision(void)
void out_kml_suite_setup(void)
static void do_kml_test_prefix(char *in, char *out, int precision, const char *prefix)
static void out_kml_test_geoms(void)
static void do_kml_unsupported(char *in, char *out)
void cu_error_msg_reset()
char cu_error_msg[MAX_CUNIT_ERROR_LENGTH+1]
#define ASSERT_VARLENA_EQUAL(v, s)
#define PG_ADD_TEST(suite, testfunc)
#define ASSERT_STRING_EQUAL(o, e)
lwvarlena_t * lwgeom_to_kml2(const LWGEOM *geom, int precision, const char *prefix)
void lwgeom_free(LWGEOM *geom)
#define LW_PARSER_CHECK_NONE
LWGEOM * lwgeom_from_wkt(const char *wkt, const char check)