simplify + fix

This commit is contained in:
Matthias Bussonnier 2015-06-24 21:53:52 +02:00 committed by Thomas Kluyver
parent 3bc6c0f936
commit 167625d24d
2 changed files with 17 additions and 15 deletions

View File

@ -238,18 +238,24 @@ class DebugInterpreter(ast.NodeVisitor):
arg_explanations.append(arg_explanation) arg_explanations.append(arg_explanation)
for keyword in call.keywords: for keyword in call.keywords:
arg_explanation, arg_result = self.visit(keyword.value) arg_explanation, arg_result = self.visit(keyword.value)
arg_name = "__exprinfo_%s" % (len(ns),) if keyword.arg:
ns[arg_name] = arg_result arg_name = "__exprinfo_%s" % (len(ns),)
keyword_source = "%s=%%s" % (keyword.arg) ns[arg_name] = arg_result
arguments.append(keyword_source % (arg_name,)) keyword_source = "%s=%%s" % (keyword.arg)
arg_explanations.append(keyword_source % (arg_explanation,)) arguments.append(keyword_source % (arg_name,))
if sys.version_info <= (3,4) and call.starargs: arg_explanations.append(keyword_source % (arg_explanation,))
else: # starargs in 3.5+
arg_name = "__exprinfo_star"
ns[arg_name] = arg_result
arguments.append("*%s" % (arg_name,))
arg_explanations.append("*%s" % (arg_explanation,))
if getattr(call, 'starargs', None): # no starargs in 3.5
arg_explanation, arg_result = self.visit(call.starargs) arg_explanation, arg_result = self.visit(call.starargs)
arg_name = "__exprinfo_star" arg_name = "__exprinfo_star"
ns[arg_name] = arg_result ns[arg_name] = arg_result
arguments.append("*%s" % (arg_name,)) arguments.append("*%s" % (arg_name,))
arg_explanations.append("*%s" % (arg_explanation,)) arg_explanations.append("*%s" % (arg_explanation,))
if sys.version_info <= (3,4) and call.kwargs: if call.kwargs:
arg_explanation, arg_result = self.visit(call.kwargs) arg_explanation, arg_result = self.visit(call.kwargs)
arg_name = "__exprinfo_kwds" arg_name = "__exprinfo_kwds"
ns[arg_name] = arg_result ns[arg_name] = arg_result

View File

@ -774,22 +774,18 @@ class AssertionRewriter(ast.NodeVisitor):
new_args = [] new_args = []
new_kwargs = [] new_kwargs = []
for arg in call.args: for arg in call.args:
res, expl = self.visit(arg)
if type(arg) is ast.Starred: if type(arg) is ast.Starred:
new_star, expl = self.visit(arg)
arg_expls.append("*" + expl) arg_expls.append("*" + expl)
new_args.append(new_star)
else: else:
res, expl = self.visit(arg)
new_args.append(res)
arg_expls.append(expl) arg_expls.append(expl)
new_args.append(res)
for keyword in call.keywords: for keyword in call.keywords:
res, expl = self.visit(keyword.value)
new_kwargs.append(ast.keyword(keyword.arg, res))
if keyword.arg: if keyword.arg:
res, expl = self.visit(keyword.value)
new_kwargs.append(ast.keyword(keyword.arg, res))
arg_expls.append(keyword.arg + "=" + expl) arg_expls.append(keyword.arg + "=" + expl)
else: ## **args have `arg` keywords with an .arg of None else: ## **args have `arg` keywords with an .arg of None
res, expl = self.visit(keyword.value)
new_kwargs.append(ast.keyword(keyword.arg, res))
arg_expls.append("**" + expl) arg_expls.append("**" + expl)
expl = "%s(%s)" % (func_expl, ', '.join(arg_expls)) expl = "%s(%s)" % (func_expl, ', '.join(arg_expls))