fix argcount generation for arg lists containing tuple unpacks

this is sort of a hack
This commit is contained in:
Jeremy Hylton 2000-02-16 00:50:29 +00:00
parent 65d4ea05d2
commit 2ce27b223b
2 changed files with 26 additions and 4 deletions

View File

@ -53,7 +53,7 @@ def __init__(self, args=(), name='?', filename='<?>',
# XXX why is the default value for flags 3? # XXX why is the default value for flags 3?
self.insts = [] self.insts = []
# used by makeCodeObject # used by makeCodeObject
self.argcount = len(args) self._getArgCount(args)
self.code = '' self.code = ''
self.consts = [docstring] self.consts = [docstring]
self.filename = filename self.filename = filename
@ -67,6 +67,16 @@ def __init__(self, args=(), name='?', filename='<?>',
self.last_addr = 0 self.last_addr = 0
self.lnotab = '' self.lnotab = ''
def _getArgCount(self, args):
if args and args[0][0] == '.':
for i in range(len(args)):
if args[i][0] == '.':
num = i
self.argcount = num + 1
else:
self.argcount = len(args)
def __repr__(self): def __repr__(self):
return "<bytecode: %d instrs>" % len(self.insts) return "<bytecode: %d instrs>" % len(self.insts)
@ -231,7 +241,8 @@ def _convertArg(self, op, arg):
return arg return arg
nameOps = ('STORE_NAME', 'IMPORT_NAME', 'IMPORT_FROM', nameOps = ('STORE_NAME', 'IMPORT_NAME', 'IMPORT_FROM',
'STORE_ATTR', 'LOAD_ATTR', 'LOAD_NAME', 'DELETE_NAME') 'STORE_ATTR', 'LOAD_ATTR', 'LOAD_NAME', 'DELETE_NAME',
'DELETE_ATTR')
localOps = ('LOAD_FAST', 'STORE_FAST', 'DELETE_FAST') localOps = ('LOAD_FAST', 'STORE_FAST', 'DELETE_FAST')
globalOps = ('LOAD_GLOBAL', 'STORE_GLOBAL', 'DELETE_GLOBAL') globalOps = ('LOAD_GLOBAL', 'STORE_GLOBAL', 'DELETE_GLOBAL')

View File

@ -53,7 +53,7 @@ def __init__(self, args=(), name='?', filename='<?>',
# XXX why is the default value for flags 3? # XXX why is the default value for flags 3?
self.insts = [] self.insts = []
# used by makeCodeObject # used by makeCodeObject
self.argcount = len(args) self._getArgCount(args)
self.code = '' self.code = ''
self.consts = [docstring] self.consts = [docstring]
self.filename = filename self.filename = filename
@ -67,6 +67,16 @@ def __init__(self, args=(), name='?', filename='<?>',
self.last_addr = 0 self.last_addr = 0
self.lnotab = '' self.lnotab = ''
def _getArgCount(self, args):
if args and args[0][0] == '.':
for i in range(len(args)):
if args[i][0] == '.':
num = i
self.argcount = num + 1
else:
self.argcount = len(args)
def __repr__(self): def __repr__(self):
return "<bytecode: %d instrs>" % len(self.insts) return "<bytecode: %d instrs>" % len(self.insts)
@ -231,7 +241,8 @@ def _convertArg(self, op, arg):
return arg return arg
nameOps = ('STORE_NAME', 'IMPORT_NAME', 'IMPORT_FROM', nameOps = ('STORE_NAME', 'IMPORT_NAME', 'IMPORT_FROM',
'STORE_ATTR', 'LOAD_ATTR', 'LOAD_NAME', 'DELETE_NAME') 'STORE_ATTR', 'LOAD_ATTR', 'LOAD_NAME', 'DELETE_NAME',
'DELETE_ATTR')
localOps = ('LOAD_FAST', 'STORE_FAST', 'DELETE_FAST') localOps = ('LOAD_FAST', 'STORE_FAST', 'DELETE_FAST')
globalOps = ('LOAD_GLOBAL', 'STORE_GLOBAL', 'DELETE_GLOBAL') globalOps = ('LOAD_GLOBAL', 'STORE_GLOBAL', 'DELETE_GLOBAL')