(Bug 40860) make purgeRedundantText not fail on pre MW1.5 records
[lhc/web/wiklou.git] / maintenance / doMaintenance.php
index dbb0352..2bb2a0f 100644 (file)
 /**
  * We want to make this whole thing as seamless as possible to the
  * end-user. Unfortunately, we can't do _all_ of the work in the class
- * because A) included files are not in global scope, but in the scope 
+ * because A) included files are not in global scope, but in the scope
  * of their caller, and B) MediaWiki has way too many globals. So instead
  * we'll kinda fake it, and do the requires() inline. <3 PHP
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with this program; if not, write to the Free Software Foundation, Inc.,
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
+ * http://www.gnu.org/copyleft/gpl.html
+ *
+ * @author Chad Horohoe <chad@anyonecanedit.org>
+ * @file
+ * @ingroup Maintenance
  */
 
-if( !isset( $maintClass ) || !class_exists( $maintClass ) ) {
-       echo "\$maintClass is not set or is set to a non-existent class.";
-       die();
+if ( !defined( 'RUN_MAINTENANCE_IF_MAIN' ) ) {
+       echo "This file must be included after Maintenance.php\n";
+       exit( 1 );
 }
 
-if( defined( 'MW_NO_SETUP' ) ) {
+// Wasn't included from the file scope, halt execution (probably wanted the class)
+// If a class is using commandLine.inc (old school maintenance), they definitely
+// cannot be included and will proceed with execution
+if( !Maintenance::shouldExecute() && $maintClass != 'CommandLineInc' ) {
        return;
 }
 
+if ( !$maintClass || !class_exists( $maintClass ) ) {
+       echo "\$maintClass is not set or is set to a non-existent class.\n";
+       exit( 1 );
+}
+
 // Get an object to start us off
 $maintenance = new $maintClass();
 
 // Basic sanity checks and such
 $maintenance->setup();
 
-# Setup the profiler
-if ( file_exists( "$IP/StartProfiler.php" ) ) {
-       require_once( "$IP/StartProfiler.php" );
-} else {
-       require_once( "$IP/includes/ProfilerStub.php" );
-}
+// We used to call this variable $self, but it was moved
+// to $maintenance->mSelf. Keep that here for b/c
+$self = $maintenance->getName();
 
-// Load settings, using wikimedia-mode if needed
-if( file_exists( dirname(__FILE__).'/wikimedia-mode' ) ) {
-       # TODO FIXME! Wikimedia-specific stuff needs to go away to an ext
-       # Maybe a hook?
-       global $cluster;
-       $wgWikiFarm = true;
-       $cluster = 'pmtma';
-       require_once( "$IP/includes/AutoLoader.php" );
-       require_once( "$IP/includes/SiteConfiguration.php" );
-       require( "$IP/wgConf.php" );
-       $maintenance->loadWikimediaSettings();
-       require( $IP.'/includes/Defines.php' );
-       require( $IP.'/CommonSettings.php' );
+// Detect compiled mode
+if ( isset( $_SERVER['MW_COMPILED'] ) ) {
+       define( 'MW_COMPILED', 1 );
 } else {
+       # Get the MWInit class
+       require_once( "$IP/includes/Init.php" );
        require_once( "$IP/includes/AutoLoader.php" );
+}
+
+# Stub the profiler
+require_once( MWInit::compiledPath( 'includes/profiler/Profiler.php' ) );
+
+// Some other requires
+if ( !defined( 'MW_COMPILED' ) ) {
        require_once( "$IP/includes/Defines.php" );
-       require_once( $maintenance->loadSettings() );
 }
+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 ( file_exists( "$IP/../wmf-config/wikimedia-mode" ) ) {
+               // Load settings, using wikimedia-mode if needed
+               // @todo FIXME: Replace this hack with general farm-friendly code
+               # @todo FIXME: Wikimedia-specific stuff needs to go away to an ext
+               # Maybe a hook?
+               global $cluster;
+               $cluster = 'pmtpa';
+               require( MWInit::interpretedPath( '../wmf-config/wgConf.php' ) );
+       }
+       // Require the configuration (probably LocalSettings.php)
+       require( $maintenance->loadSettings() );
+}
+
+if ( $maintenance->getDbType() === Maintenance::DB_ADMIN &&
+       is_readable( "$IP/AdminSettings.php" ) )
+{
+       require( MWInit::interpretedPath( 'AdminSettings.php' ) );
+}
+
+if ( $maintenance->getDbType() === Maintenance::DB_NONE ) {
+       if ( $wgLocalisationCacheConf['storeClass'] === false && ( $wgLocalisationCacheConf['store'] == 'db' || ( $wgLocalisationCacheConf['store'] == 'detect' && !$wgCacheDirectory ) ) )
+               $wgLocalisationCacheConf['storeClass'] = 'LCStore_Null';
+}
+$maintenance->finalSetup();
 // Some last includes
-require_once( "$IP/includes/Setup.php" );
-require_once( "$IP/install-utils.inc" );
+require_once( MWInit::compiledPath( 'includes/Setup.php' ) );
 
-$wgTitle = null; # Much much faster startup than creating a title object
+// Much much faster startup than creating a title object
+$wgTitle = null;
 
+// Do the work
 try {
        $maintenance->execute();
-} catch( MWException $mwe ) {
+
+       // Potentially debug globals
+       $maintenance->globals();
+} catch ( MWException $mwe ) {
        echo( $mwe->getText() );
-}
\ No newline at end of file
+       exit( 1 );
+}
+