Commit 595ccb23 authored by Stefan Behnel's avatar Stefan Behnel

reformat dict unpacking code to show the two alternative branches at the same indentation level

parent b4f8fd7e
...@@ -5589,6 +5589,7 @@ class MergedDictNode(ExprNode): ...@@ -5589,6 +5589,7 @@ class MergedDictNode(ExprNode):
helpers = set() helpers = set()
for item in args: for item in args:
if item.is_dict_literal: if item.is_dict_literal:
# inline update instead of creating an intermediate dict
for arg in item.key_value_pairs: for arg in item.key_value_pairs:
arg.generate_evaluation_code(code) arg.generate_evaluation_code(code)
if self.reject_duplicates: if self.reject_duplicates:
...@@ -5607,19 +5608,20 @@ class MergedDictNode(ExprNode): ...@@ -5607,19 +5608,20 @@ class MergedDictNode(ExprNode):
arg.value.py_result())) arg.value.py_result()))
arg.generate_disposal_code(code) arg.generate_disposal_code(code)
arg.free_temps(code) arg.free_temps(code)
continue else:
item.generate_evaluation_code(code) item.generate_evaluation_code(code)
if self.reject_duplicates: if self.reject_duplicates:
# merge mapping into kwdict one by one as we need to check for duplicates # merge mapping into kwdict one by one as we need to check for duplicates
helpers.add("MergeKeywords") helpers.add("MergeKeywords")
code.put_error_if_neg(item.pos, "__Pyx_MergeKeywords(%s, %s)" % (self.result(), item.py_result())) code.put_error_if_neg(item.pos, "__Pyx_MergeKeywords(%s, %s)" % (
self.result(), item.py_result()))
else: else:
# simple case, just add all entries # simple case, just add all entries
helpers.add("RaiseMappingExpected") helpers.add("RaiseMappingExpected")
code.putln("if (unlikely(PyDict_Update(%s, %s) < 0)) {" % (self.result(), item.py_result())) code.putln("if (unlikely(PyDict_Update(%s, %s) < 0)) {" % (
code.putln("if (PyErr_ExceptionMatches(PyExc_AttributeError)) __Pyx_RaiseMappingExpectedError(%s);" % ( self.result(), item.py_result()))
item.py_result())) code.putln("if (PyErr_ExceptionMatches(PyExc_AttributeError)) "
"__Pyx_RaiseMappingExpectedError(%s);" % item.py_result())
code.putln(code.error_goto(item.pos)) code.putln(code.error_goto(item.pos))
code.putln("}") code.putln("}")
item.generate_disposal_code(code) item.generate_disposal_code(code)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment