Jeremy Hylton | 65d4ea0 | 2000-02-16 00:49:47 +0000 | [diff] [blame] | 1 | |
| 2 | def flatten(tup): |
| 3 | elts = [] |
| 4 | for elt in tup: |
Neal Norwitz | d752f7d | 2005-11-25 03:17:59 +0000 | [diff] [blame] | 5 | if isinstance(elt, tuple): |
Jeremy Hylton | 65d4ea0 | 2000-02-16 00:49:47 +0000 | [diff] [blame] | 6 | elts = elts + flatten(elt) |
| 7 | else: |
| 8 | elts.append(elt) |
| 9 | return elts |
| 10 | |
Jeremy Hylton | 8b6323d | 2000-02-04 00:28:21 +0000 | [diff] [blame] | 11 | class Set: |
| 12 | def __init__(self): |
Jeremy Hylton | 772dd41 | 2000-02-21 22:46:00 +0000 | [diff] [blame] | 13 | self.elts = {} |
Jeremy Hylton | 95b8614 | 2000-02-10 20:54:27 +0000 | [diff] [blame] | 14 | def __len__(self): |
| 15 | return len(self.elts) |
Jeremy Hylton | 314e3fb | 2000-11-06 03:43:11 +0000 | [diff] [blame] | 16 | def __contains__(self, elt): |
Guido van Rossum | 49061f7 | 2006-08-19 15:28:37 +0000 | [diff] [blame] | 17 | return elt in self.elts |
Jeremy Hylton | 8b6323d | 2000-02-04 00:28:21 +0000 | [diff] [blame] | 18 | def add(self, elt): |
Jeremy Hylton | 772dd41 | 2000-02-21 22:46:00 +0000 | [diff] [blame] | 19 | self.elts[elt] = elt |
Jeremy Hylton | e4d6293 | 2000-03-16 20:02:38 +0000 | [diff] [blame] | 20 | def elements(self): |
Guido van Rossum | cc2b016 | 2007-02-11 06:12:03 +0000 | [diff] [blame] | 21 | return list(self.elts.keys()) |
Jeremy Hylton | 8b6323d | 2000-02-04 00:28:21 +0000 | [diff] [blame] | 22 | def has_elt(self, elt): |
Guido van Rossum | 49061f7 | 2006-08-19 15:28:37 +0000 | [diff] [blame] | 23 | return elt in self.elts |
Jeremy Hylton | 69926ea | 2000-02-10 00:43:22 +0000 | [diff] [blame] | 24 | def remove(self, elt): |
| 25 | del self.elts[elt] |
Jeremy Hylton | 314e3fb | 2000-11-06 03:43:11 +0000 | [diff] [blame] | 26 | def copy(self): |
| 27 | c = Set() |
| 28 | c.elts.update(self.elts) |
| 29 | return c |
Jeremy Hylton | 8b6323d | 2000-02-04 00:28:21 +0000 | [diff] [blame] | 30 | |
| 31 | class Stack: |
| 32 | def __init__(self): |
Jeremy Hylton | 772dd41 | 2000-02-21 22:46:00 +0000 | [diff] [blame] | 33 | self.stack = [] |
| 34 | self.pop = self.stack.pop |
Jeremy Hylton | 95b8614 | 2000-02-10 20:54:27 +0000 | [diff] [blame] | 35 | def __len__(self): |
| 36 | return len(self.stack) |
Jeremy Hylton | 8b6323d | 2000-02-04 00:28:21 +0000 | [diff] [blame] | 37 | def push(self, elt): |
Jeremy Hylton | 772dd41 | 2000-02-21 22:46:00 +0000 | [diff] [blame] | 38 | self.stack.append(elt) |
Jeremy Hylton | 8b6323d | 2000-02-04 00:28:21 +0000 | [diff] [blame] | 39 | def top(self): |
Jeremy Hylton | 772dd41 | 2000-02-21 22:46:00 +0000 | [diff] [blame] | 40 | return self.stack[-1] |
Jeremy Hylton | 4bd4ddd | 2001-08-29 22:26:35 +0000 | [diff] [blame] | 41 | def __getitem__(self, index): # needed by visitContinue() |
| 42 | return self.stack[index] |
Jeremy Hylton | c59e220 | 2001-08-27 22:56:16 +0000 | [diff] [blame] | 43 | |
| 44 | MANGLE_LEN = 256 # magic constant from compile.c |
| 45 | |
| 46 | def 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 Hylton | 09392b7 | 2001-09-17 18:02:21 +0000 | [diff] [blame] | 66 | |
| 67 | def 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()) |