Mass convert NULL -> null. Left strings and comments alone, obviously.
[lhc/web/wiklou.git] / includes / specials / SpecialUnwatchedpages.php
1 <?php
2 /**
3 * @file
4 * @ingroup SpecialPage
5 */
6
7 /**
8 * A special page that displays a list of pages that are not on anyones watchlist.
9 * Implements Special:Unwatchedpages
10 *
11 * @ingroup SpecialPage
12 * @author Ævar Arnfjörð Bjarmason <avarab@gmail.com>
13 * @copyright Copyright © 2005, Ævar Arnfjörð Bjarmason
14 * @license http://www.gnu.org/copyleft/gpl.html GNU General Public License 2.0 or later
15 */
16 class UnwatchedpagesPage extends QueryPage {
17
18 function getName() { return 'Unwatchedpages'; }
19 function isExpensive() { return true; }
20 function isSyndicated() { return false; }
21
22 function getSQL() {
23 $dbr = wfGetDB( DB_SLAVE );
24 list( $page, $watchlist ) = $dbr->tableNamesN( 'page', 'watchlist' );
25 $mwns = NS_MEDIAWIKI;
26 return
27 "
28 SELECT
29 'Unwatchedpages' as type,
30 page_namespace as namespace,
31 page_title as title,
32 page_namespace as value
33 FROM $page
34 LEFT JOIN $watchlist ON wl_namespace = page_namespace AND page_title = wl_title
35 WHERE wl_title IS NULL AND page_is_redirect = 0 AND page_namespace<>$mwns
36 ";
37 }
38
39 function sortDescending() { return false; }
40
41 function formatResult( $skin, $result ) {
42 global $wgContLang;
43
44 $nt = Title::makeTitle( $result->namespace, $result->title );
45 $text = $wgContLang->convert( $nt->getPrefixedText() );
46
47 $plink = $skin->linkKnown(
48 $nt,
49 htmlspecialchars( $text )
50 );
51 $wlink = $skin->linkKnown(
52 $nt,
53 wfMsgHtml( 'watch' ),
54 array(),
55 array( 'action' => 'watch' )
56 );
57
58 return wfSpecialList( $plink, $wlink );
59 }
60 }
61
62 /**
63 * constructor
64 */
65 function wfSpecialUnwatchedpages() {
66 global $wgUser, $wgOut;
67
68 if ( ! $wgUser->isAllowed( 'unwatchedpages' ) )
69 return $wgOut->permissionRequired( 'unwatchedpages' );
70
71 list( $limit, $offset ) = wfCheckLimits();
72
73 $wpp = new UnwatchedpagesPage();
74
75 $wpp->doQuery( $offset, $limit );
76 }