aboutsummaryrefslogtreecommitdiff
path: root/libarcfire.py
diff options
context:
space:
mode:
authorVincenzo Maffione <v.maffione@gmail.com>2016-10-23 19:48:25 +0200
committerVincenzo Maffione <v.maffione@gmail.com>2016-10-23 19:48:25 +0200
commitbfcf3c3ca410178c404b41c49c961892e7e25b46 (patch)
tree65e6ff70b539962a800090d81f793ce9772e080e /libarcfire.py
parentc67e0fff3369c798e54e5241e89a2abdee5fb832 (diff)
downloadrumba-bfcf3c3ca410178c404b41c49c961892e7e25b46.tar.gz
rumba-bfcf3c3ca410178c404b41c49c961892e7e25b46.zip
libarcfire: add appmap support
Diffstat (limited to 'libarcfire.py')
-rwxr-xr-xlibarcfire.py23
1 files changed, 20 insertions, 3 deletions
diff --git a/libarcfire.py b/libarcfire.py
index 0993d66..e04b667 100755
--- a/libarcfire.py
+++ b/libarcfire.py
@@ -6,6 +6,7 @@
#
# @name [string] DIF name
# @members [iterable] Nodes belonging to the DIF
+# @appmap [iterable] Application names mapped to this DIF
#
class DIF:
def __init__(self, name, members):
@@ -14,16 +15,32 @@ class DIF:
if members != None:
for m in members:
self.members[m] = m
+ self.appmap = set()
def __repr__(self):
- return "%s: %s" % (self.name, str(sorted(self.members)))
+ s = "DIF %s: members=%s" % (self.name, str(sorted(self.members)))
+ if len(self.appmap) > 0:
+ s += " appmap=%s" % self.appmap
+ return s
- def node_add(node_name):
+ def node_add(self, node_name):
self.members[node_name] = node_name
- def node_del(node_name):
+ def node_del(self, node_name):
del self.members[node_name]
+ def appmap_add(self, apname, apinst = None):
+ s = apname
+ if apinst:
+ s += apinst
+ self.appmap.add(s)
+
+ def appmap_del(self, apname, apinst = None):
+ s = apname
+ if apinst:
+ s += apinst
+ self.appmap.discard(s)
+
# Shim over Ethernet
#