* (bug 5432) Fix inconsistencies in cookie names when using table prefixes
[mediawiki.git] / includes / SpecialMostcategories.php
blob17dbb5d60a4d07b4ca3438a9fbb34d0d66dbf925
1 <?php
2 /**
3 * @package MediaWiki
4 * @subpackage SpecialPage
6 * @author Ævar Arnfjörð Bjarmason <avarab@gmail.com>
7 * @copyright Copyright © 2005, Ævar Arnfjörð Bjarmason
8 * @license http://www.gnu.org/copyleft/gpl.html GNU General Public License 2.0 or later
9 */
11 /* */
12 require_once 'QueryPage.php';
14 /**
15 * @package MediaWiki
16 * @subpackage SpecialPage
18 class MostcategoriesPage extends QueryPage {
20 function getName() { return 'Mostcategories'; }
21 function isExpensive() { return true; }
22 function isSyndicated() { return false; }
24 function getSQL() {
25 $dbr =& wfGetDB( DB_SLAVE );
26 extract( $dbr->tableNames( 'categorylinks', 'page' ) );
27 return
29 SELECT
30 'Mostcategories' as type,
31 page_namespace as namespace,
32 page_title as title,
33 COUNT(*) as value
34 FROM $categorylinks
35 LEFT JOIN $page ON cl_from = page_id
36 WHERE page_namespace = " . NS_MAIN . "
37 GROUP BY cl_from
38 HAVING COUNT(*) > 1
42 function formatResult( $skin, $result ) {
43 global $wgContLang;
45 $nt = Title::makeTitle( $result->namespace, $result->title );
46 $text = $wgContLang->convert( $nt->getPrefixedText() );
48 $plink = $skin->makeKnownLink( $nt->getPrefixedText(), $text );
50 $nl = wfMsg( 'ncategories', $result->value );
51 $nlink = $skin->makeKnownLink( $wgContLang->specialPage( 'Categories' ), $nl, 'article=' . $nt->getPrefixedURL() );
53 return "{$plink} ({$nlink})";
57 /**
58 * constructor
60 function wfSpecialMostcategories() {
61 list( $limit, $offset ) = wfCheckLimits();
63 $wpp = new MostcategoriesPage();
65 $wpp->doQuery( $offset, $limit );