Whitespace updates.
[lhc/web/wiklou.git] / index.php
index ff50131..3b7195c 100644 (file)
--- a/index.php
+++ b/index.php
@@ -63,91 +63,104 @@ ENDL;
 
 # Initialise common code.  This gives us access to GlobalFunctions, the AutoLoader, and
 # the globals $wgRequest, $wgOut, $wgUser, $wgLang and $wgContLang, amongst others; it
-# does *not* load $wgTitle or $wgArticle
-require ( dirname( __FILE__ ) . '/includes/WebStart.php' );
-
-wfProfileIn( 'index.php' );
-wfProfileIn( 'index.php-setup' );
-
-$maxLag = $wgRequest->getVal( 'maxlag' );
-if ( !is_null( $maxLag ) ) {
-       $lb = wfGetLB(); // foo()->bar() is not supported in PHP4
-       list( $host, $lag ) = $lb->getMaxLag();
-       if ( $lag > $maxLag ) {
-               header( 'HTTP/1.1 503 Service Unavailable' );
-               header( 'Retry-After: ' . max( intval( $maxLag ), 5 ) );
-               header( 'X-Database-Lag: ' . intval( $lag ) );
-               header( 'Content-Type: text/plain' );
-               if( $wgShowHostnames ) {
-                       echo "Waiting for $host: $lag seconds lagged\n";
-               } else {
-                       echo "Waiting for a database server: $lag seconds lagged\n";
+# does *not* load $wgTitle
+if ( isset( $_SERVER['MW_COMPILED'] ) ) {
+       require ( 'phase3/includes/WebStart.php' );
+} else {
+       require ( dirname( __FILE__ ) . '/includes/WebStart.php' );
+}
+
+try {
+       wfIndexMain();
+} catch ( Exception $e ) {
+       MWExceptionHandler::handle( $e );
+}
+
+function wfIndexMain() {
+       global $wgRequest, $wgShowHostnames, $mediaWiki, $wgTitle, $wgUseAjax, $wgUseFileCache;
+
+       wfProfileIn( 'index.php' );
+       wfProfileIn( 'index.php-setup' );
+
+       $maxLag = $wgRequest->getVal( 'maxlag' );
+       if ( !is_null( $maxLag ) ) {
+               $lb = wfGetLB(); // foo()->bar() is not supported in PHP4
+               list( $host, $lag ) = $lb->getMaxLag();
+               if ( $lag > $maxLag ) {
+                       header( 'HTTP/1.1 503 Service Unavailable' );
+                       header( 'Retry-After: ' . max( intval( $maxLag ), 5 ) );
+                       header( 'X-Database-Lag: ' . intval( $lag ) );
+                       header( 'Content-Type: text/plain' );
+                       if( $wgShowHostnames ) {
+                               echo "Waiting for $host: $lag seconds lagged\n";
+                       } else {
+                               echo "Waiting for a database server: $lag seconds lagged\n";
+                       }
+                       return;
                }
-               exit;
        }
-}
 
-# Initialize MediaWiki base class
-$context = RequestContext::getMain();
-$mediaWiki = new MediaWiki( $context );
+       # Initialize MediaWiki base class
+       $context = RequestContext::getMain();
+       $mediaWiki = new MediaWiki( $context );
 
-# Set title from request parameters
-$wgTitle = $mediaWiki->getTitle();
-$action = $wgRequest->getVal( 'action', 'view' );
+       # Set title from request parameters
+       $wgTitle = $mediaWiki->getTitle();
+       $action = $wgRequest->getVal( 'action', 'view' );
 
-wfProfileOut( 'index.php-setup' );
+       wfProfileOut( 'index.php-setup' );
 
-# Send Ajax requests to the Ajax dispatcher.
-if ( $wgUseAjax && $action == 'ajax' ) {
-       $dispatcher = new AjaxDispatcher();
-       $dispatcher->performAction();
-       wfProfileOut( 'index.php' );
-       $mediaWiki->restInPeace();
-       exit;
-}
+       # Send Ajax requests to the Ajax dispatcher.
+       if ( $wgUseAjax && $action == 'ajax' ) {
+               $dispatcher = new AjaxDispatcher();
+               $dispatcher->performAction();
+               wfProfileOut( 'index.php' );
+               $mediaWiki->restInPeace();
+               return;
+       }
 
-if ( $wgUseFileCache && $wgTitle !== null ) {
-       wfProfileIn( 'index.php-filecache' );
-       // Raw pages should handle cache control on their own,
-       // even when using file cache. This reduces hits from clients.
-       if ( $action != 'raw' && HTMLFileCache::useFileCache() ) {
-               /* Try low-level file cache hit */
-               $cache = new HTMLFileCache( $wgTitle, $action );
-               if ( $cache->isFileCacheGood( /* Assume up to date */ ) ) {
-                       /* Check incoming headers to see if client has this cached */
-                       if ( !$context->output->checkLastModified( $cache->fileCacheTime() ) ) {
-                               $cache->loadFromFileCache();
+       if ( $wgUseFileCache && $wgTitle !== null ) {
+               wfProfileIn( 'index.php-filecache' );
+               // Raw pages should handle cache control on their own,
+               // even when using file cache. This reduces hits from clients.
+               if ( $action != 'raw' && HTMLFileCache::useFileCache() ) {
+                       /* Try low-level file cache hit */
+                       $cache = new HTMLFileCache( $wgTitle, $action );
+                       if ( $cache->isFileCacheGood( /* Assume up to date */ ) ) {
+                               /* Check incoming headers to see if client has this cached */
+                               if ( !$context->output->checkLastModified( $cache->fileCacheTime() ) ) {
+                                       $cache->loadFromFileCache();
+                               }
+                               # Do any stats increment/watchlist stuff
+                               $article = Article::newFromTitle( $wgTitle, $context );
+                               $article->viewUpdates();
+                               # Tell OutputPage that output is taken care of
+                               $context->output->disable();
+                               wfProfileOut( 'index.php-filecache' );
+                               $mediaWiki->finalCleanup();
+                               wfProfileOut( 'index.php' );
+                               $mediaWiki->restInPeace();
+                               return;
                        }
-                       # Do any stats increment/watchlist stuff
-                       $wgArticle = MediaWiki::articleFromTitle( $wgTitle, $context );
-                       $wgArticle->viewUpdates();
-                       # Tell OutputPage that output is taken care of
-                       $context->output->disable();
-                       wfProfileOut( 'index.php-filecache' );
-                       $mediaWiki->finalCleanup();
-                       wfProfileOut( 'index.php' );
-                       $mediaWiki->restInPeace();
-                       exit;
                }
+               wfProfileOut( 'index.php-filecache' );
        }
-       wfProfileOut( 'index.php-filecache' );
-}
 
-# Setting global variables in mediaWiki
-$mediaWiki->setVal( 'DisableHardRedirects', $wgDisableHardRedirects );
-$mediaWiki->setVal( 'EnableCreativeCommonsRdf', $wgEnableCreativeCommonsRdf );
-$mediaWiki->setVal( 'EnableDublinCoreRdf', $wgEnableDublinCoreRdf );
-$mediaWiki->setVal( 'Server', $wgServer );
-$mediaWiki->setVal( 'SquidMaxage', $wgSquidMaxage );
-$mediaWiki->setVal( 'UseExternalEditor', $wgUseExternalEditor );
-$mediaWiki->setVal( 'UsePathInfo', $wgUsePathInfo );
+       /**
+        * $wgArticle is deprecated, do not use it. This will possibly be removed
+        * entirely in 1.20 or 1.21
+        * @deprecated since 1.19
+        */
+       global $wgArticle;
+
+       $wgArticle = $mediaWiki->performRequest();
 
-$mediaWiki->performRequestForTitle( $wgArticle );
-$mediaWiki->finalCleanup();
+       $mediaWiki->finalCleanup();
 
-wfProfileOut( 'index.php' );
+       wfProfileOut( 'index.php' );
 
-$mediaWiki->restInPeace();
+       $mediaWiki->restInPeace();
+}
 
 /**
  * Display something vaguely comprehensible in the event of a totally unrecoverable error.
@@ -206,4 +219,4 @@ function wfDie( $errorMsg ){
 </html>
        <?php
        die( 1 );
-}
\ No newline at end of file
+}