Fix GlobIterator without constructor breaks count() (#18314)

As reported by OpenAI AARDVARK.
This commit is contained in:
Niels Dossche 2025-04-12 09:59:56 +02:00 committed by GitHub
parent fd7ebd4d15
commit 1684c52a88
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
2 changed files with 20 additions and 6 deletions

View file

@ -1599,12 +1599,12 @@ PHP_METHOD(GlobIterator, count)
RETURN_THROWS(); RETURN_THROWS();
} }
/* The spl_filesystem_object_get_method_check() function is called prior to calling this function. if (EXPECTED(spl_intern_is_glob(intern))) {
* Therefore, the directory entry cannot be NULL. However, if it is not NULL, then it must be a glob iterator
* by construction. */
ZEND_ASSERT(spl_intern_is_glob(intern));
RETURN_LONG(php_glob_stream_get_count(intern->u.dir.dirp, NULL)); RETURN_LONG(php_glob_stream_get_count(intern->u.dir.dirp, NULL));
} else {
/* This can happen by avoiding constructors in specially-crafted code. */
zend_throw_error(NULL, "GlobIterator is not initialized");
}
} }
/* }}} */ /* }}} */
#endif /* HAVE_GLOB */ #endif /* HAVE_GLOB */

View file

@ -0,0 +1,14 @@
--TEST--
GlobIterator without constructor breaks count()
--FILE--
<?php
$rc = new ReflectionClass(GlobIterator::class);
$in = $rc->newInstanceWithoutConstructor();
try {
count($in);
} catch (Error $e) {
echo $e->getMessage(), "\n";
}
?>
--EXPECT--
GlobIterator is not initialized