From: Ian Jackson Date: Sun, 3 Nov 2019 12:52:31 +0000 (+0000) Subject: make-secnet-sites: output_vpnflat: Change recursive variables X-Git-Tag: v0.5.1~51 X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=commitdiff_plain;h=b743b0306f7cc18dec233d25ece721fe09adef84;hp=d1169993a6ade5d81321c9fae7c903f18c54c41e;p=secnet.git make-secnet-sites: output_vpnflat: Change recursive variables Pass a tuple path, of the objects. rather than the string so far and an indent value. This will make it easier to more complex things here. Signed-off-by: Ian Jackson --- diff --git a/make-secnet-sites b/make-secnet-sites index 3fc6fcd..f56ed3f 100755 --- a/make-secnet-sites +++ b/make-secnet-sites @@ -435,13 +435,13 @@ class vpnlevel(level): } def __init__(self,w): level.__init__(self,w) - def output_vpnflat(self,w,ind,h): + def output_vpnflat(self,w,path): "Output flattened list of site names for this VPN" + ind=2*(len(path)+1) self.indent(w,ind) w.write("%s {\n"%(self.name)) for i in self.children.keys(): - self.children[i].output_vpnflat(w,ind+2, - h+"/"+self.name+"/"+i) + self.children[i].output_vpnflat(w,path+(self,)) w.write("\n") self.indent(w,ind+2) w.write("all-sites %s;\n"% @@ -461,13 +461,19 @@ class locationlevel(level): def __init__(self,w): level.__init__(self,w) self.group=w[2].groupname() - def output_vpnflat(self,w,ind,h): + def output_vpnflat(self,w,path): + ind=2*(len(path)+1) self.indent(w,ind) - # The "h=h,self=self" abomination below exists because + # The "path=path,self=self" abomination below exists because # Python didn't support nested_scopes until version 2.1 + # + #"/"+self.name+"/"+i w.write("%s %s;\n"%(self.name,','.join( - map(lambda x,h=h,self=self: - h+"/"+x,self.children.keys())))) + map(lambda x,path=path,self=self: + '/'.join([prefix+"vpn-data"] + list(map( + lambda i: i.name, + path+(self,x)))), + self.children.values())))) class sitelevel(level): "Site level (i.e. a leafnode) in the configuration hierarchy" @@ -655,7 +661,7 @@ def outputsites(w): # Per-VPN flattened lists w.write(prefix+"vpn {\n") for i in root.children.values(): - i.output_vpnflat(w,2,prefix+"vpn-data") + i.output_vpnflat(w,()) w.write("};\n") # Flattened list of sites