68 lines
1.6 KiB
PHP
68 lines
1.6 KiB
PHP
<?php
|
|
/**
|
|
* @package MediaWiki
|
|
* @subpackage SpecialPage
|
|
*
|
|
* @author Ævar Arnfjörð Bjarmason <avarab@gmail.com>
|
|
* @copyright Copyright © 2005, Ævar Arnfjörð Bjarmason
|
|
* @license http://www.gnu.org/copyleft/gpl.html GNU General Public License 2.0 or later
|
|
*/
|
|
|
|
/* */
|
|
require_once 'QueryPage.php';
|
|
|
|
/**
|
|
* @package MediaWiki
|
|
* @subpackage SpecialPage
|
|
*/
|
|
class MostcategoriesPage extends QueryPage {
|
|
|
|
function getName() { return 'Mostcategories'; }
|
|
function isExpensive() { return true; }
|
|
function isSyndicated() { return false; }
|
|
|
|
function getSQL() {
|
|
$dbr =& wfGetDB( DB_SLAVE );
|
|
extract( $dbr->tableNames( 'categorylinks', 'page' ) );
|
|
return
|
|
"
|
|
SELECT
|
|
'Mostcategories' as type,
|
|
page_namespace as namespace,
|
|
page_title as title,
|
|
COUNT(*) as value
|
|
FROM $categorylinks
|
|
LEFT JOIN $page ON cl_from = page_id
|
|
WHERE page_namespace = " . NS_MAIN . "
|
|
GROUP BY cl_from
|
|
HAVING COUNT(*) > 1
|
|
";
|
|
}
|
|
|
|
function formatResult( $skin, $result ) {
|
|
global $wgContLang;
|
|
|
|
$nt = Title::makeTitle( $result->namespace, $result->title );
|
|
$text = $wgContLang->convert( $nt->getPrefixedText() );
|
|
|
|
$plink = $skin->makeKnownLink( $nt->getPrefixedText(), $text );
|
|
|
|
$nl = wfMsg( 'ncategories', $result->value );
|
|
$nlink = $skin->makeKnownLink( $wgContLang->specialPage( 'Categories' ), $nl, 'article=' . $nt->getPrefixedURL() );
|
|
|
|
return "{$plink} ({$nlink})";
|
|
}
|
|
}
|
|
|
|
/**
|
|
* constructor
|
|
*/
|
|
function wfSpecialMostcategories() {
|
|
list( $limit, $offset ) = wfCheckLimits();
|
|
|
|
$wpp = new MostcategoriesPage();
|
|
|
|
$wpp->doQuery( $offset, $limit );
|
|
}
|
|
|
|
?>
|