This is a personal TODO lisit of things I noticed in PHP or in php-src's codebase of things I want to fix. Anyone is free to start tackling these issues as some might be good entry point into contributing to php-src.
Some ideas might require RFC which I may or may not have already marked down as ideas on my other RFC ideas repo.
- https://heap.space
ZEND_STRL()
- Throw ValueError for
log()
with base = 1 instead of returning NAN - Fix zval_compare() semantics so that
array_diff()
andarray_intersect()
are better bheaved - Do bound checking on
time_t
andtimeval
struct members, see GH-16246 for an example - ValueError for
scandir()
on invalid sort orders - ValueError for I/O functions when an empty path is provided
- ext/standard
- ext/phar
- Add warning when destructing a scalar value (e.g. (
[$x] = true
) see: code snippet 1, code snippet 2, doc PR ) -
unserialize()
changes:- Add new option to throw when encountering an undefined class instead of creating a
PHP_Incomplete
object - Use a callback or just blanket?
- Deprecate not passing the
allowed_classes
option - Option for enabling or not the autoloader
- Deprecate INI setting after option has been introduced
- Add new option to throw when encountering an undefined class instead of creating a
-
__PHP_Incomplete_Class
- Prevent instantiation in userland
- Disable cloning
- Promote warnings to
Error
inPHP_Incomplete
object handlers - Remove
disable_classes
INI setting (see: PR) - Warn when attempting to cast non finite float values to something else (i.e.
NAN
,INF
,-INF
) - Reflection:
- Split ReflectionClass into RelfectionClass, ReflectionInterface, and ReflectionTrait (bunch of methods do not make sense for each individual type)
- Creatre a C enum for
HASH_KEY_IS_*
constants - Better name for
is_vertical
flag inphp_into_print_box_start()
- Remove call to
strlen()
inzend_get_module_version()
? - Enable
-Wshadow
warning (probably will need to only do local asexecute_date
is shadowed a lot (see related PR) - Enable
-Wconversion
warning (note: huge effort) - ext/hash uses
SUCCESS
/FAILURE
in unserialize handler for dubious reasons (i.e. it does not returnzend_return
) - New Zend API for
bin2hex()
to remove ext/hash usage in:-
ext/standard/string.c
-
ext/hash/php_hash.h
-
Zend/zend_system_id.c
-
ext/opcache/ZendAccelerator/
-
ext/soap/
-
./php_encoding.c
-
./php_http.c
- Check
to_xml_hexbin()
-
- Check related ext/session
bin_to_readable()
function
-
- Review usage of forced casts (see php-tasks issue)
- Review validation of INI settings (see php-tasks issue)
-
array_combine()
non string behaviour -
array_walk(_recursive)()
with objects as HashTable - Stream wrappers and stream filters able to disable?
-
main/network.c
-
ext/standard/head.c
-
ext/phar
what happens with empty aliases or nul bytes?- Use
P
ZPP specifier forPhar::addFile()
andPhar::setAlias()
- Use
- Check https://wiki.php.net/rfc/inconsistent-behaviors#array_of_chars is still relevant in PHP 8.
-
php_mblen()
use re-entrant version always or C23 requirement makes this irrelevant
- Deprecate
default_dir
behaviour forreaddir()
,rewinddir()
, andclosedir()
-
strip_tags()
and corresponding stream filter (todo check if both were done in 8.1) -
str_rot13()
and corresponding stream filter -
soundex()
-
metaphone()
- Deprecate
double
meaning - Deprecate non standard casts (See: RFC from someone else)
- Deprecate
exclude_disabled
parameter ofget_defined_functions()
as it is useless since 8.0- Amend documentation to reflect this
- Deprecate
realpath()
with empty string in favour ofgetcwd()
- Documentation: Update See Also section to include link to
getcwd()
- Documentation: Update See Also section to include link to