Log profiling info from maintenance scripts.
[lhc/web/wiklou.git] / maintenance / doMaintenance.php
1 <?php
2 /**
3 * We want to make this whole thing as seamless as possible to the
4 * end-user. Unfortunately, we can't do _all_ of the work in the class
5 * because A) included files are not in global scope, but in the scope
6 * of their caller, and B) MediaWiki has way too many globals. So instead
7 * we'll kinda fake it, and do the requires() inline. <3 PHP
8 *
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU General Public License as published by
11 * the Free Software Foundation; either version 2 of the License, or
12 * (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU General Public License for more details.
18 *
19 * You should have received a copy of the GNU General Public License along
20 * with this program; if not, write to the Free Software Foundation, Inc.,
21 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
22 * http://www.gnu.org/copyleft/gpl.html
23 *
24 * @author Chad Horohoe <chad@anyonecanedit.org>
25 * @file
26 * @ingroup Maintenance
27 */
28
29 if ( !defined( 'RUN_MAINTENANCE_IF_MAIN' ) ) {
30 echo "This file must be included after Maintenance.php\n";
31 exit( 1 );
32 }
33
34 // Wasn't included from the file scope, halt execution (probably wanted the class)
35 // If a class is using commandLine.inc (old school maintenance), they definitely
36 // cannot be included and will proceed with execution
37 if( !Maintenance::shouldExecute() && $maintClass != 'CommandLineInc' ) {
38 return;
39 }
40
41 if ( !$maintClass || !class_exists( $maintClass ) ) {
42 echo "\$maintClass is not set or is set to a non-existent class.\n";
43 exit( 1 );
44 }
45
46 // Get an object to start us off
47 $maintenance = new $maintClass();
48
49 // Basic sanity checks and such
50 $maintenance->setup();
51
52 // We used to call this variable $self, but it was moved
53 // to $maintenance->mSelf. Keep that here for b/c
54 $self = $maintenance->getName();
55
56 // Detect compiled mode
57 if ( isset( $_SERVER['MW_COMPILED'] ) ) {
58 define( 'MW_COMPILED', 1 );
59 } else {
60 # Get the MWInit class
61 require_once( "$IP/includes/Init.php" );
62 require_once( "$IP/includes/AutoLoader.php" );
63 }
64
65 # Stub the profiler
66 require_once( MWInit::compiledPath( 'includes/profiler/Profiler.php' ) );
67
68 // Some other requires
69 if ( !defined( 'MW_COMPILED' ) ) {
70 require_once( "$IP/includes/Defines.php" );
71 }
72 require_once( MWInit::compiledPath( 'includes/DefaultSettings.php' ) );
73
74 if ( defined( 'MW_CONFIG_CALLBACK' ) ) {
75 # Use a callback function to configure MediaWiki
76 MWFunction::call( MW_CONFIG_CALLBACK );
77 } else {
78 if ( file_exists( "$IP/../wmf-config/wikimedia-mode" ) ) {
79 // Load settings, using wikimedia-mode if needed
80 // @todo FIXME: Replace this hack with general farm-friendly code
81 # @todo FIXME: Wikimedia-specific stuff needs to go away to an ext
82 # Maybe a hook?
83 global $cluster;
84 $cluster = 'pmtpa';
85 require( MWInit::interpretedPath( '../wmf-config/wgConf.php' ) );
86 }
87 // Require the configuration (probably LocalSettings.php)
88 require( $maintenance->loadSettings() );
89 }
90
91 if ( $maintenance->getDbType() === Maintenance::DB_ADMIN &&
92 is_readable( "$IP/AdminSettings.php" ) )
93 {
94 require( MWInit::interpretedPath( 'AdminSettings.php' ) );
95 }
96
97 if ( $maintenance->getDbType() === Maintenance::DB_NONE ) {
98 if ( $wgLocalisationCacheConf['storeClass'] === false && ( $wgLocalisationCacheConf['store'] == 'db' || ( $wgLocalisationCacheConf['store'] == 'detect' && !$wgCacheDirectory ) ) )
99 $wgLocalisationCacheConf['storeClass'] = 'LCStore_Null';
100 }
101 $maintenance->finalSetup();
102 // Some last includes
103 require_once( MWInit::compiledPath( 'includes/Setup.php' ) );
104
105 // Much much faster startup than creating a title object
106 $wgTitle = null;
107
108 // Do the work
109 try {
110 $maintenance->execute();
111
112 // Potentially debug globals
113 $maintenance->globals();
114
115 // log profiling info
116 wfLogProfilingData();
117 } catch ( MWException $mwe ) {
118 echo( $mwe->getText() );
119 exit( 1 );
120 }
121