diff options
| author | Christoph M. Becker <cmbecker69@gmx.de> | 2020-05-25 19:12:24 +0200 | 
|---|---|---|
| committer | Christoph M. Becker <cmbecker69@gmx.de> | 2020-05-26 17:45:25 +0200 | 
| commit | 8483a21f29fbfd8d86ddf2eb2b7db0ae0b462949 (patch) | |
| tree | b802051897238ecb5deeaa6872a38ad1d2798b9e /sapi/phpdbg/phpdbg_utils.c | |
| parent | e483761a1e8ab058d9155688434c5fa9138f5ae1 (diff) | |
| download | php-git-8483a21f29fbfd8d86ddf2eb2b7db0ae0b462949.tar.gz | |
Fix several mostly Windows related phpdbg bugs
* Properly initialize PHPDBG_G(watch_tmp)
  Otherwise that may cause segfaults in ZTS builds.
* Deactivate potentially remaining watchpoints after REPL
  Otherwise the memory could still be protected, resulting in segfaults
  during shutdown.
* NULL zend_handlers_table after freeing
  As of commit 4130fe4[1], the `zend_handlers_table` is explicitly
  freed in the `zend_vm_dtor()`.  Since phpdbg (and maybe some other
  SAPIs) may restart the engine afterwards, we have to make sure that
  the table is also NULLed.
* Only set context option if there is a context
  In other words, we must not follow the null pointer.
* Cater to file handles without attached console
  File handles do not necessarily have an attached console (for
  instance, pipes do not), in which case `GetConsoleScreenBufferInfo()`
  fails.  In this case we set a default value (`40`) for lines like on
  other systems.
[1] <http://git.php.net/?p=php-src.git;a=commit;h=4130fe437a5db7ead1444d3748bd0fbad9829cb2>
Diffstat (limited to 'sapi/phpdbg/phpdbg_utils.c')
| -rw-r--r-- | sapi/phpdbg/phpdbg_utils.c | 7 | 
1 files changed, 5 insertions, 2 deletions
| diff --git a/sapi/phpdbg/phpdbg_utils.c b/sapi/phpdbg/phpdbg_utils.c index 857b5e3311..dca70deb8f 100644 --- a/sapi/phpdbg/phpdbg_utils.c +++ b/sapi/phpdbg/phpdbg_utils.c @@ -357,8 +357,11 @@ PHPDBG_API int phpdbg_get_terminal_height(void) /* {{{ */  #ifdef _WIN32  	CONSOLE_SCREEN_BUFFER_INFO csbi; -	GetConsoleScreenBufferInfo(GetStdHandle(STD_OUTPUT_HANDLE), &csbi); -	lines = csbi.srWindow.Bottom - csbi.srWindow.Top + 1; +	if (GetConsoleScreenBufferInfo(GetStdHandle(STD_OUTPUT_HANDLE), &csbi)) { +		lines = csbi.srWindow.Bottom - csbi.srWindow.Top + 1; +	} else { +		lines = 40; +	}  #elif defined(HAVE_SYS_IOCTL_H) && defined(TIOCGWINSZ)  	struct winsize w; | 
