<?php
+if ( ! defined( 'MEDIAWIKI' ) )
+ die( -1 );
/**
*
* @subpackage Skins
*/
-/**
- * This is not a valid entry point, perform no further processing unless MEDIAWIKI is defined
- */
-if( defined( "MEDIAWIKI" ) ) {
-
# See skin.txt
require_once( 'Linker.php' );
require_once( 'Image.php' );
# while code from www.php.net
while (false !== ($file = $skinDir->read())) {
- if(preg_match('/^([^.].*)\.php$/',$file, $matches)) {
+ // Skip non-PHP files, hidden files, and '.dep' includes
+ if(preg_match('/^([^.]*)\.php$/',$file, $matches)) {
$aSkin = $matches[1];
$wgValidSkinNames[strtolower($aSkin)] = $aSkin;
}
$skinDir->close();
unset($matches);
-require_once( 'RecentChange.php' );
-
-/**
- * @todo document
- * @package MediaWiki
- */
-class RCCacheEntry extends RecentChange
-{
- var $secureName, $link;
- var $curlink , $difflink, $lastlink , $usertalklink , $versionlink ;
- var $userlink, $timestamp, $watched;
-
- function newFromParent( $rc )
- {
- $rc2 = new RCCacheEntry;
- $rc2->mAttribs = $rc->mAttribs;
- $rc2->mExtra = $rc->mExtra;
- return $rc2;
- }
-} ;
-
-
/**
- * The main skin class that provide methods and properties for all other skins
- * including PHPTal skins.
+ * The main skin class that provide methods and properties for all other skins.
* This base class is also the "Standard" skin.
* @package MediaWiki
*/
/** Constructor, call parent constructor */
function Skin() { parent::Linker(); }
+ /**
+ * Fetch the set of available skins.
+ * @return array of strings
+ * @static
+ */
function getSkinNames() {
global $wgValidSkinNames;
return $wgValidSkinNames;
}
+ /**
+ * Normalize a skin preference value to a form that can be loaded.
+ * If a skin can't be found, it will fall back to the configured
+ * default (or the old 'Classic' skin if that's broken).
+ * @param string $key
+ * @return string
+ * @static
+ */
+ function normalizeKey( $key ) {
+ global $wgDefaultSkin;
+ $skinNames = Skin::getSkinNames();
+
+ if( $key == '' ) {
+ // Don't return the default immediately;
+ // in a misconfiguration we need to fall back.
+ $key = $wgDefaultSkin;
+ }
+
+ if( isset( $skinNames[$key] ) ) {
+ return $key;
+ }
+
+ // Older versions of the software used a numeric setting
+ // in the user preferences.
+ $fallback = array(
+ 0 => $wgDefaultSkin,
+ 1 => 'nostalgia',
+ 2 => 'cologneblue' );
+
+ if( isset( $fallback[$key] ) ){
+ $key = $fallback[$key];
+ }
+
+ if( isset( $skinNames[$key] ) ) {
+ return $key;
+ } else {
+ // The old built-in skin
+ return 'standard';
+ }
+ }
+
+ /**
+ * Factory method for loading a skin of a given type
+ * @param string $key 'monobook', 'standard', etc
+ * @return Skin
+ * @static
+ */
+ function &newFromKey( $key ) {
+ $key = Skin::normalizeKey( $key );
+
+ $skinNames = Skin::getSkinNames();
+ $skinName = $skinNames[$key];
+
+ global $IP;
+
+ # Grab the skin class and initialise it.
+ wfSuppressWarnings();
+ // Preload base classes to work around APC/PHP5 bug
+ include_once( $IP.'/skins/'.$skinName.'.deps.php' );
+ wfRestoreWarnings();
+ require_once( $IP.'/skins/'.$skinName.'.php' );
+
+ # Check if we got if not failback to default skin
+ $className = 'Skin'.$skinName;
+ if( !class_exists( $className ) ) {
+ # DO NOT die if the class isn't found. This breaks maintenance
+ # scripts and can cause a user account to be unrecoverable
+ # except by SQL manipulation if a previously valid skin name
+ # is no longer valid.
+ $className = 'SkinStandard';
+ require_once( $IP.'/skins/Standard.php' );
+ }
+ $skin =& new $className;
+ return $skin;
+ }
+
/** @return string path to the skin stylesheet */
- function getStylesheet() { return 'common/wikistandard.css?1'; }
+ function getStylesheet() {
+ return 'common/wikistandard.css?1';
+ }
/** @return string skin name */
function getSkinName() {
}
function initPage( &$out ) {
+ global $wgFavicon;
+
$fname = 'Skin::initPage';
wfProfileIn( $fname );
- $out->addLink( array( 'rel' => 'shortcut icon', 'href' => '/favicon.ico' ) );
+ if( false !== $wgFavicon ) {
+ $out->addLink( array( 'rel' => 'shortcut icon', 'href' => $wgFavicon ) );
+ }
$this->addMetadataLinks($out);
+ $this->mRevisionId = $out->mRevisionId;
+
wfProfileOut( $fname );
}
function addMetadataLinks( &$out ) {
- global $wgTitle, $wgEnableDublinCoreRdf, $wgEnableCreativeCommonsRdf, $wgRdfMimeType, $action;
- global $wgRightsPage, $wgRightsUrl, $wgUseTrackbacks;
+ global $wgTitle, $wgEnableDublinCoreRdf, $wgEnableCreativeCommonsRdf;
+ global $wgRightsPage, $wgRightsUrl;
if( $out->isArticleRelated() ) {
# note: buggy CC software only reads first "meta" link
$out->out( $this->afterContent() );
- wfProfileClose();
$out->out( $out->reportTime() );
$out->out( "\n</body></html>" );
}
function getHeadScripts() {
- global $wgStylePath, $wgUser, $wgContLang, $wgAllowUserJs, $wgJsMimeType;
+ global $wgStylePath, $wgUser, $wgAllowUserJs, $wgJsMimeType;
$r = "<script type=\"{$wgJsMimeType}\" src=\"{$wgStylePath}/common/wikibits.js\"></script>\n";
if( $wgAllowUserJs && $wgUser->isLoggedIn() ) {
$userpage = $wgUser->getUserPage();
$wgRequest->getVal( 'wpEditToken' ) );
}
- # get the user/site-specific stylesheet, SkinPHPTal called from RawPage.php (settings are cached that way)
+ # get the user/site-specific stylesheet, SkinTemplate loads via RawPage.php (settings are cached that way)
function getUserStylesheet() {
global $wgOut, $wgStylePath, $wgRequest, $wgContLang, $wgSquidMaxage;
$sheet = $this->getStylesheet();
* Return html code that include User stylesheets
*/
function getUserStyles() {
- global $wgOut, $wgStylePath, $wgLang;
+ global $wgOut, $wgStylePath;
$s = "<style type='text/css'>\n";
$s .= "/*/*/ /*<![CDATA[*/\n"; # <-- Hide the styles from Netscape 4 without hiding them from IE/Mac
$s .= $this->getUserStylesheet();
global $wgUser, $wgContLang, $wgUser, $wgRequest, $wgTitle, $wgAllowUserCss;
$s = '';
-
+
if( $wgAllowUserCss && $wgUser->isLoggedIn() ) { # logged in
if($wgTitle->isCssSubpage() && $this->userCanPreview( $action ) ) {
$s .= $wgRequest->getText('wpTextbox1');
}
function getBodyOptions() {
- global $wgUser, $wgTitle, $wgNamespaceBackgrounds, $wgOut, $wgRequest;
+ global $wgUser, $wgTitle, $wgOut, $wgRequest;
extract( $wgRequest->getValues( 'oldid', 'redirect', 'diff' ) );
if($wgOut->isArticle() && $wgUser->getOption('editondblclick') &&
$wgTitle->userCanEdit() ) {
$t = wfMsg( 'editthispage' );
- $oid = $red = '';
- if ( !empty($redirect) && $redirect == 'no' ) {
- $red = "&redirect={$redirect}";
- }
- if ( !empty($oldid) && ! isset( $diff ) ) {
- $oid = "&oldid=" . intval( $oldid );
- }
- $s = $wgTitle->getFullURL( "action=edit{$oid}{$red}" );
- $s = 'document.location = "' .$s .'";';
+ $s = $wgTitle->getFullURL( $this->editUrlOptions() );
+ $s = 'document.location = "' .wfEscapeJSString( $s ) .'";';
$a += array ('ondblclick' => $s);
}
function getCategoryLinks () {
- global $wgOut, $wgTitle, $wgParser;
- global $wgUseCategoryMagic, $wgUseCategoryBrowser, $wgContLang;
+ global $wgOut, $wgTitle, $wgUseCategoryBrowser;
+ global $wgContLang;
- if( !$wgUseCategoryMagic ) return '' ;
if( count( $wgOut->mCategoryLinks ) == 0 ) return '';
// Use Unicode bidi embedding override characters,
// to make sure links don't smash each other up in ugly ways.
- // FIXME: should we use 'dir=emded' or something on links instead?
- $embed = $wgContLang->isRTL() ? '‫' : '‪';
- $pop = '‬';
+ $dir = $wgContLang->isRTL() ? 'rtl' : 'ltr';
+ $embed = "<span dir='$dir'>";
+ $pop = '</span>';
$t = $embed . implode ( "$pop | $embed" , $wgOut->mCategoryLinks ) . $pop;
-
+
$msg = count( $wgOut->mCategoryLinks ) === 1 ? 'categories1' : 'categories';
$s = $this->makeKnownLinkObj( Title::makeTitle( NS_SPECIAL, 'Categories' ),
wfMsg( $msg ), 'article=' . urlencode( $wgTitle->getPrefixedDBkey() ) )
}
if ( $wgUser->getNewtalk() ) {
- # do not show "You have new messages" text when we are viewing our
- # own talk page
-
+ # do not show "You have new messages" text when we are viewing our
+ # own talk page
if( !$wgTitle->equals( $wgUser->getTalkPage() ) ) {
- $tl = $this->makeKnownLinkObj( $wgUser->getTalkPage(),
- wfMsg('newmessageslink') );
- $s.= ' | <strong>'. wfMsg( 'newmessages', $tl ) . '</strong>';
+ $tl = $this->makeKnownLinkObj( $wgUser->getTalkPage(), wfMsgHtml( 'newmessageslink' ) );
+ $dl = $this->makeKnownLinkObj( $wgUser->getTalkPage(), wfMsgHtml( 'newmessagesdifflink' ), 'diff=cur' );
+ $s.= ' | <strong>'. wfMsg( 'youhavenewmessages', $tl, $dl ) . '</strong>';
# disable caching
$wgOut->setSquidMaxage(0);
$wgOut->enableClientCache(false);
function getUndeleteLink() {
global $wgUser, $wgTitle, $wgContLang, $action;
- if( (($wgTitle->getArticleId() == 0) || ($action == "history")) &&
- ($n = $wgTitle->isDeleted() ) )
+ if( $wgUser->isAllowed( 'deletedhistory' ) &&
+ (($wgTitle->getArticleId() == 0) || ($action == "history")) &&
+ ($n = $wgTitle->isDeleted() ) )
{
if ( $wgUser->isAllowed( 'delete' ) ) {
$msg = 'thisisdeleted';
function editThisPage() {
global $wgOut, $wgTitle, $wgRequest;
- $oldid = $wgRequest->getVal( 'oldid' );
- $diff = $wgRequest->getVal( 'diff' );
- $redirect = $wgRequest->getVal( 'redirect' );
-
if ( ! $wgOut->isArticleRelated() ) {
$s = wfMsg( 'protectedpage' );
} else {
} else {
$t = wfMsg( 'viewsource' );
}
- $oid = $red = '';
- if ( !is_null( $redirect ) ) { $red = "&redirect={$redirect}"; }
- if ( $oldid && ! isset( $diff ) ) {
- $oid = '&oldid='.$oldid;
- }
- $s = $this->makeKnownLinkObj( $wgTitle, $t, "action=edit{$oid}{$red}" );
+ $s = $this->makeKnownLinkObj( $wgTitle, $t, $this->editUrlOptions() );
}
return $s;
}
+ /**
+ * Return URL options for the 'edit page' link.
+ * This may include an 'oldid' specifier, if the current page view is such.
+ *
+ * @return string
+ * @access private
+ */
+ function editUrlOptions() {
+ global $wgArticle;
+
+ if( $this->mRevisionId && ! $wgArticle->isCurrent() ) {
+ return "action=edit&oldid=" . intval( $this->mRevisionId );
+ } else {
+ return "action=edit";
+ }
+ }
+
function deleteThisPage() {
global $wgUser, $wgOut, $wgTitle, $wgRequest;
}
function dateLink() {
- global $wgLinkCache;
$t1 = Title::newFromText( gmdate( 'F j' ) );
$t2 = Title::newFromText( gmdate( 'Y' ) );
- $wgLinkCache->suspend();
$id = $t1->getArticleID();
- $wgLinkCache->resume();
if ( 0 == $id ) {
$s = $this->makeBrokenLink( $t1->getText() );
}
$s .= ', ';
- $wgLinkCache->suspend();
$id = $t2->getArticleID();
- $wgLinkCache->resume();
if ( 0 == $id ) {
$s .= $this->makeBrokenLink( $t2->getText() );
}
function talkLink() {
- global $wgTitle, $wgLinkCache;
+ global $wgTitle;
if ( NS_SPECIAL == $wgTitle->getNamespace() ) {
# No discussion links for special pages
$text = wfMsg( 'talkpage' );
}
- $wgLinkCache->suspend();
$s = $this->makeLinkObj( $link, $text );
- $wgLinkCache->resume();
return $s;
}
function commentLink() {
- global $wgContLang, $wgTitle, $wgLinkCache;
+ global $wgContLang, $wgTitle;
if ( $wgTitle->getNamespace() == NS_SPECIAL ) {
return '';
wfMsg( 'postcomment' ), 'action=edit§ion=new' );
}
- /* these are used extensively in SkinPHPTal, but also some other places */
+ /* these are used extensively in SkinTemplate, but also some other places */
/*static*/ function makeSpecialUrl( $name, $urlaction='' ) {
$title = Title::makeTitle( NS_SPECIAL, $name );
return $title->getLocalURL( $urlaction );
* @access private
*/
function buildSidebar() {
- global $wgTitle, $action;
+ global $wgTitle, $action, $wgDBname, $parserMemc;
+ global $wgLanguageCode, $wgContLanguageCode;
$fname = 'SkinTemplate::buildSidebar';
- $pageurl = $wgTitle->getLocalURL();
+
wfProfileIn( $fname );
+ if ($wgLanguageCode == $wgContLanguageCode)
+ $cacheSidebar = true;
+ else
+ $cacheSidebar = false;
+
+ if ($cacheSidebar) {
+ $cachedsidebar=$parserMemc->get("{$wgDBname}:sidebar");
+ if ($cachedsidebar!="") {
+ wfProfileOut($fname);
+ return $cachedsidebar;
+ }
+ }
+
$bar = array();
$lines = explode( "\n", wfMsgForContent( 'sidebar' ) );
foreach ($lines as $line) {
'text' => $text,
'href' => $href,
'id' => 'n-' . strtr($line[1], ' ', '-'),
- 'active' => $pageurl == $href
+ 'active' => false
);
} else { continue; }
}
}
-
+ if ($cacheSidebar)
+ $cachednotice=$parserMemc->set("{$wgDBname}:sidebar",$bar,86400);
wfProfileOut( $fname );
return $bar;
}
}
-
-}
?>