PHP 5.4

PHP 5.4 is the next major version of PHP after the PHP 5.3 that we require as of MediaWiki 1.21 (May 2013). PHP 5.3 gave us a number of things like closures, namespaces, and late static binding. PHP 5.4 adds a number of new features: http://php.net/manual/en/migration54.changes.php

Once we are able to require PHP 5.4 there are some things we can start doing, this document attempts to list cleanup tasks that will be need to be conducted as well as new features worth discussing.

TContextSource (traits)
We can use the which my be used in RequestContext. Instead of being stuck with the ContextSource class we can implement a TContextSource trait. Context sources with parent classes would then be able to use the trait instead of having to reimplement a bunch of junk since it can't extend ContextSource.

Our ContextSource class can even become something as small as this.

WebRequest (magic_quotes_gpc)
With gone WebRequest will no longer need to modify  $_COOKIE, $_ENV, $_GET, $_POST, $_REQUEST, and $_SERVER. WebRequest::checkMagicQuotes and WebRequest::fix_magic_quotes can disappear entirely.

As a bonus result thanks to the fact that WebRequest doesn't need to be constructed early on to modify these variables we can stop constructing it inside of Setup.php and can add it properly when the main context is setup.

safe_mode
was removed so we won't need to do any more checks for it anymore.

register_globals
is gone, WebStart.php will no longer need to raise an error whenever the flag is enabled. Thus we can remove the following block of code:

parse_url
now supports protocol relative urls. We won't need to hack around this as much. Our wfParseUrl wrapper could probably be made simpler.

$this in Closures
is now handled correctly in closures. So cases where we might not have been able to use closures in the past because of needing to use private or protected methods or members can now use closures.

short array syntax
A shorter syntax is available to declare arrays. The array construct can be replaced by square brackets [ ] similar to other interpreted languages.

Array dereferencing
will now work as you might expect

JSON formatting
New flags were added to json_encode, allowing JSON pretty printing and unescaped unicode. This way a large (and slow) block of regex code could be removed from our JSON lib. Useful for the API and some extensions.

callable type-hint
A new 'callable' type hint is now available. We can remove is_callable checks from functions that take a callable as an argument and use the type-hint instead including MWCallableUpdate, ConfigFactory, SkinFactory, and probably more places.