65 const std::vector<const Geometry*>& m_coverage;
66 std::map<const LinearRing*, std::vector<CoverageEdge*>> m_ringEdgesMap;
67 std::vector<CoverageEdge*> m_edges;
68 std::vector<std::unique_ptr<CoverageEdge>> m_edgeStore;
77 : m_coverage(coverage)
83 std::vector<CoverageEdge*>& getEdges()
95 std::size_t ringCount)
const;
111 Coordinate::UnorderedSet& nodes,
112 LineSegment::UnorderedSet& boundarySegs,
113 std::map<LineSegment, CoverageEdge*>& uniqueEdgeMap);
115 void addBoundaryInnerNodes(
117 LineSegment::UnorderedSet& boundarySegs,
118 Coordinate::UnorderedSet& nodes);
120 std::vector<CoverageEdge*> extractRingEdges(
122 std::map<LineSegment, CoverageEdge*>& uniqueEdgeMap,
123 Coordinate::UnorderedSet& nodes);
127 std::map<LineSegment, CoverageEdge*>& uniqueEdgeMap);
131 std::size_t start, std::size_t end,
132 std::map<LineSegment, CoverageEdge*>& uniqueEdgeMap);
134 std::size_t findNextNodeIndex(
137 Coordinate::UnorderedSet& nodes)
const;
139 static std::size_t next(
143 Coordinate::UnorderedSet findMultiRingNodes(
144 const std::vector<const Geometry*>& coverage);
146 Coordinate::UnorderedSet findBoundaryNodes(
147 LineSegment::UnorderedSet& lineSegments);
149 std::unique_ptr<Geometry> buildPolygonal(
152 std::unique_ptr<Geometry> buildMultiPolygon(
155 std::unique_ptr<Polygon> buildPolygon(
158 std::unique_ptr<LinearRing> buildRing(
161 bool isEdgeDirForward(
162 const std::vector<CoverageEdge*>& ringEdges,