*/
-/**
- *
- */
-global $wgSpecialPages, $wgUser;
-
/**
* @access private
*/
'Recentchanges' => new IncludableSpecialPage( 'Recentchanges' ),
'Upload' => new SpecialPage( 'Upload' ),
'Imagelist' => new SpecialPage( 'Imagelist' ),
- 'Newimages' => new SpecialPage( 'Newimages' ),
+ 'Newimages' => new IncludableSpecialPage( 'Newimages' ),
'Listusers' => new SpecialPage( 'Listusers' ),
'Statistics' => new SpecialPage( 'Statistics' ),
'Random' => new SpecialPage( 'Randompage' ),
'Uncategorizedcategories'=> new SpecialPage( 'Uncategorizedcategories' ),
'Unusedcategories' => new SpecialPage( 'Unusedcategories' ),
'Unusedimages' => new SpecialPage( 'Unusedimages' ),
- 'Wantedpages' => new SpecialPage( 'Wantedpages' ),
+ 'Wantedpages' => new IncludableSpecialPage( 'Wantedpages' ),
+ 'Wantedcategories' => new SpecialPage( 'Wantedcategories' ),
+ 'Mostlinked' => new SpecialPage( 'Mostlinked' ),
+ 'Mostlinkedcategories' => new SpecialPage( 'Mostlinkedcategories' ),
+ 'Mostcategories' => new SpecialPage( 'Mostcategories' ),
+ 'Mostimages' => new SpecialPage( 'Mostimages' ),
+ 'Mostrevisions' => new SpecialPage( 'Mostrevisions' ),
'Shortpages' => new SpecialPage( 'Shortpages' ),
'Longpages' => new SpecialPage( 'Longpages' ),
'Newpages' => new IncludableSpecialPage( 'Newpages' ),
'Ancientpages' => new SpecialPage( 'Ancientpages' ),
'Deadendpages' => new SpecialPage( 'Deadendpages' ),
'Allpages' => new IncludableSpecialPage( 'Allpages' ),
+ 'Prefixindex' => new IncludableSpecialPage( 'Prefixindex' ) ,
'Ipblocklist' => new SpecialPage( 'Ipblocklist' ),
'Specialpages' => new UnlistedSpecialPage( 'Specialpages' ),
'Contributions' => new UnlistedSpecialPage( 'Contributions' ),
'Allmessages' => new SpecialPage( 'Allmessages' ),
'Log' => new SpecialPage( 'Log' ),
'Blockip' => new SpecialPage( 'Blockip', 'block' ),
- 'Undelete' => new SpecialPage( 'Undelete', 'delete' ),
+ 'Undelete' => new SpecialPage( 'Undelete', 'deletedhistory' ),
"Import" => new SpecialPage( "Import", 'import' ),
'Lockdb' => new SpecialPage( 'Lockdb', 'siteadmin' ),
'Unlockdb' => new SpecialPage( 'Unlockdb', 'siteadmin' ),
'Userrights' => new SpecialPage( 'Userrights', 'userrights' ),
+ 'MIMEsearch' => new SpecialPage( 'MIMEsearch' ),
+ 'Unwatchedpages' => new SpecialPage( 'Unwatchedpages', 'unwatchedpages' ),
+ 'Listredirects' => new SpecialPage( 'Listredirects' )
);
-global $wgUseValidation ;
-if ( $wgUseValidation )
- $wgSpecialPages['Validate'] = new SpecialPage( 'Validate' );
-
-global $wgDisableCounters;
if( !$wgDisableCounters ) {
$wgSpecialPages['Popularpages'] = new SpecialPage( 'Popularpages' );
}
-global $wgDisableInternalSearch;
if( !$wgDisableInternalSearch ) {
- $wgSpecialPages['Search'] = new UnlistedSpecialPage( 'Search' );
+ $wgSpecialPages['Search'] = new SpecialPage( 'Search' );
}
-global $wgEmailAuthentication;
if( $wgEmailAuthentication ) {
$wgSpecialPages['Confirmemail'] = new UnlistedSpecialPage( 'Confirmemail' );
}
* @static
* @param string $name
*/
- function &getPage( $name ) {
+ function getPage( $name ) {
global $wgSpecialPages;
if ( array_key_exists( $name, $wgSpecialPages ) ) {
return $wgSpecialPages[$name];
* @param string $name
* @return mixed Title object if the redirect exists, otherwise NULL
*/
- function &getRedirect( $name ) {
+ function getRedirect( $name ) {
global $wgUser;
- switch ( $name ) {
- case 'Mypage':
- return Title::makeTitle( NS_USER, $wgUser->getName() );
- case 'Mytalk':
- return Title::makeTitle( NS_USER_TALK, $wgUser->getName() );
- case 'Mycontributions':
- return Title::makeTitle( NS_SPECIAL, 'Contributions/' . $wgUser->getName() );
- case 'Listadmins':
- return Title::makeTitle( NS_SPECIAL, 'Listusers/sysop' ); # @bug 2832
- case 'Randompage':
- return Title::makeTitle( NS_SPECIAL, 'Random' );
- default:
- return NULL;
- }
+
+ $redirects = array(
+ 'Mypage' => Title::makeTitle( NS_USER, $wgUser->getName() ),
+ 'Mytalk' => Title::makeTitle( NS_USER_TALK, $wgUser->getName() ),
+ 'Mycontributions' => Title::makeTitle( NS_SPECIAL, 'Contributions/' . $wgUser->getName() ),
+ 'Listadmins' => Title::makeTitle( NS_SPECIAL, 'Listusers/sysop' ), # @bug 2832
+ 'Randompage' => Title::makeTitle( NS_SPECIAL, 'Random' )
+ );
+ wfRunHooks( 'SpecialPageGetRedirect', array( &$redirects ) );
+
+ return isset( $redirects[$name] ) ? $redirects[$name] : null;
}
/**
*/
function executePath( &$title, $including = false ) {
global $wgSpecialPages, $wgOut, $wgTitle;
+ $fname = 'SpecialPage::executePath';
+ wfProfileIn( $fname );
$bits = split( "/", $title->getDBkey(), 2 );
$name = $bits[0];
$par = $bits[1];
}
- $page =& SpecialPage::getPage( $name );
+ $page = SpecialPage::getPage( $name );
if ( is_null( $page ) ) {
if ( $including ) {
+ wfProfileOut( $fname );
return false;
} else {
- $redir =& SpecialPage::getRedirect( $name );
+ $redir = SpecialPage::getRedirect( $name );
if ( isset( $redir ) ) {
if ( isset( $par ) )
$wgOut->redirect( $redir->getFullURL() . '/' . $par );
$retVal = $redir;
} else {
$wgOut->setArticleRelated( false );
- $wgOut->setRobotpolicy( "noindex,follow" );
- $wgOut->errorpage( "nosuchspecialpage", "nospecialpagetext" );
+ $wgOut->setRobotpolicy( 'noindex,follow' );
+ $wgOut->setStatusCode( 404 );
+ $wgOut->errorpage( 'nosuchspecialpage', 'nospecialpagetext' );
$retVal = false;
}
}
} else {
if ( $including && !$page->includable() ) {
+ wfProfileOut( $fname );
return false;
}
if($par !== NULL) {
}
$page->including( $including );
+ $profName = 'Special:' . $page->getName();
+ wfProfileIn( $profName );
$page->execute( $par );
+ wfProfileOut( $profName );
$retVal = true;
}
+ wfProfileOut( $fname );
return $retVal;
}
}
}
- # Accessor functions, see the descriptions of the associated variables above
+ /**#@+
+ * Accessor
+ *
+ * @deprecated
+ */
function getName() { return $this->mName; }
function getRestriction() { return $this->mRestriction; }
- function isListed() { return $this->mListed; }
function getFile() { return $this->mFile; }
- function including( $x = NULL ) { return wfSetVar( $this->mIncluding, $x ); }
+ function isListed() { return $this->mListed; }
+ /**#@-*/
+
+ /**#@+
+ * Accessor and mutator
+ */
+ function name( $x = NULL ) { return wfSetVar( $this->mName, $x ); }
+ function restrictions( $x = NULL) { return wfSetVar( $this->mRestrictions, $x ); }
+ function listed( $x = NULL) { return wfSetVar( $this->mListed, $x ); }
+ function func( $x = NULL) { return wfSetVar( $this->mFunction, $x ); }
+ function file( $x = NULL) { return wfSetVar( $this->mFile, $x ); }
function includable( $x = NULL ) { return wfSetVar( $this->mIncludable, $x ); }
+ function including( $x = NULL ) { return wfSetVar( $this->mIncluding, $x ); }
+ /**#@-*/
/**
* Checks if the given user (identified by an object) can execute this
$this->setHeaders();
if ( $this->userCanExecute( $wgUser ) ) {
- if ( $this->mFile ) {
+ $func = $this->mFunction;
+ // only load file if the function does not exist
+ if(!function_exists($func) and $this->mFile) {
require_once( $this->mFile );
}
- $func = $this->mFunction;
+ if ( wfRunHooks( 'SpecialPageExecuteBeforeHeader', array( &$this, &$par, &$func ) ) )
+ $this->outputHeader();
+ if ( ! wfRunHooks( 'SpecialPageExecuteBeforePage', array( &$this, &$par, &$func ) ) )
+ return;
$func( $par, $this );
+ if ( ! wfRunHooks( 'SpecialPageExecuteAfterPage', array( &$this, &$par, &$func ) ) )
+ return;
} else {
$this->displayRestrictionError();
}
}
+ function outputHeader() {
+ global $wgOut, $wgContLang;
+
+ $msg = $wgContLang->lc( $this->name() ) . '-summary';
+ $out = wfMsg( $msg );
+ if ( ! wfEmptyMsg( $msg, $out ) and $out !== '' and ! $this->including() )
+ $wgOut->addWikiText( $out );
+
+ }
+
# Returns the name that goes in the <h1> in the special page itself, and also the name that
# will be listed in Special:Specialpages
#