mirror of
https://github.com/python/cpython.git
synced 2025-08-04 08:59:19 +00:00
GH-128534: Fix behavior of branch monitoring for async for
(GH-130847)
* Both branches in a pair now have a common source and are included in co_branches
This commit is contained in:
parent
e5527f2cdd
commit
89df62c120
17 changed files with 235 additions and 154 deletions
10
Python/generated_cases.c.h
generated
10
Python/generated_cases.c.h
generated
|
@ -5183,6 +5183,8 @@
|
|||
_PyStackRef exc_st;
|
||||
exc_st = stack_pointer[-1];
|
||||
awaitable_st = stack_pointer[-2];
|
||||
JUMPBY(0); // Pretend jump as we need source offset for monitoring
|
||||
(void)oparg;
|
||||
PyObject *exc = PyStackRef_AsPyObjectBorrow(exc_st);
|
||||
assert(exc && PyExceptionInstance_Check(exc));
|
||||
_PyFrame_SetStackPointer(frame, stack_pointer);
|
||||
|
@ -6607,7 +6609,6 @@
|
|||
int opcode = INSTRUMENTED_END_ASYNC_FOR;
|
||||
(void)(opcode);
|
||||
#endif
|
||||
_Py_CODEUNIT* const prev_instr = frame->instr_ptr;
|
||||
_Py_CODEUNIT* const this_instr = next_instr;
|
||||
(void)this_instr;
|
||||
frame->instr_ptr = next_instr;
|
||||
|
@ -6615,14 +6616,17 @@
|
|||
INSTRUCTION_STATS(INSTRUMENTED_END_ASYNC_FOR);
|
||||
_PyStackRef awaitable_st;
|
||||
_PyStackRef exc_st;
|
||||
// _MONITOR_BRANCH_RIGHT
|
||||
// _MONITOR_END_ASYNC_FOR
|
||||
{
|
||||
INSTRUMENTED_JUMP(prev_instr, this_instr+1, PY_MONITORING_EVENT_BRANCH_RIGHT);
|
||||
assert((next_instr-oparg)->op.code == END_SEND || (next_instr-oparg)->op.code >= MIN_INSTRUMENTED_OPCODE);
|
||||
INSTRUMENTED_JUMP(next_instr-oparg, this_instr+1, PY_MONITORING_EVENT_BRANCH_RIGHT);
|
||||
}
|
||||
// _END_ASYNC_FOR
|
||||
{
|
||||
exc_st = stack_pointer[-1];
|
||||
awaitable_st = stack_pointer[-2];
|
||||
JUMPBY(0); // Pretend jump as we need source offset for monitoring
|
||||
(void)oparg;
|
||||
PyObject *exc = PyStackRef_AsPyObjectBorrow(exc_st);
|
||||
assert(exc && PyExceptionInstance_Check(exc));
|
||||
_PyFrame_SetStackPointer(frame, stack_pointer);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue