File tree Expand file tree Collapse file tree 3 files changed +52
-1
lines changed Expand file tree Collapse file tree 3 files changed +52
-1
lines changed Original file line number Diff line number Diff line change @@ -108,6 +108,8 @@ PHP NEWS
108108 . Fix GH-16477 (Segmentation fault when calling __debugInfo() after failed
109109 SplFileObject::__constructor). (Girgias)
110110 . Fixed bug GH-16589 (UAF in SplDoublyLinked->serialize()). (nielsdos)
111+ . Fixed bug GH-14687 (segfault on SplObjectIterator instance).
112+ (David Carlier)
111113
112114- Standard:
113115 . Fixed bug GH-16293 (Failed assertion when throwing in assert() callback with
Original file line number Diff line number Diff line change @@ -668,7 +668,7 @@ static inline HashTable *spl_filesystem_object_get_debug_info(zend_object *objec
668668 if (intern -> type == SPL_FS_DIR ) {
669669#ifdef HAVE_GLOB
670670 pnstr = spl_gen_private_prop_name (spl_ce_DirectoryIterator , "glob" , sizeof ("glob" )- 1 );
671- if (php_stream_is (intern -> u .dir .dirp ,& php_glob_stream_ops )) {
671+ if (intern -> u . dir . dirp && php_stream_is (intern -> u .dir .dirp ,& php_glob_stream_ops )) {
672672 ZVAL_STR_COPY (& tmp , intern -> path );
673673 } else {
674674 ZVAL_FALSE (& tmp );
Original file line number Diff line number Diff line change 1+ --TEST--
2+ GH-14687 segfault on debugging SplObjectStorage instance after __destruct.
3+ --CREDITS--
4+ YuanchengJiang
5+ --EXTENSIONS--
6+ phar
7+ --INI--
8+ phar.require_hash=0
9+ phar.readonly=0
10+ --FILE--
11+ <?php
12+ $ fname = __DIR__ . '/gh14687.phar.zip ' ;
13+ $ phar = new Phar ($ fname );
14+ class HasDestructor {
15+ public function __destruct () {
16+ var_dump ($ GLOBALS ['s ' ]);
17+ }
18+ }
19+ $ s = new SplObjectStorage ();
20+ $ s [$ phar ] = new HasDestructor ();
21+ register_shutdown_function (function () {
22+ global $ s ;
23+ });
24+ ?>
25+ --CLEAN--
26+ <?php
27+ @unlink (__DIR__ . '/gh14687.phar.zip ' );
28+ ?>
29+ --EXPECT--
30+ object(SplObjectStorage)#2 (1) {
31+ ["storage":"SplObjectStorage":private]=>
32+ array(1) {
33+ [0]=>
34+ array(2) {
35+ ["obj"]=>
36+ object(Phar)#1 (3) {
37+ ["pathName":"SplFileInfo":private]=>
38+ string(0) ""
39+ ["glob":"DirectoryIterator":private]=>
40+ bool(false)
41+ ["subPathName":"RecursiveDirectoryIterator":private]=>
42+ string(0) ""
43+ }
44+ ["inf"]=>
45+ object(HasDestructor)#3 (0) {
46+ }
47+ }
48+ }
49+ }
You can’t perform that action at this time.
0 commit comments