]> scripts.mit.edu Git - autoinstallsdev/mediawiki.git/blob - includes/specials/SpecialMostlinkedcategories.php
MediaWiki 1.17.3-scripts
[autoinstallsdev/mediawiki.git] / includes / specials / SpecialMostlinkedcategories.php
1 <?php
2 /**
3  * Implements Special:Mostlinkedcategories
4  *
5  * Copyright © 2005, Ævar Arnfjörð Bjarmason
6  *
7  * This program is free software; you can redistribute it and/or modify
8  * it under the terms of the GNU General Public License as published by
9  * the Free Software Foundation; either version 2 of the License, or
10  * (at your option) any later version.
11  *
12  * This program is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License along
18  * with this program; if not, write to the Free Software Foundation, Inc.,
19  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
20  * http://www.gnu.org/copyleft/gpl.html
21  *
22  * @file
23  * @ingroup SpecialPage
24  * @author Ævar Arnfjörð Bjarmason <avarab@gmail.com>
25  */
26
27 /**
28  * A querypage to show categories ordered in descending order by the pages  in them
29  *
30  * @ingroup SpecialPage
31  */
32 class MostlinkedCategoriesPage extends QueryPage {
33
34         function getName() { return 'Mostlinkedcategories'; }
35         function isExpensive() { return true; }
36         function isSyndicated() { return false; }
37
38         function getSQL() {
39                 $dbr = wfGetDB( DB_SLAVE );
40                 $categorylinks = $dbr->tableName( 'categorylinks' );
41                 $name = $dbr->addQuotes( $this->getName() );
42                 return
43                         "
44                         SELECT
45                                 $name as type,
46                                 " . NS_CATEGORY . " as namespace,
47                                 cl_to as title,
48                                 COUNT(*) as value
49                         FROM $categorylinks
50                         GROUP BY cl_to
51                         ";
52         }
53
54         function sortDescending() { return true; }
55
56         /**
57          * Fetch user page links and cache their existence
58          */
59         function preprocessResults( $db, $res ) {
60                 $batch = new LinkBatch;
61                 foreach ( $res as $row ) {
62                         $batch->add( $row->namespace, $row->title );
63                 }
64                 $batch->execute();
65
66                 // Back to start for display
67                 if ( $db->numRows( $res ) > 0 )
68                         // If there are no rows we get an error seeking.
69                         $db->dataSeek( $res, 0 );
70         }
71
72         function formatResult( $skin, $result ) {
73                 global $wgLang, $wgContLang;
74
75                 $nt = Title::makeTitle( $result->namespace, $result->title );
76                 $text = $wgContLang->convert( $nt->getText() );
77
78                 $plink = $skin->link( $nt, htmlspecialchars( $text ) );
79
80                 $nlinks = wfMsgExt( 'nmembers', array( 'parsemag', 'escape'),
81                         $wgLang->formatNum( $result->value ) );
82                 return wfSpecialList($plink, $nlinks);
83         }
84 }
85
86 /**
87  * constructor
88  */
89 function wfSpecialMostlinkedCategories() {
90         list( $limit, $offset ) = wfCheckLimits();
91
92         $wpp = new MostlinkedCategoriesPage();
93
94         $wpp->doQuery( $offset, $limit );
95 }