* (bug 10242) Update Chinese translations
[lhc/web/wiklou.git] / includes / SpecialStatistics.php
index 4a51efd..1c9e0ab 100644 (file)
@@ -1,8 +1,7 @@
 <?php
 /**
 *
-* @package MediaWiki
-* @subpackage SpecialPage
+* @addtogroup SpecialPage
 */
 
 /**
@@ -14,43 +13,17 @@ function wfSpecialStatistics() {
 
        $action = $wgRequest->getVal( 'action' );
 
-       $dbr =& wfGetDB( DB_SLAVE );
-       extract( $dbr->tableNames( 'page', 'site_stats', 'user', 'user_groups' ) );
+       $dbr = wfGetDB( DB_SLAVE );
 
-       $row = $dbr->selectRow( 'site_stats', '*', false, $fname );
-       $views = $row->ss_total_views;
-       $edits = $row->ss_total_edits;
-       $good = $row->ss_good_articles;
-       $images = $row->ss_images;
-
-       # This code is somewhat schema-agnostic, because I'm changing it in a minor release -- TS
-       if ( isset( $row->ss_total_pages ) && $row->ss_total_pages == -1 ) {
-               # Update schema
-               $u = new SiteStatsUpdate( 0, 0, 0 );
-               $u->doUpdate();
-               $row = $dbr->selectRow( 'site_stats', '*', false, $fname );
-       }
-
-       if ( isset( $row->ss_total_pages ) ) {
-               $total = $row->ss_total_pages;
-       } else {
-               $sql = "SELECT COUNT(page_namespace) AS total FROM $page";
-               $res = $dbr->query( $sql, $fname );
-               $pageRow = $dbr->fetchObject( $res );
-               $total = $pageRow->total;
-       }
-
-       if ( isset( $row->ss_users ) ) {
-               $users = $row->ss_users;
-       } else {
-               $sql = "SELECT MAX(user_id) AS total FROM $user";
-               $res = $dbr->query( $sql, $fname );
-               $userRow = $dbr->fetchObject( $res );
-               $users = $userRow->total;
-       }
+       $views = SiteStats::views();
+       $edits = SiteStats::edits();
+       $good = SiteStats::articles();
+       $images = SiteStats::images();
+       $total = SiteStats::pages();
+       $users = SiteStats::users();
 
        $admins = $dbr->selectField( 'user_groups', 'COUNT(*)', array( 'ug_group' => 'sysop' ), $fname );
-       $numJobs = $dbr->selectField( 'job', 'COUNT(*)', '', $fname );
+       $numJobs = $dbr->estimateRowCount('job');
 
        if ($action == 'raw') {
                $wgOut->disable();
@@ -59,7 +32,7 @@ function wfSpecialStatistics() {
                return;
        } else {
                $text = '==' . wfMsg( 'sitestats' ) . "==\n" ;
-               $text .= wfMsg( 'sitestatstext',
+               $text .= wfMsgExt( 'sitestatstext', array ( 'parsemag' ),
                        $wgLang->formatNum( $total ),
                        $wgLang->formatNum( $good ),
                        $wgLang->formatNum( $views ),
@@ -72,7 +45,7 @@ function wfSpecialStatistics() {
 
                $text .= "\n==" . wfMsg( 'userstats' ) . "==\n";
 
-               $text .= wfMsg( 'userstatstext',
+               $text .= wfMsgExt( 'userstatstext', array ( 'parsemag' ),
                        $wgLang->formatNum( $users ),
                        $wgLang->formatNum( $admins ),
                        '[[' . wfMsgForContent( 'grouppage-sysop' ) . ']]', # TODO somehow remove, kept for backwards compatibility
@@ -84,12 +57,13 @@ function wfSpecialStatistics() {
 
                global $wgDisableCounters, $wgMiserMode, $wgUser, $wgLang, $wgContLang;
                if( !$wgDisableCounters && !$wgMiserMode ) {
+                       $page = $dbr->tableName( 'page' );
                        $sql = "SELECT page_namespace, page_title, page_counter FROM {$page} WHERE page_is_redirect = 0 AND page_counter > 0 ORDER BY page_counter DESC";
                        $sql = $dbr->limitResult($sql, 10, 0);
                        $res = $dbr->query( $sql, $fname );
                        if( $res ) {
                                $wgOut->addHtml( '<h2>' . wfMsgHtml( 'statistics-mostpopular' ) . '</h2>' );
-                               $skin =& $wgUser->getSkin();
+                               $skin = $wgUser->getSkin();
                                $wgOut->addHtml( '<ol>' );
                                while( $row = $dbr->fetchObject( $res ) ) {
                                        $link = $skin->makeKnownLinkObj( Title::makeTitleSafe( $row->page_namespace, $row->page_title ) );
@@ -101,6 +75,10 @@ function wfSpecialStatistics() {
                        }
                }
                
+               $footer = wfMsg( 'statistics-footer' );
+               if( !wfEmptyMsg( 'statistics-footer', $footer ) && $footer != '' )
+                       $wgOut->addWikiText( $footer );
+               
        }
 }
 ?>