blob: b32d0dc00da8b9d4da7295b3150fc4e9f696ff5c [file] [log] [blame]
Jeremy Hylton65d4ea02000-02-16 00:49:47 +00001
2def flatten(tup):
3 elts = []
4 for elt in tup:
Neal Norwitzd752f7d2005-11-25 03:17:59 +00005 if isinstance(elt, tuple):
Jeremy Hylton65d4ea02000-02-16 00:49:47 +00006 elts = elts + flatten(elt)
7 else:
8 elts.append(elt)
9 return elts
10
Jeremy Hylton8b6323d2000-02-04 00:28:21 +000011class Set:
12 def __init__(self):
Jeremy Hylton772dd412000-02-21 22:46:00 +000013 self.elts = {}
Jeremy Hylton95b86142000-02-10 20:54:27 +000014 def __len__(self):
15 return len(self.elts)
Jeremy Hylton314e3fb2000-11-06 03:43:11 +000016 def __contains__(self, elt):
Guido van Rossum49061f72006-08-19 15:28:37 +000017 return elt in self.elts
Jeremy Hylton8b6323d2000-02-04 00:28:21 +000018 def add(self, elt):
Jeremy Hylton772dd412000-02-21 22:46:00 +000019 self.elts[elt] = elt
Jeremy Hyltone4d62932000-03-16 20:02:38 +000020 def elements(self):
Guido van Rossumcc2b0162007-02-11 06:12:03 +000021 return list(self.elts.keys())
Jeremy Hylton8b6323d2000-02-04 00:28:21 +000022 def has_elt(self, elt):
Guido van Rossum49061f72006-08-19 15:28:37 +000023 return elt in self.elts
Jeremy Hylton69926ea2000-02-10 00:43:22 +000024 def remove(self, elt):
25 del self.elts[elt]
Jeremy Hylton314e3fb2000-11-06 03:43:11 +000026 def copy(self):
27 c = Set()
28 c.elts.update(self.elts)
29 return c
Jeremy Hylton8b6323d2000-02-04 00:28:21 +000030
31class Stack:
32 def __init__(self):
Jeremy Hylton772dd412000-02-21 22:46:00 +000033 self.stack = []
34 self.pop = self.stack.pop
Jeremy Hylton95b86142000-02-10 20:54:27 +000035 def __len__(self):
36 return len(self.stack)
Jeremy Hylton8b6323d2000-02-04 00:28:21 +000037 def push(self, elt):
Jeremy Hylton772dd412000-02-21 22:46:00 +000038 self.stack.append(elt)
Jeremy Hylton8b6323d2000-02-04 00:28:21 +000039 def top(self):
Jeremy Hylton772dd412000-02-21 22:46:00 +000040 return self.stack[-1]
Jeremy Hylton4bd4ddd2001-08-29 22:26:35 +000041 def __getitem__(self, index): # needed by visitContinue()
42 return self.stack[index]
Jeremy Hyltonc59e2202001-08-27 22:56:16 +000043
44MANGLE_LEN = 256 # magic constant from compile.c
45
46def mangle(name, klass):
47 if not name.startswith('__'):
48 return name
49 if len(name) + 2 >= MANGLE_LEN:
50 return name
51 if name.endswith('__'):
52 return name
53 try:
54 i = 0
55 while klass[i] == '_':
56 i = i + 1
57 except IndexError:
58 return name
59 klass = klass[i:]
60
61 tlen = len(klass) + len(name)
62 if tlen > MANGLE_LEN:
63 klass = klass[:MANGLE_LEN-tlen]
64
65 return "_%s%s" % (klass, name)
Jeremy Hylton09392b72001-09-17 18:02:21 +000066
67def set_filename(filename, tree):
68 """Set the filename attribute to filename on every node in tree"""
69 worklist = [tree]
70 while worklist:
71 node = worklist.pop(0)
72 node.filename = filename
73 worklist.extend(node.getChildNodes())