Commit a7e2f3c0 authored by Stefan Behnel's avatar Stefan Behnel

Merge branch '0.29.x'

parents 5500fbb7 bbef4d74
...@@ -454,6 +454,10 @@ Other changes ...@@ -454,6 +454,10 @@ Other changes
Bugs fixed Bugs fixed
---------- ----------
* Nested try-except statements with multiple ``return`` statements could crash
due to incorrect deletion of the ``except as`` target variable.
(Github issue #3666)
* The ``@classmethod`` decorator no longer rejects unknown input from other decorators. * The ``@classmethod`` decorator no longer rejects unknown input from other decorators.
Patch by David Woods. (Github issue #3660) Patch by David Woods. (Github issue #3660)
......
...@@ -1220,8 +1220,6 @@ class ControlFlowAnalysis(CythonTransform): ...@@ -1220,8 +1220,6 @@ class ControlFlowAnalysis(CythonTransform):
if self.flow.loops: if self.flow.loops:
self.flow.loops[-1].exceptions.append(descr) self.flow.loops[-1].exceptions.append(descr)
self.flow.block = body_block self.flow.block = body_block
## XXX: Is it still required
body_block.add_child(entry_point)
self.flow.nextblock() self.flow.nextblock()
self._visit(node.body) self._visit(node.body)
self.flow.exceptions.pop() self.flow.exceptions.pop()
...@@ -1255,11 +1253,18 @@ class ControlFlowAnalysis(CythonTransform): ...@@ -1255,11 +1253,18 @@ class ControlFlowAnalysis(CythonTransform):
self.mark_position(node) self.mark_position(node)
self.visitchildren(node) self.visitchildren(node)
for exception in self.flow.exceptions[::-1]: outer_exception_handlers = iter(self.flow.exceptions[::-1])
if exception.finally_enter: for handler in outer_exception_handlers:
self.flow.block.add_child(exception.finally_enter) if handler.finally_enter:
if exception.finally_exit: self.flow.block.add_child(handler.finally_enter)
exception.finally_exit.add_child(self.flow.exit_point) if handler.finally_exit:
# 'return' goes to function exit, or to the next outer 'finally' clause
exit_point = self.flow.exit_point
for next_handler in outer_exception_handlers:
if next_handler.finally_enter:
exit_point = next_handler.finally_enter
break
handler.finally_exit.add_child(exit_point)
break break
else: else:
if self.flow.block: if self.flow.block:
......
...@@ -270,6 +270,32 @@ def except_as_deletes_target_in_gen(x, a): ...@@ -270,6 +270,32 @@ def except_as_deletes_target_in_gen(x, a):
yield 6 yield 6
def nested_except_gh3666(a=False, b=False):
"""
>>> nested_except_gh3666()
'A'
>>> nested_except_gh3666(a=True)
'B-V'
>>> nested_except_gh3666(a=True, b=True)
'B-V-T'
"""
try:
if a:
raise ValueError
return "A"
except TypeError as exc:
return "A-T"
except ValueError as exc:
try:
if b:
raise TypeError
return "B-V"
except ValueError as exc:
return "B-V-V"
except TypeError as exc:
return "B-V-T"
### Py3 feature tests ### Py3 feature tests
def print_function(*args): def print_function(*args):
......
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