[ Index ] |
PHP Cross Reference of MediaWiki-1.24.0 |
[Summary view] [Print] [Text view]
1 <?php 2 /** 3 * Class definition for a wanted query page. 4 * 5 * This program is free software; you can redistribute it and/or modify 6 * it under the terms of the GNU General Public License as published by 7 * the Free Software Foundation; either version 2 of the License, or 8 * (at your option) any later version. 9 * 10 * This program is distributed in the hope that it will be useful, 11 * but WITHOUT ANY WARRANTY; without even the implied warranty of 12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 13 * GNU General Public License for more details. 14 * 15 * You should have received a copy of the GNU General Public License along 16 * with this program; if not, write to the Free Software Foundation, Inc., 17 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. 18 * http://www.gnu.org/copyleft/gpl.html 19 * 20 * @file 21 * @ingroup SpecialPage 22 */ 23 24 /** 25 * Class definition for a wanted query page like 26 * WantedPages, WantedTemplates, etc 27 * @ingroup SpecialPage 28 */ 29 abstract class WantedQueryPage extends QueryPage { 30 function isExpensive() { 31 return true; 32 } 33 34 function isSyndicated() { 35 return false; 36 } 37 38 /** 39 * Cache page existence for performance 40 * @param DatabaseBase $db 41 * @param ResultWrapper $res 42 */ 43 function preprocessResults( $db, $res ) { 44 if ( !$res->numRows() ) { 45 return; 46 } 47 48 $batch = new LinkBatch; 49 foreach ( $res as $row ) { 50 $batch->add( $row->namespace, $row->title ); 51 } 52 $batch->execute(); 53 54 // Back to start for display 55 $res->seek( 0 ); 56 } 57 58 /** 59 * Should formatResult() always check page existence, even if 60 * the results are fresh? This is a (hopefully temporary) 61 * kluge for Special:WantedFiles, which may contain false 62 * positives for files that exist e.g. in a shared repo (bug 63 * 6220). 64 * @return bool 65 */ 66 function forceExistenceCheck() { 67 return false; 68 } 69 70 /** 71 * Format an individual result 72 * 73 * @param Skin $skin Skin to use for UI elements 74 * @param object $result Result row 75 * @return string 76 */ 77 public function formatResult( $skin, $result ) { 78 $title = Title::makeTitleSafe( $result->namespace, $result->title ); 79 if ( $title instanceof Title ) { 80 if ( $this->isCached() || $this->forceExistenceCheck() ) { 81 $pageLink = $this->existenceCheck( $title ) 82 ? '<del>' . Linker::link( $title ) . '</del>' 83 : Linker::link( $title ); 84 } else { 85 $pageLink = Linker::link( 86 $title, 87 null, 88 array(), 89 array(), 90 array( 'broken' ) 91 ); 92 } 93 return $this->getLanguage()->specialList( $pageLink, $this->makeWlhLink( $title, $result ) ); 94 } else { 95 return $this->msg( 'wantedpages-badtitle', $result->title )->escaped(); 96 } 97 } 98 99 /** 100 * Does the Title currently exists 101 * 102 * This method allows a subclass to override this check 103 * (For example, wantedfiles, would want to check if the file exists 104 * not just that a page in the file namespace exists). 105 * 106 * This will only control if the link is crossed out. Whether or not the link 107 * is blue vs red is controlled by if the title exists. 108 * 109 * @note This will only be run if the page is cached (ie $wgMiserMode = true) 110 * unless forceExistenceCheck() is true. 111 * @since 1.24 112 * @return boolean 113 */ 114 protected function existenceCheck( Title $title ) { 115 return $title->isKnown(); 116 } 117 118 /** 119 * Make a "what links here" link for a given title 120 * 121 * @param Title $title Title to make the link for 122 * @param object $result Result row 123 * @return string 124 */ 125 private function makeWlhLink( $title, $result ) { 126 $wlh = SpecialPage::getTitleFor( 'Whatlinkshere', $title->getPrefixedText() ); 127 $label = $this->msg( 'nlinks' )->numParams( $result->value )->escaped(); 128 return Linker::link( $wlh, $label ); 129 } 130 }
title
Description
Body
title
Description
Body
title
Description
Body
title
Body
Generated: Fri Nov 28 14:03:12 2014 | Cross-referenced by PHPXref 0.7.1 |