From: bdemsky Date: Wed, 12 Jun 2019 20:38:39 +0000 (-0700) Subject: Remove backedges from cyclegraph X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=2a59ba5a8cb2db9eb9bc7403d3459d70e74fc635;p=c11tester.git Remove backedges from cyclegraph --- diff --git a/cyclegraph.cc b/cyclegraph.cc index 8acbb4ed..36f64a43 100644 --- a/cyclegraph.cc +++ b/cyclegraph.cc @@ -342,21 +342,6 @@ unsigned int CycleNode::getNumEdges() const return edges.size(); } -/** - * @param i The index of the back edge to return - * @returns The CycleNode back-edge indexed by i - */ -CycleNode * CycleNode::getBackEdge(unsigned int i) const -{ - return back_edges[i]; -} - -/** @returns The number of edges entering this CycleNode */ -unsigned int CycleNode::getNumBackEdges() const -{ - return back_edges.size(); -} - /** * @brief Remove an element from a vector * @param v The vector @@ -386,22 +371,6 @@ CycleNode * CycleNode::removeEdge() CycleNode *ret = edges.back(); edges.pop_back(); - vector_remove_node(ret->back_edges, this); - return ret; -} - -/** - * @brief Remove a (back) edge from this CycleNode - * @return The CycleNode which was popped, if one exists; otherwise NULL - */ -CycleNode * CycleNode::removeBackEdge() -{ - if (back_edges.empty()) - return NULL; - - CycleNode *ret = back_edges.back(); - back_edges.pop_back(); - vector_remove_node(ret->edges, this); return ret; } @@ -416,7 +385,6 @@ bool CycleNode::addEdge(CycleNode *node) if (edges[i] == node) return false; edges.push_back(node); - node->back_edges.push_back(this); return true; } diff --git a/cyclegraph.h b/cyclegraph.h index 7a90f5cf..fefe3440 100644 --- a/cyclegraph.h +++ b/cyclegraph.h @@ -86,10 +86,7 @@ public: bool addEdge(CycleNode *node); CycleNode * getEdge(unsigned int i) const; unsigned int getNumEdges() const; - CycleNode * getBackEdge(unsigned int i) const; - unsigned int getNumBackEdges() const; CycleNode * removeEdge(); - CycleNode * removeBackEdge(); bool setRMW(CycleNode *); CycleNode * getRMW() const; @@ -104,9 +101,6 @@ private: /** @brief The edges leading out from this node */ SnapVector edges; - /** @brief The edges leading into this node */ - SnapVector back_edges; - /** Pointer to a RMW node that reads from this node, or NULL, if none * exists */ CycleNode *hasRMW;