php-src/Zend/tests/debug_backtrace_with_include_and_this.phpt
Peter Kokot d679f02295 Sync leading and final newlines in *.phpt sections
This patch adds missing newlines, trims multiple redundant final
newlines into a single one, and trims redundant leading newlines in all
*.phpt sections.

According to POSIX, a line is a sequence of zero or more non-' <newline>'
characters plus a terminating '<newline>' character. [1] Files should
normally have at least one final newline character.

C89 [2] and later standards [3] mention a final newline:
"A source file that is not empty shall end in a new-line character,
which shall not be immediately preceded by a backslash character."

Although it is not mandatory for all files to have a final newline
fixed, a more consistent and homogeneous approach brings less of commit
differences issues and a better development experience in certain text
editors and IDEs.

[1] http://pubs.opengroup.org/onlinepubs/9699919799/basedefs/V1_chap03.html#tag_03_206
[2] https://port70.net/~nsz/c/c89/c89-draft.html#2.1.1.2
[3] https://port70.net/~nsz/c/c99/n1256.html#5.1.1.2
2018-10-15 04:33:09 +02:00

39 lines
1.0 KiB
PHP

--TEST--
debug_backtrace segmentation fault with include and error handler
--FILE--
<?php
class CLWrapper {
function stream_open($path, $mode, $options, $opened_path) {
return false;
}
}
class CL {
public function load($class) {
if (!include($class)) {
throw new Exception('Failed loading '.$class);
}
}
}
stream_wrapper_register('class', 'CLWrapper');
set_error_handler(function($code, $msg, $file, $line) {
$bt= debug_backtrace(DEBUG_BACKTRACE_IGNORE_ARGS, 2);
echo "ERR#$code: $msg @ ", $bt[1]['function'], "\n";
});
try {
(new CL())->load('class://non.existent.Class');
} catch (CLException $e) {
echo $e."\n";
}
--EXPECTF--
ERR#2: include(class://non.existent.Class): failed to open stream: "CLWrapper::stream_open" call failed @ include
ERR#2: include(): Failed opening 'class://non.existent.Class' for inclusion (include_path='%s') @ include
Fatal error: Uncaught Exception: Failed loading class://non.existent.Class in %s
Stack trace:
#0 %s(%d): CL->load('class://non.exi...')
#1 {main}
thrown in %s on line %d