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

◆ _lwt_FaceByEdges()

static LWGEOM * _lwt_FaceByEdges ( LWT_TOPOLOGY topo,
LWT_ISO_EDGE edges,
int  numfaceedges 
)
static

Definition at line 2744 of file lwgeom_topo.c.

2745{
2746 LWGEOM *outg;
2747 LWCOLLECTION *bounds;
2748 LWGEOM **geoms = lwalloc( sizeof(LWGEOM*) * numfaceedges );
2749 int i, validedges = 0;
2750
2751 for ( i=0; i<numfaceedges; ++i )
2752 {
2753 /* NOTE: skipping edges with same face on both sides, although
2754 * correct, results in a failure to build faces from
2755 * invalid topologies as expected by legacy tests.
2756 * TODO: update legacy tests expectances/unleash this skipping ?
2757 */
2758 /* if ( edges[i].face_left == edges[i].face_right ) continue; */
2759 geoms[validedges++] = lwline_as_lwgeom(edges[i].geom);
2760 }
2761 if ( ! validedges )
2762 {
2763 /* Face has no valid boundary edges, we'll return EMPTY, see
2764 * https://trac.osgeo.org/postgis/ticket/3221 */
2765 if ( numfaceedges ) lwfree(geoms);
2766 LWDEBUG(1, "_lwt_FaceByEdges returning empty polygon");
2767 return lwpoly_as_lwgeom(
2768 lwpoly_construct_empty(topo->srid, topo->hasZ, 0)
2769 );
2770 }
2772 topo->srid,
2773 NULL, /* gbox */
2774 validedges,
2775 geoms);
2776 outg = lwgeom_buildarea( lwcollection_as_lwgeom(bounds) );
2777 lwcollection_release(bounds);
2778 lwfree(geoms);
2779#if 0
2780 {
2781 size_t sz;
2782 char *wkt = lwgeom_to_wkt(outg, WKT_EXTENDED, 2, &sz);
2783 LWDEBUGF(1, "_lwt_FaceByEdges returning area: %s", wkt);
2784 lwfree(wkt);
2785 }
2786#endif
2787 return outg;
2788}
LWCOLLECTION * lwcollection_construct(uint8_t type, int32_t srid, GBOX *bbox, uint32_t ngeoms, LWGEOM **geoms)
#define MULTILINETYPE
Definition liblwgeom.h:120
#define WKT_EXTENDED
Definition liblwgeom.h:2132
char * lwgeom_to_wkt(const LWGEOM *geom, uint8_t variant, int precision, size_t *size_out)
WKT emitter function.
Definition lwout_wkt.c:676
void * lwalloc(size_t size)
Definition lwutil.c:227
void lwfree(void *mem)
Definition lwutil.c:242
LWGEOM * lwline_as_lwgeom(const LWLINE *obj)
Definition lwgeom.c:321
void lwcollection_release(LWCOLLECTION *lwcollection)
LWPOLY * lwpoly_construct_empty(int32_t srid, char hasz, char hasm)
Definition lwpoly.c:161
LWGEOM * lwgeom_buildarea(const LWGEOM *geom)
Take a geometry and return an areal geometry (Polygon or MultiPolygon).
LWGEOM * lwpoly_as_lwgeom(const LWPOLY *obj)
Definition lwgeom.c:311
LWGEOM * lwcollection_as_lwgeom(const LWCOLLECTION *obj)
Definition lwgeom.c:291
#define LWDEBUG(level, msg)
Definition lwgeom_log.h:83
#define LWDEBUGF(level, msg,...)
Definition lwgeom_log.h:88

References LWT_TOPOLOGY_T::hasZ, lwalloc(), lwcollection_as_lwgeom(), lwcollection_construct(), lwcollection_release(), LWDEBUG, LWDEBUGF, lwfree(), lwgeom_buildarea(), lwgeom_to_wkt(), lwline_as_lwgeom(), lwpoly_as_lwgeom(), lwpoly_construct_empty(), MULTILINETYPE, LWT_TOPOLOGY_T::srid, and WKT_EXTENDED.

Referenced by lwt_GetFaceEdges(), and lwt_GetFaceGeometry().

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