]> scripts.mit.edu Git - autoinstalls/mediawiki.git/blob - includes/specials/SpecialMostrevisions.php
MediaWiki 1.17.0
[autoinstalls/mediawiki.git] / includes / specials / SpecialMostrevisions.php
1 <?php
2 /**
3  * Implements Special:Mostrevisions
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 special page to show pages with highest revision count
29  *
30  * @ingroup SpecialPage
31  */
32 class MostrevisionsPage extends QueryPage {
33
34         function getName() { return 'Mostrevisions'; }
35         function isExpensive() { return true; }
36         function isSyndicated() { return false; }
37
38         function getSQL() {
39                 $dbr = wfGetDB( DB_SLAVE );
40                 list( $revision, $page ) = $dbr->tableNamesN( 'revision', 'page' );
41                 return
42                         "
43                         SELECT
44                                 'Mostrevisions' as type,
45                                 page_namespace as namespace,
46                                 page_title as title,
47                                 COUNT(*) as value
48                         FROM $revision
49                         JOIN $page ON page_id = rev_page
50                         WHERE page_namespace = " . NS_MAIN . "
51                         GROUP BY page_namespace, page_title
52                         HAVING COUNT(*) > 1
53                         ";
54         }
55
56         function formatResult( $skin, $result ) {
57                 global $wgLang, $wgContLang;
58
59                 $nt = Title::makeTitle( $result->namespace, $result->title );
60                 $text = $wgContLang->convert( $nt->getPrefixedText() );
61
62                 $plink = $skin->linkKnown( $nt, $text );
63
64                 $nl = wfMsgExt( 'nrevisions', array( 'parsemag', 'escape'),
65                         $wgLang->formatNum( $result->value ) );
66                 $nlink = $skin->linkKnown(
67                         $nt,
68                         $nl,
69                         array(),
70                         array( 'action' => 'history' )
71                 );
72
73                 return wfSpecialList($plink, $nlink);
74         }
75 }
76
77 /**
78  * constructor
79  */
80 function wfSpecialMostrevisions() {
81         list( $limit, $offset ) = wfCheckLimits();
82
83         $wpp = new MostrevisionsPage();
84
85         $wpp->doQuery( $offset, $limit );
86 }