diff options
author | Tim Starling <tstarling@users.mediawiki.org> | 2011-04-04 12:59:55 +0000 |
---|---|---|
committer | Tim Starling <tstarling@users.mediawiki.org> | 2011-04-04 12:59:55 +0000 |
commit | 7bb50c630a6b760c0cdc7662c44f8c3607954a19 (patch) | |
tree | 16060b536069d4028318fc744210ae199e35f2e3 /includes/WebStart.php | |
parent | 2e43da7c6b555cb0adb6592f49fa56fc5e739f25 (diff) | |
download | mediawikicore-7bb50c630a6b760c0cdc7662c44f8c3607954a19.tar.gz mediawikicore-7bb50c630a6b760c0cdc7662c44f8c3607954a19.zip |
The beginnings of HipHop compiled mode support. It works now for parser cache hits.
* Work around HipHop issue 314 (volatile broken) and issue 308 (no compilation detection) by adding some large and ugly compilation detection code to WebStart.php and doMaintenance.php.
* Provide an MW_COMPILED constant which can be used to detect compiled mode throughout the codebase.
* Introduced wfIsHipHop(), which detects either compiled or interpreted mode. Used this to work around unusual eval() return value in eval.php.
* Work around lack of ini_get() in Maintenance.php, by duplicating wfIsHipHop().
* In Maintenance::shouldExecute(), accept "include" as an inclusion function name, since all kinds of inclusion give this string in HipHop.
* Introduced new class MWInit, which provides some static functions in the pre-autoloader environment.
* Introduced MWInit::compiledPath(), which provides a relative path for invoking a compiled file, and MWInit::interpretedPath(), which provides an absolute path for interpreting a PHP file. Used these new functions in the appropriate places.
* When we are running compiled code, don't include files which would generate duplicate class, function or constant definitions. Documented the new requirements on the contents of Defines.php and UtfNormalDefines.php.
* In HipHop compiled mode, it's not possible to have executable code in the same file as a class definition.
** Moved MimeMagic initialisation to the constructor.
** Moved Namespace.php global variable initialisation to Setup.php.
** Moved MemcachedSessions.php initialisation to the caller in GlobalFunctions.php.
** Moved Sanitizer.php constants and global variables to static class members. Introduced an accessor function for the attribs regex, as a new place to put code formerly at file level.
** Moved Language.php initialisation of $wgLanguageNames to Language::getLanguageNames(). Removed the global variable, marked "private" since forever.
* In two places: don't use error_log() with type=3 to append to a file, HipHop doesn't support it. Use file_put_contents() with FILE_APPEND instead.
* Work around the terrible breakage of class_exists() by using MWInit::classExists() instead in various places. In WebInstaller::getPageByName(), the class_exists() was marked with a fixme comment already, so I replaced it with an autoloader solution.
Notes
Notes:
http://mediawiki.org/wiki/Special:Code/MediaWiki/85327
Diffstat (limited to 'includes/WebStart.php')
-rw-r--r-- | includes/WebStart.php | 81 |
1 files changed, 54 insertions, 27 deletions
diff --git a/includes/WebStart.php b/includes/WebStart.php index 2c21cdb2db1a..4a40343e3169 100644 --- a/includes/WebStart.php +++ b/includes/WebStart.php @@ -8,6 +8,20 @@ * @file */ +/** + * Detect compiled mode by looking for a function that only exists if compiled + * in. Note that we can't use function_exists(), because it is terribly broken + * under HipHop due to the "volatile" feature. + */ +function wfDetectCompiledMode() { + try { + $r = new ReflectionFunction( 'wfHipHopCompilerVersion' ); + } catch ( ReflectionException $e ) { + $r = false; + } + return $r !== false; +} + # Protect against register_globals # This must be done before any globals are set by the code if ( ini_get( 'register_globals' ) ) { @@ -67,40 +81,51 @@ if ( $IP === false ) { $IP = realpath( '.' ); } - -# Start profiler -if( file_exists("$IP/StartProfiler.php") ) { - require_once( "$IP/StartProfiler.php" ); -} else { - require_once( "$IP/includes/ProfilerStub.php" ); +if ( wfDetectCompiledMode() ) { + define( 'MW_COMPILED', 1 ); } -wfProfileIn( 'WebStart.php-conf' ); -# Load up some global defines. -require_once( "$IP/includes/Defines.php" ); - -# Check for PHP 5 -if ( !function_exists( 'version_compare' ) - || version_compare( phpversion(), '5.0.0' ) < 0 -) { - define( 'MW_PHP4', '1' ); - require( "$IP/includes/DefaultSettings.php" ); - require( "$IP/includes/templates/PHP4.php" ); - exit; +if ( !defined( 'MW_COMPILED' ) ) { + # Get MWInit class + require_once( "$IP/includes/Init.php" ); + + # Start profiler + # FIXME: rewrite wfProfileIn/wfProfileOut so that they can work in compiled mode + if ( file_exists( "$IP/StartProfiler.php" ) ) { + require_once( "$IP/StartProfiler.php" ); + } else { + require_once( "$IP/includes/ProfilerStub.php" ); + } + + # Load up some global defines. + require_once( "$IP/includes/Defines.php" ); + + # Check for PHP 5 + if ( !function_exists( 'version_compare' ) + || version_compare( phpversion(), '5.0.0' ) < 0 + ) { + define( 'MW_PHP4', '1' ); + require( "$IP/includes/DefaultSettings.php" ); + require( "$IP/includes/templates/PHP4.php" ); + exit; + } + + # Start the autoloader, so that extensions can derive classes from core files + require_once( "$IP/includes/AutoLoader.php" ); } -# Start the autoloader, so that extensions can derive classes from core files -require_once( "$IP/includes/AutoLoader.php" ); +wfProfileIn( 'WebStart.php-conf' ); + # Load default settings -require_once( "$IP/includes/DefaultSettings.php" ); +require_once( MWInit::compiledPath( "includes/DefaultSettings.php" ) ); if ( defined( 'MW_CONFIG_CALLBACK' ) ) { # Use a callback function to configure MediaWiki MWFunction::call( MW_CONFIG_CALLBACK ); - } else { - if ( !defined('MW_CONFIG_FILE') ) - define('MW_CONFIG_FILE', "$IP/LocalSettings.php"); + if ( !defined( 'MW_CONFIG_FILE' ) ) { + define('MW_CONFIG_FILE', MWInit::interpretedPath( 'LocalSettings.php' ) ); + } # LocalSettings.php is the per site customization file. If it does not exist # the wiki installer needs to be launched or the generated file uploaded to @@ -115,7 +140,7 @@ if ( defined( 'MW_CONFIG_CALLBACK' ) ) { } if ( $wgEnableSelenium ) { - require_once( "$IP/includes/SeleniumWebSettings.php" ); + require_once( MWInit::compiledPath( "includes/SeleniumWebSettings.php" ) ); } wfProfileOut( 'WebStart.php-conf' ); @@ -126,12 +151,14 @@ wfProfileIn( 'WebStart.php-ob_start' ); # that would cause us to potentially mix gzip and non-gzip output, creating a # big mess. if ( !defined( 'MW_NO_OUTPUT_BUFFER' ) && ob_get_level() == 0 ) { - require_once( "$IP/includes/OutputHandler.php" ); + if ( !defined( 'MW_COMPILED' ) ) { + require_once( "$IP/includes/OutputHandler.php" ); + } ob_start( 'wfOutputHandler' ); } wfProfileOut( 'WebStart.php-ob_start' ); if ( !defined( 'MW_NO_SETUP' ) ) { - require_once( "$IP/includes/Setup.php" ); + require_once( MWInit::compiledPath( "includes/Setup.php" ) ); } |