summaryrefslogtreecommitdiffstats
path: root/Lib/compiler/pyassem.py
diff options
context:
space:
mode:
Diffstat (limited to 'Lib/compiler/pyassem.py')
-rw-r--r--Lib/compiler/pyassem.py23
1 files changed, 13 insertions, 10 deletions
diff --git a/Lib/compiler/pyassem.py b/Lib/compiler/pyassem.py
index fa42b84..4cb910c 100644
--- a/Lib/compiler/pyassem.py
+++ b/Lib/compiler/pyassem.py
@@ -143,17 +143,19 @@ class PyAssembler:
for t in self.insts:
opname = t[0]
if len(t) == 1:
- lnotab.addCode(chr(self.opnum[opname]))
+ lnotab.addCode(self.opnum[opname])
elif len(t) == 2:
- oparg = self._convertArg(opname, t[1])
if opname == 'SET_LINENO':
+ oparg = t[1]
lnotab.nextLine(oparg)
+ else:
+ oparg = self._convertArg(opname, t[1])
try:
hi, lo = divmod(oparg, 256)
except TypeError:
raise TypeError, "untranslated arg: %s, %s" % (opname, oparg)
- lnotab.addCode(chr(self.opnum[opname]) + chr(lo) +
- chr(hi))
+ lnotab.addCode(self.opnum[opname], lo, hi)
+
# why is a module a special case?
if self.flags == 0:
nlocals = 0
@@ -324,9 +326,10 @@ class LineAddrTable:
self.lastoff = 0
self.lnotab = []
- def addCode(self, code):
- self.code.append(code)
- self.codeOffset = self.codeOffset + len(code)
+ def addCode(self, *args):
+ for arg in args:
+ self.code.append(chr(arg))
+ self.codeOffset = self.codeOffset + len(args)
def nextLine(self, lineno):
if self.firstline == 0:
@@ -451,9 +454,9 @@ class StackDepthTracker:
('LOAD_', 1),
('IMPORT_', 1),
]
- # special cases
-
- #: UNPACK_TUPLE, UNPACK_LIST, BUILD_TUPLE,
+
+ # special cases:
+ # UNPACK_TUPLE, UNPACK_LIST, BUILD_TUPLE,
# BUILD_LIST, CALL_FUNCTION, MAKE_FUNCTION, BUILD_SLICE
def UNPACK_TUPLE(self, count):
return count