diff options
-rw-r--r-- | ryu/controller/network.py | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/ryu/controller/network.py b/ryu/controller/network.py index e81bd3c8..f70da080 100644 --- a/ryu/controller/network.py +++ b/ryu/controller/network.py @@ -78,14 +78,15 @@ class Networks(dict): def remove_network(self, network_id): try: - network = self[network_id] + ports = self[network_id] except KeyError: raise NetworkNotFound(network_id=network_id) - for (dpid, port_no) in network: - self.send_event(EventNetworkPort(network_id, dpid, port_no, False)) - self.send_event(EventNetworkDel(network_id)) - del self[network_id] + while ports: + (dpid, port_no) = ports.pop() + self._remove_event(network_id, dpid, port_no) + if self.pop(network_id, None) is not None: + self.send_event(EventNetworkDel(network_id)) def list_ports(self, network_id): try: @@ -106,11 +107,14 @@ class Networks(dict): # self.add_raw(network_id, dpid, port_no) # self.add_event(network_id, dpid, port_no) + def _remove_event(self, network_id, dpid, port_no): + self.send_event(EventNetworkPort(network_id, dpid, port_no, False)) + def remove_raw(self, network_id, dpid, port_no): ports = self[network_id] if (dpid, port_no) in ports: ports.remove((dpid, port_no)) - self.send_event(EventNetworkPort(network_id, dpid, port_no, False)) + self._remove_event(network_id, dpid, port_no) def remove(self, network_id, dpid, port_no): try: |