Commit 2ce645df authored by Bram Schoenmakers's avatar Bram Schoenmakers

Add function to get the edge ID given the from and to node.

parent 049fc7d5
...@@ -127,6 +127,21 @@ class DirectedGraph(object): ...@@ -127,6 +127,21 @@ class DirectedGraph(object):
""" """
return p_id in self._edge_numbers return p_id in self._edge_numbers
def edge_id(self, p_from, p_to):
"""
Returns the edge ID given the from and to nodes.
Returns None if the edge does not exist or has no value assigned.
"""
result = None
for key, value in self._edge_numbers.iteritems():
if value == (p_from, p_to):
result = key
break
return result
def remove_edge(self, p_from, p_to, remove_unconnected_nodes=True): def remove_edge(self, p_from, p_to, remove_unconnected_nodes=True):
""" """
Removes an edge from the graph. Removes an edge from the graph.
...@@ -137,10 +152,9 @@ class DirectedGraph(object): ...@@ -137,10 +152,9 @@ class DirectedGraph(object):
if self.has_edge(p_from, p_to): if self.has_edge(p_from, p_to):
self._edges[p_from].remove(p_to) self._edges[p_from].remove(p_to)
for key, value in self._edge_numbers.iteritems(): edge_id = self.edge_id(p_from, p_to)
if value == (p_from, p_to): if edge_id:
del self._edge_numbers[key] del self._edge_numbers[edge_id]
break
if remove_unconnected_nodes: if remove_unconnected_nodes:
if self.is_isolated(p_from): if self.is_isolated(p_from):
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment