While rambling with some code today, I realized that `call_user_func`
behaves strangely, appearing and disappearing from stack traces depending
on versions of PHP. For an example, compare
http://3v4l.org/fGpIk#vphp7@20140901, http://3v4l.org/fGpIk#v530 and
This makes debugging code quite complicated if not just annoying and
Additionally, it seems like `call_user_func` and similars are impacting
performance in some parts of my codebase (event dispatcher logic).
Therefore, here comes my idea of simply getting rid of `call_user_func`,
`call_user_func_array`, `func_get_args`, `func_num_args` and `func_get_arg`.
My plan for it would be to add a deprecation (notice? not sure about that)
in PHP 5.7, and a complete removal of those methods in PHP 7.0.
BC compatibility is easily achieved as variadics (
https://wiki.php.net/rfc/variadics) allow for writing cleaner and less
- http://3v4l.org/HDQb6 (call_user_func)
- http://3v4l.org/AgEG5 (call_user_func_array)
- http://3v4l.org/O3G6T (func_get_args) (broken in HHVM)
- http://3v4l.org/vcYso (func_get_arg) (broken in HHVM)
- http://3v4l.org/cg8i0 (func_num_args) (broken in HHVM)
Those files could moved to a library and included when running on legacy
codebases. Eventually, grepping for those function calls is also trivial.
Here's also the example with the exception and the userland implementation
of `call_user_func`, which has a much more readable/clear/inspectable stack
Thoughts? If this idea gets enough traction, I'd gladly go and ask for
karma, open an RFC and eventually provide a patch if I'm able to.