Commit 6dbd2209 authored by Stefan Behnel's avatar Stefan Behnel

Improve GIL-state assertion to point at the user function that triggered it.

parent 4bfd9354
...@@ -2080,7 +2080,8 @@ class FuncDefNode(StatNode, BlockNode): ...@@ -2080,7 +2080,8 @@ class FuncDefNode(StatNode, BlockNode):
# ----- Non-error return cleanup # ----- Non-error return cleanup
code.put_label(code.return_label) code.put_label(code.return_label)
assert gil_owned['error'] == gil_owned['success'], "%s != %s" % (gil_owned['error'], gil_owned['success']) assert gil_owned['error'] == gil_owned['success'], "%s: error path %s != success path %s" % (
self.pos, gil_owned['error'], gil_owned['success'])
for entry in used_buffer_entries: for entry in used_buffer_entries:
assure_gil('success') assure_gil('success')
...@@ -2110,7 +2111,8 @@ class FuncDefNode(StatNode, BlockNode): ...@@ -2110,7 +2111,8 @@ class FuncDefNode(StatNode, BlockNode):
# If we came through the success path, then we took the same GIL decisions as for jumping here. # If we came through the success path, then we took the same GIL decisions as for jumping here.
# If we came through the error path and did not jump, then we aligned both paths above. # If we came through the error path and did not jump, then we aligned both paths above.
# In the end, all paths are aligned from this point on. # In the end, all paths are aligned from this point on.
assert gil_owned['error'] == gil_owned['success'], "%s != %s" % (gil_owned['error'], gil_owned['success']) assert gil_owned['error'] == gil_owned['success'], "%s: error path %s != success path %s" % (
self.pos, gil_owned['error'], gil_owned['success'])
code.put_label(code.return_from_error_cleanup_label) code.put_label(code.return_from_error_cleanup_label)
for entry in lenv.var_entries: for entry in lenv.var_entries:
......
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