You've already forked python-uncompyle6
mirror of
https://github.com/rocky/python-uncompyle6.git
synced 2025-08-03 00:45:53 +08:00
Bang on Python 3.6 MAKE_FUNCTION
This commit is contained in:
BIN
test/bytecode_3.6/01_named_and_kwargs.pyc
Normal file
BIN
test/bytecode_3.6/01_named_and_kwargs.pyc
Normal file
Binary file not shown.
@@ -491,8 +491,9 @@ def make_function3(self, node, is_lambda, nested=1, codeNode=None):
|
|||||||
else:
|
else:
|
||||||
if self.version < 3.6:
|
if self.version < 3.6:
|
||||||
defparams = node[:args_node.attr]
|
defparams = node[:args_node.attr]
|
||||||
|
kw_args = 0
|
||||||
else:
|
else:
|
||||||
default, kw, annotate, closure = args_node.attr
|
default, kw_args, annotate, closure = args_node.attr
|
||||||
if default:
|
if default:
|
||||||
assert node[0] == 'expr', "expecting mkfunc default node to be an expr"
|
assert node[0] == 'expr', "expecting mkfunc default node to be an expr"
|
||||||
expr_node = node[0]
|
expr_node = node[0]
|
||||||
@@ -504,8 +505,6 @@ def make_function3(self, node, is_lambda, nested=1, codeNode=None):
|
|||||||
else:
|
else:
|
||||||
defparams = []
|
defparams = []
|
||||||
# FIXME: handle kw, annotate and closure
|
# FIXME: handle kw, annotate and closure
|
||||||
|
|
||||||
kw_args = 0
|
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
|
||||||
@@ -586,16 +585,9 @@ def make_function3(self, node, is_lambda, nested=1, codeNode=None):
|
|||||||
else:
|
else:
|
||||||
self.write(", ")
|
self.write(", ")
|
||||||
|
|
||||||
if not 3.0 <= self.version <= 3.2:
|
# FIXME: this is not correct for 3.5. or 3.6 (which works different)
|
||||||
for n in node:
|
# and 3.7?
|
||||||
if n == 'pos_arg':
|
if 3.0 <= self.version <= 3.2:
|
||||||
continue
|
|
||||||
elif self.version >= 3.4 and not (n.kind in ('kwargs', 'kwargs1', 'kwarg')):
|
|
||||||
continue
|
|
||||||
else:
|
|
||||||
self.preorder(n)
|
|
||||||
break
|
|
||||||
else:
|
|
||||||
kwargs = node[0]
|
kwargs = node[0]
|
||||||
last = len(kwargs)-1
|
last = len(kwargs)-1
|
||||||
i = 0
|
i = 0
|
||||||
@@ -605,10 +597,37 @@ def make_function3(self, node, is_lambda, nested=1, codeNode=None):
|
|||||||
self.preorder(n[1])
|
self.preorder(n[1])
|
||||||
if i < last:
|
if i < last:
|
||||||
self.write(', ')
|
self.write(', ')
|
||||||
|
pass
|
||||||
i += 1
|
i += 1
|
||||||
pass
|
pass
|
||||||
pass
|
pass
|
||||||
pass
|
pass
|
||||||
|
elif self.version <= 3.5:
|
||||||
|
# FIXME this is not qute right for 3.5
|
||||||
|
for n in node:
|
||||||
|
if n == 'pos_arg':
|
||||||
|
continue
|
||||||
|
elif self.version >= 3.4 and not (n.kind in ('kwargs', 'kwargs1', 'kwarg')):
|
||||||
|
continue
|
||||||
|
else:
|
||||||
|
self.preorder(n)
|
||||||
|
break
|
||||||
|
elif self.version >= 3.6:
|
||||||
|
d = node[1]
|
||||||
|
if d == 'expr':
|
||||||
|
d = d[0]
|
||||||
|
assert d == 'dict'
|
||||||
|
defaults = [self.traverse(n, indent='') for n in d[:-2]]
|
||||||
|
names = eval(self.traverse(d[-2]))
|
||||||
|
assert len(defaults) == len(names)
|
||||||
|
sep = ''
|
||||||
|
# FIXME: possibly handle line breaks
|
||||||
|
for i, n in enumerate(names):
|
||||||
|
self.write(sep)
|
||||||
|
self.write("%s=%s" % (n, defaults[i]))
|
||||||
|
sep = ', '
|
||||||
|
pass
|
||||||
|
pass
|
||||||
pass
|
pass
|
||||||
|
|
||||||
if code_has_star_star_arg(code):
|
if code_has_star_star_arg(code):
|
||||||
|
@@ -568,8 +568,17 @@ class SourceWalker(GenericASTTraversal, object):
|
|||||||
self.n_build_tuple_unpack_with_call = build_unpack_tuple_with_call
|
self.n_build_tuple_unpack_with_call = build_unpack_tuple_with_call
|
||||||
|
|
||||||
def build_unpack_map_with_call(node):
|
def build_unpack_map_with_call(node):
|
||||||
sep = '**'
|
n = node[0]
|
||||||
for n in node[:-1]:
|
if n == 'expr':
|
||||||
|
n = n[0]
|
||||||
|
if n == 'dict':
|
||||||
|
self.call36_dict(n)
|
||||||
|
first = 1
|
||||||
|
sep = ', **'
|
||||||
|
else:
|
||||||
|
first = 0
|
||||||
|
sep = '**'
|
||||||
|
for n in node[first:-1]:
|
||||||
self.f.write(sep)
|
self.f.write(sep)
|
||||||
self.preorder(n)
|
self.preorder(n)
|
||||||
sep = ', **'
|
sep = ', **'
|
||||||
|
Reference in New Issue
Block a user