750 char *in_ewkt, *out_ewkt;
756 in_ewkt =
"POLYGON((0 0,0 10,10 10,10 0,0 0))";
758 if (strcmp(in_ewkt, out_ewkt))
759 fprintf(stderr,
"\nExp: %s\nObt: %s\n", in_ewkt, out_ewkt);
760 CU_ASSERT_STRING_EQUAL(in_ewkt, out_ewkt);
768 in_ewkt =
"POLYGON((0 0,0 10,10 10,10 0,0 0))";
770 if (strcmp(in_ewkt, out_ewkt))
771 fprintf(stderr,
"\nExp: %s\nObt: %s\n", in_ewkt, out_ewkt);
772 CU_ASSERT_STRING_EQUAL(in_ewkt, out_ewkt);
777 geom =
lwgeom_from_wkt(
"POLYGON((0 0,10 0,10 10,0 10,0 0),(2 2,2 4,4 2,2 2),(6 2,8 2,8 4,6 2))",
LW_PARSER_CHECK_NONE);
780 in_ewkt =
"POLYGON((0 0,0 10,10 10,10 0,0 0),(2 2,4 2,2 4,2 2),(6 2,8 2,8 4,6 2))";
782 if (strcmp(in_ewkt, out_ewkt))
783 fprintf(stderr,
"\nExp: %s\nObt: %s\n", in_ewkt, out_ewkt);
784 CU_ASSERT_STRING_EQUAL(in_ewkt, out_ewkt);
789 geom =
lwgeom_from_wkt(
"POLYGON((0 0,0 10,10 10,10 0,0 0),(2 2,4 2,2 4,2 2),(6 2,8 4,8 2,6 2))",
LW_PARSER_CHECK_NONE);
792 in_ewkt =
"POLYGON((0 0,0 10,10 10,10 0,0 0),(2 2,4 2,2 4,2 2),(6 2,8 2,8 4,6 2))";
794 if (strcmp(in_ewkt, out_ewkt))
795 fprintf(stderr,
"\nExp: %s\nObt: %s\n", in_ewkt, out_ewkt);
796 CU_ASSERT_STRING_EQUAL(in_ewkt, out_ewkt);
802 in_ewkt =
"0103000000010000000500000000917E9BA468294100917E9B8AEA2841C976BE1FA4682941C976BE9F8AEA2841B39ABE1FA46829415ACCC29F8AEA284137894120A4682941C976BE9F8AEA284100917E9BA468294100917E9B8AEA2841";
char lwgeom_same(const LWGEOM *lwgeom1, const LWGEOM *lwgeom2)
geom1 same as geom2 iff
LWGEOM * lwgeom_from_hexwkb(const char *hexwkb, const char check)
void lwgeom_free(LWGEOM *geom)
#define LW_PARSER_CHECK_NONE
char * lwgeom_to_ewkt(const LWGEOM *lwgeom)
Return an alloced string.
void lwgeom_force_clockwise(LWGEOM *lwgeom)
Force Right-hand-rule on LWGEOM polygons.
LWGEOM * lwgeom_from_wkt(const char *wkt, const char check)
int lwgeom_is_clockwise(LWGEOM *lwgeom)
Ensure the outer ring is clockwise oriented and all inner rings are counter-clockwise.