56class GEOS_DLL SegmentNodeList {
58 std::set<SegmentNode*,SegmentNodeLT> nodeMap;
69 void checkSplitEdgesCorrectness(std::vector<SegmentString*>& splitEdges);
89 void addCollapsedNodes();
95 void findCollapsesFromExistingVertices(
96 std::vector<std::size_t>& collapsedVertexIndexes);
105 void findCollapsesFromInsertedNodes(
106 std::vector<std::size_t>& collapsedVertexIndexes);
109 size_t& collapsedVertexIndex);
112 SegmentNodeList(
const SegmentNodeList& other);
113 SegmentNodeList& operator=(
const SegmentNodeList& rhs);
117 friend std::ostream& operator<< (std::ostream& os,
const SegmentNodeList& l);
119 typedef std::set<SegmentNode*,SegmentNodeLT> container;
120 typedef container::iterator iterator;
121 typedef container::const_iterator const_iterator;
131 virtual ~SegmentNodeList();
146 return add(*intPt, segmentIndex);
154 std::set<SegmentNode*,SegmentNodeLT>* getNodes() {
return &nodeMap; }
157 size_t size()
const {
return nodeMap.size(); }
159 container::iterator begin() {
return nodeMap.begin(); }
160 container::const_iterator begin()
const {
return nodeMap.begin(); }
161 container::iterator end() {
return nodeMap.end(); }
162 container::const_iterator end()
const {
return nodeMap.end(); }