diff options
author | Jeremy Hylton <jeremy@alum.mit.edu> | 2001-04-12 21:04:43 (GMT) |
---|---|---|
committer | Jeremy Hylton <jeremy@alum.mit.edu> | 2001-04-12 21:04:43 (GMT) |
commit | 13d70944cba10f6f9b39aa94cb9c5df442523dda (patch) | |
tree | f443417d887e85847838db9d33f65199c6be7546 /Lib/compiler | |
parent | 23f7aed2a792190c42209732f1520ccb7321be8e (diff) | |
download | cpython-13d70944cba10f6f9b39aa94cb9c5df442523dda.zip cpython-13d70944cba10f6f9b39aa94cb9c5df442523dda.tar.gz cpython-13d70944cba10f6f9b39aa94cb9c5df442523dda.tar.bz2 |
Use new _implicitNameOp() to generate name op code for list comprehensions.
Always emit a SET_LINENO 0 at the beginning of the module. The
builtin compiler does this, and it's much easier to compare bytecode
generated by the two compilers if they both do.
Move the SET_LINENO inside the FOR_LOOP block for list
comprehensions. Also for compat. with builtin compiler.
Diffstat (limited to 'Lib/compiler')
-rw-r--r-- | Lib/compiler/pycodegen.py | 21 |
1 files changed, 17 insertions, 4 deletions
diff --git a/Lib/compiler/pycodegen.py b/Lib/compiler/pycodegen.py index e67b2ef..dc2be32 100644 --- a/Lib/compiler/pycodegen.py +++ b/Lib/compiler/pycodegen.py @@ -193,6 +193,18 @@ class CodeGenerator: else: self.emit(prefix + '_GLOBAL', name) + def _implicitNameOp(self, prefix, name): + """Emit name ops for names generated implicitly by for loops + + The interpreter generates names that start with a period or + dollar sign. The symbol table ignores these names because + they aren't present in the program text. + """ + if self.optimized: + self.emit(prefix + '_FAST', name) + else: + self.emit(prefix + '_NAME', name) + def set_lineno(self, node, force=0): """Emit SET_LINENO if node has lineno attribute and it is different than the last lineno emitted. @@ -221,6 +233,7 @@ class CodeGenerator: ClassGen = None def visitModule(self, node): + self.emit('SET_LINENO', 0) lnf = walk(node.node, self.NameFinder(), 0) self.locals.push(lnf.getLocals()) if node.doc: @@ -421,7 +434,7 @@ class CodeGenerator: self.emit('BUILD_LIST', 0) self.emit('DUP_TOP') self.emit('LOAD_ATTR', 'append') - self.emit('STORE_FAST', append) + self._implicitNameOp('STORE', append) stack = [] for i, for_ in zip(range(len(node.quals)), node.quals): @@ -433,7 +446,7 @@ class CodeGenerator: self.visit(if_, cont) stack.insert(0, (start, cont, anchor)) - self.emit('LOAD_FAST', append) + self._implicitNameOp('LOAD', append) self.visit(node.expr) self.emit('CALL_FUNCTION', 1) self.emit('POP_TOP') @@ -447,7 +460,7 @@ class CodeGenerator: self.nextBlock(skip_one) self.emit('JUMP_ABSOLUTE', start) self.startBlock(anchor) - self.emit('DELETE_FAST', append) + self._implicitNameOp('DELETE', append) self.__list_count = self.__list_count - 1 @@ -457,8 +470,8 @@ class CodeGenerator: self.visit(node.list) self.visit(ast.Const(0)) - self.emit('SET_LINENO', node.lineno) self.nextBlock(start) + self.emit('SET_LINENO', node.lineno) self.emit('FOR_LOOP', anchor) self.nextBlock() self.visit(node.assign) |