diff options
-rw-r--r-- | sapi/phpdbg/phpdbg_prompt.c | 10 | ||||
-rw-r--r-- | sapi/phpdbg/tests/next_001.phpt | 37 |
2 files changed, 44 insertions, 3 deletions
diff --git a/sapi/phpdbg/phpdbg_prompt.c b/sapi/phpdbg/phpdbg_prompt.c index b19739ed34..2a75dedc67 100644 --- a/sapi/phpdbg/phpdbg_prompt.c +++ b/sapi/phpdbg/phpdbg_prompt.c @@ -1535,12 +1535,18 @@ ex_is_caught: goto next; } + /* not while in conditionals */ + phpdbg_print_opline_ex(execute_data, 0); + /* perform seek operation */ if ((PHPDBG_G(flags) & PHPDBG_SEEK_MASK) && !(PHPDBG_G(flags) & PHPDBG_IN_EVAL)) { /* current address */ zend_ulong address = (zend_ulong) execute_data->opline; if (PHPDBG_G(seek_ex) != execute_data) { + if (PHPDBG_G(flags) & PHPDBG_IS_STEPPING) { + goto stepping; + } goto next; } @@ -1584,10 +1590,8 @@ ex_is_caught: } } - /* not while in conditionals */ - phpdbg_print_opline_ex(execute_data, 0); - if (PHPDBG_G(flags) & PHPDBG_IS_STEPPING && (PHPDBG_G(flags) & PHPDBG_STEP_OPCODE || execute_data->opline->lineno != PHPDBG_G(last_line))) { +stepping: PHPDBG_G(flags) &= ~PHPDBG_IS_STEPPING; DO_INTERACTIVE(1); } diff --git a/sapi/phpdbg/tests/next_001.phpt b/sapi/phpdbg/tests/next_001.phpt new file mode 100644 index 0000000000..3c92cebbdb --- /dev/null +++ b/sapi/phpdbg/tests/next_001.phpt @@ -0,0 +1,37 @@ +--TEST-- +Test next command on function boundaries +--PHPDBG-- +b 4 +r +n + + +q +--EXPECTF-- +[Successful compilation of %s] +prompt> [Breakpoint #0 added at %s:4] +prompt> [Breakpoint #0 at %s:4, hits: 1] +>00004: echo 0; + 00005: } + 00006: +prompt> 0 +[L5 %s RETURN null %s] +>00005: } + 00006: + 00007: foo(); +prompt> [L8 %s ECHO 1 %s] +>00008: echo 1; + 00009: +prompt> 1 +[L8 %s RETURN 1 %s] +[Script ended normally] +prompt> +--FILE-- +<?php + +function foo() { + echo 0; +} + +foo(); +echo 1; |