X-Git-Url: https://git.heureux-cyclage.org/?a=blobdiff_plain;f=includes%2FSkin.php;h=186a883d368884d92c185da36313dc5e01f7cc08;hb=ea56a5acffcffeaa6f9bc1807299e83511b9db08;hp=45f1f2a230d2bf10efede1426956829839eb65f5;hpb=a3219c72b2851b9892bf2100934e77f460486401;p=lhc%2Fweb%2Fwiklou.git diff --git a/includes/Skin.php b/includes/Skin.php index 45f1f2a230..186a883d36 100644 --- a/includes/Skin.php +++ b/includes/Skin.php @@ -3,6 +3,7 @@ /** * * @package MediaWiki + * @subpackage Skins */ /** @@ -13,27 +14,6 @@ if( defined( "MEDIAWIKI" ) ) { # See skin.doc require_once( 'Image.php' ); -# These are the INTERNAL names, which get mapped directly to class names and -# file names in ./skins/. For display purposes, the Language class has -# internationalized names -# -/* -$wgValidSkinNames = array( - 'standard' => 'Standard', - 'nostalgia' => 'Nostalgia', - 'cologneblue' => 'CologneBlue' -); -if( $wgUsePHPTal ) { - #$wgValidSkinNames[] = 'PHPTal'; - #$wgValidSkinNames['davinci'] = 'DaVinci'; - #$wgValidSkinNames['mono'] = 'Mono'; - #$wgValidSkinNames['monobookminimal'] = 'MonoBookMinimal'; - $wgValidSkinNames['monobook'] = 'MonoBook'; - $wgValidSkinNames['myskin'] = 'MySkin'; - $wgValidSkinNames['chick'] = 'Chick'; -} -*/ - # Get a list of all skins available in /skins/ # Build using the regular expression '^(.*).php$' # Array keys are all lower case, array value keep the case used by filename @@ -43,9 +23,9 @@ $skinDir = dir($IP.'/skins'); # while code from www.php.net while (false !== ($file = $skinDir->read())) { - if(preg_match('/^(.*).php$/',$file, $matches)) { + if(preg_match('/^([^.].*)\.php$/',$file, $matches)) { $aSkin = $matches[1]; - $wgValidSkinNames[strtolower($aSkin)] = $aSkin; + $wgValidSkinNames[strtolower($aSkin)] = $aSkin; } } $skinDir->close(); @@ -61,6 +41,8 @@ $wgLinkHolders = array( 'texts' => array(), 'titles' => array() ); +global $wgInterwikiLinkHolders; +$wgInterwikiLinkHolders = array(); /** * @todo document @@ -97,13 +79,18 @@ class Skin { var $rc_cache ; # Cache for Enhanced Recent Changes var $rcCacheIndex ; # Recent Changes Cache Counter for visibility toggle var $rcMoveIndex; - var $postParseLinkColour = true; + var $postParseLinkColour = false; /**#@-*/ function Skin() { - global $wgUseOldExistenceCheck; - $postParseLinkColour = !$wgUseOldExistenceCheck; - $this->linktrail = wfMsg('linktrail'); + $this->linktrail = wfMsgForContent('linktrail'); + + # Cache option lookups done very frequently + $options = array( 'highlightbroken', 'hover' ); + foreach( $options as $opt ) { + global $wgUser; + $this->mOptions[$opt] = $wgUser->getOption( $opt ); + } } function getSkinNames() { @@ -212,10 +199,10 @@ class Skin { } function getHeadScripts() { - global $wgStylePath, $wgUser, $wgLang, $wgAllowUserJs; + global $wgStylePath, $wgUser, $wgContLang, $wgAllowUserJs; $r = "\n"; if( $wgAllowUserJs && $wgUser->getID() != 0 ) { # logged in - $userpage = $wgLang->getNsText( Namespace::getUser() ) . ":" . $wgUser->getName(); + $userpage = $wgContLang->getNsText( Namespace::getUser() ) . ":" . $wgUser->getName(); $userjs = htmlspecialchars($this->makeUrl($userpage.'/'.$this->getSkinName().'.js', 'action=raw&ctype=text/javascript')); $r .= '\n"; } @@ -224,16 +211,16 @@ class Skin { # get the user/site-specific stylesheet, SkinPHPTal called from RawPage.php (settings are cached that way) function getUserStylesheet() { - global $wgOut, $wgStylePath, $wgLang, $wgUser, $wgRequest, $wgTitle, $wgAllowUserCss; + global $wgOut, $wgStylePath, $wgContLang, $wgUser, $wgRequest, $wgTitle, $wgAllowUserCss; $sheet = $this->getStylesheet(); $action = $wgRequest->getText('action'); $s = "@import \"$wgStylePath/$sheet\";\n"; - if($wgLang->isRTL()) $s .= "@import \"$wgStylePath/common/common_rtl.css\";\n"; + if($wgContLang->isRTL()) $s .= "@import \"$wgStylePath/common/common_rtl.css\";\n"; if( $wgAllowUserCss && $wgUser->getID() != 0 ) { # logged in if($wgTitle->isCssSubpage() and $action == 'submit' and $wgTitle->userCanEditCssJsSubpage()) { $s .= $wgRequest->getText('wpTextbox1'); } else { - $userpage = $wgLang->getNsText( Namespace::getUser() ) . ":" . $wgUser->getName(); + $userpage = $wgContLang->getNsText( Namespace::getUser() ) . ":" . $wgUser->getName(); $s.= '@import "'.$this->makeUrl($userpage.'/'.$this->getSkinName().'.css', 'action=raw&ctype=text/css').'";'."\n"; } } @@ -263,9 +250,9 @@ class Skin { * Some styles that are set by user through the user settings interface. */ function doGetUserStyles() { - global $wgUser, $wgLang; + global $wgUser, $wgContLang; - $csspage = $wgLang->getNsText( NS_MEDIAWIKI ) . ':' . $this->getSkinName() . '.css'; + $csspage = $wgContLang->getNsText( NS_MEDIAWIKI ) . ':' . $this->getSkinName() . '.css'; $s = '@import "'.$this->makeUrl($csspage, 'action=raw&ctype=text/css')."\";\n"; if ( 1 == $wgUser->getOption( 'underline' ) ) { @@ -275,7 +262,7 @@ class Skin { # Force no underline $s .= "a { text-decoration: none; }\n"; } - if ( 1 == $wgUser->getOption( 'highlightbroken' ) ) { + if ( 1 == $this->mOptions['highlightbroken'] ) { $s .= "a.new, #quickbar a.new { color: #CC2200; }\n"; } if ( 1 == $wgUser->getOption( 'justify' ) ) { @@ -294,14 +281,14 @@ class Skin { } else $a = array( 'bgcolor' => '#FFFFFF' ); if($wgOut->isArticle() && $wgUser->getOption('editondblclick') && - (!$wgTitle->isProtected() || $wgUser->isSysop()) ) { + (!$wgTitle->isProtected() || $wgUser->isAllowed('protect')) ) { $t = wfMsg( 'editthispage' ); $oid = $red = ''; - if ( !empty($redirect) ) { + if ( !empty($redirect) && $redirect == 'no' ) { $red = "&redirect={$redirect}"; } if ( !empty($oldid) && ! isset( $diff ) ) { - $oid = "&oldid={$oldid}"; + $oid = "&oldid=" . IntVal( $oldid ); } $s = $wgTitle->getFullURL( "action=edit{$oid}{$red}" ); $s = 'document.location = "' .$s .'";'; @@ -313,29 +300,28 @@ class Skin { } function getExternalLinkAttributes( $link, $text, $class='' ) { - global $wgUser, $wgOut, $wgLang; + global $wgContLang; + $same = ($link == $text); $link = urldecode( $link ); - $link = $wgLang->checkTitleEncoding( $link ); + $link = $wgContLang->checkTitleEncoding( $link ); $link = str_replace( '_', ' ', $link ); $link = htmlspecialchars( $link ); $r = ($class != '') ? " class='$class'" : " class='external'"; - if ( 1 == $wgUser->getOption( 'hover' ) ) { + if( !$same && $this->mOptions['hover'] ) { $r .= " title=\"{$link}\""; } return $r; } function getInternalLinkAttributes( $link, $text, $broken = false ) { - global $wgUser, $wgOut; - $link = urldecode( $link ); $link = str_replace( '_', ' ', $link ); $link = htmlspecialchars( $link ); - if ( $broken == 'stub' ) { + if( $broken == 'stub' ) { $r = ' class="stub"'; } else if ( $broken == 'yes' ) { $r = ' class="new"'; @@ -343,7 +329,7 @@ class Skin { $r = ''; } - if ( 1 == $wgUser->getOption( 'hover' ) ) { + if( $this->mOptions['hover'] ) { $r .= " title=\"{$link}\""; } return $r; @@ -353,9 +339,7 @@ class Skin { * @param bool $broken */ function getInternalLinkAttributesObj( &$nt, $text, $broken = false ) { - global $wgUser, $wgOut; - - if ( $broken == 'stub' ) { + if( $broken == 'stub' ) { $r = ' class="stub"'; } else if ( $broken == 'yes' ) { $r = ' class="new"'; @@ -363,7 +347,7 @@ class Skin { $r = ''; } - if ( 1 == $wgUser->getOption( 'hover' ) ) { + if( $this->mOptions['hover'] ) { $r .= ' title="' . $nt->getEscapedText() . '"'; } return $r; @@ -388,7 +372,7 @@ class Skin { } function doBeforeContent() { - global $wgUser, $wgOut, $wgTitle, $wgLang, $wgSiteNotice; + global $wgUser, $wgOut, $wgTitle, $wgContLang, $wgSiteNotice; $fname = 'Skin::doBeforeContent'; wfProfileIn( $fname ); @@ -409,7 +393,7 @@ class Skin { $shove = ($qb != 0); $left = ($qb == 1 || $qb == 3); - if($wgLang->isRTL()) $left = !$left; + if($wgContLang->isRTL()) $left = !$left; if ( !$shove ) { $s .= "\n" . @@ -417,13 +401,13 @@ class Skin { } elseif( $left ) { $s .= $this->getQuickbarCompensator( $rows ); } - $l = $wgLang->isRTL() ? 'right' : 'left'; + $l = $wgContLang->isRTL() ? 'right' : 'left'; $s .= "\n"; $s .= $this->topLinks() ; $s .= "

" . $this->pageTitleLinks() . "

\n"; - $r = $wgLang->isRTL() ? "left" : "right"; + $r = $wgContLang->isRTL() ? "left" : "right"; $s .= "\n"; $s .= $this->nameAndLogin(); $s .= "\n
" . $this->searchForm() . ""; @@ -448,6 +432,7 @@ class Skin { return $s; } + function getCategoryLinks () { global $wgOut, $wgTitle, $wgUser, $wgParser; global $wgUseCategoryMagic, $wgUseCategoryBrowser, $wgLang; @@ -469,7 +454,7 @@ class Skin { $s .= '

'; # get a big array of the parents tree - $parenttree = $wgTitle->getCategorieBrowser(); + $parenttree = $wgTitle->getParentCategoryTree(); # Render the array as a serie of links function walkThrough ($tree) { @@ -487,7 +472,7 @@ class Skin { # add our current element to the list $eltitle = Title::NewFromText($element); # FIXME : should be makeLink() [AV] - $return .= $sk->makeKnownLink($element, $eltitle->getText()).' > '; + $return .= $sk->makeLink($element, $eltitle->getText()).' > '; } return $return; } @@ -531,60 +516,20 @@ class Skin { } function doAfterContent() { - global $wgUser, $wgOut, $wgLang; - $fname = 'Skin::doAfterContent'; - wfProfileIn( $fname ); - wfProfileIn( $fname.'-1' ); - - $s = "\n
\n"; - $s .= "\n\n\n"; - - wfProfileOut( $fname.'-3' ); - wfProfileIn( $fname.'-4' ); - if ( 0 != $qb ) { $s .= $this->quickBar(); } - wfProfileOut( $fname.'-4' ); - wfProfileOut( $fname ); - return $s; + # overloaded by derived classes } function pageTitleLinks() { - global $wgOut, $wgTitle, $wgUser, $wgLang, $wgUseApproval, $wgRequest; + global $wgOut, $wgTitle, $wgUser, $wgContLang, $wgUseApproval, $wgRequest; extract( $wgRequest->getValues( 'oldid', 'diff' ) ); $action = $wgRequest->getText( 'action' ); $s = $this->printableLink(); - if ( wfMsg ( 'disclaimers' ) != '-' ) $s .= ' | ' . $this->makeKnownLink( wfMsg( 'disclaimerpage' ), wfMsg( 'disclaimers' ) ) ; + $disclaimer = $this->disclaimerLink(); # may be empty + if( $disclaimer ) { + $s .= ' | ' . $disclaimer; + } if ( $wgOut->isArticleRelated() ) { if ( $wgTitle->getNamespace() == Namespace::getImage() ) { @@ -616,12 +561,13 @@ class Skin { if(!(strcmp($wgTitle->getText(),$wgUser->getName()) == 0 && $wgTitle->getNamespace()==Namespace::getTalk(Namespace::getUser()))) { $n =$wgUser->getName(); - $tl = $this->makeKnownLink( $wgLang->getNsText( + $tl = $this->makeKnownLink( $wgContLang->getNsText( Namespace::getTalk( Namespace::getUser() ) ) . ":{$n}", wfMsg('newmessageslink') ); $s.= ' | '. wfMsg( 'newmessages', $tl ) . ''; # disable caching $wgOut->setSquidMaxage(0); + $wgOut->enableClientCache(false); } } @@ -633,13 +579,13 @@ class Skin { } function getUndeleteLink() { - global $wgUser, $wgTitle, $wgLang, $action; - if( $wgUser->isSysop() && + global $wgUser, $wgTitle, $wgContLang, $action; + if( $wgUser->isAllowed('rollback') && (($wgTitle->getArticleId() == 0) || ($action == "history")) && ($n = $wgTitle->isDeleted() ) ) { return wfMsg( 'thisisdeleted', $this->makeKnownLink( - $wgLang->SpecialPage( 'Undelete/' . $wgTitle->getPrefixedDBkey() ), + $wgContLang->SpecialPage( 'Undelete/' . $wgTitle->getPrefixedDBkey() ), wfMsg( 'restorelink', $n ) ) ); } return ''; @@ -671,7 +617,7 @@ class Skin { global $wgOut, $wgTitle, $wgUser; $s = '

' . htmlspecialchars( $wgOut->getPageTitle() ) . '

'; - if($wgUser->getOption( 'editsectiononrightclick' ) && $wgTitle->userCanEdit()) { $s=$this->editSectionScript(0,$s);} + if($wgUser->getOption( 'editsectiononrightclick' ) && $wgTitle->userCanEdit()) { $s=$this->editSectionScript($wgTitle, 0,$s);} return $s; } @@ -719,19 +665,19 @@ class Skin { } function nameAndLogin() { - global $wgUser, $wgTitle, $wgLang, $wgShowIPinHeader, $wgIP; + global $wgUser, $wgTitle, $wgLang, $wgContLang, $wgShowIPinHeader, $wgIP; - $li = $wgLang->specialPage( 'Userlogin' ); - $lo = $wgLang->specialPage( 'Userlogout' ); + $li = $wgContLang->specialPage( 'Userlogin' ); + $lo = $wgContLang->specialPage( 'Userlogout' ); $s = ''; if ( 0 == $wgUser->getID() ) { if( $wgShowIPinHeader && isset( $_COOKIE[ini_get('session.name')] ) ) { $n = $wgIP; - $tl = $this->makeKnownLink( $wgLang->getNsText( + $tl = $this->makeKnownLink( $wgContLang->getNsText( Namespace::getTalk( Namespace::getUser() ) ) . ":{$n}", - $wgLang->getNsText( Namespace::getTalk( 0 ) ) ); + $wgContLang->getNsText( Namespace::getTalk( 0 ) ) ); $s .= $n . ' ('.$tl.')'; } else { @@ -748,19 +694,19 @@ class Skin { } else { $n = $wgUser->getName(); $rt = $wgTitle->getPrefixedURL(); - $tl = $this->makeKnownLink( $wgLang->getNsText( + $tl = $this->makeKnownLink( $wgContLang->getNsText( Namespace::getTalk( Namespace::getUser() ) ) . ":{$n}", - $wgLang->getNsText( Namespace::getTalk( 0 ) ) ); + $wgContLang->getNsText( Namespace::getTalk( 0 ) ) ); $tl = " ({$tl})"; - $s .= $this->makeKnownLink( $wgLang->getNsText( + $s .= $this->makeKnownLink( $wgContLang->getNsText( Namespace::getUser() ) . ":{$n}", $n ) . "{$tl}
" . $this->makeKnownLink( $lo, wfMsg( 'logout' ), "returnto={$rt}" ) . ' | ' . $this->specialLink( 'preferences' ); } - $s .= ' | ' . $this->makeKnownLink( wfMsg( 'helppage' ), + $s .= ' | ' . $this->makeKnownLink( wfMsgForContent( 'helppage' ), wfMsg( 'help' ) ); return $s; @@ -831,16 +777,15 @@ class Skin { if($id || $ip) { # both anons and non-anons have contri list $s .= $sep . $this->userContribsLink(); } - if ( 0 != $wgUser->getID() ) { # show only to signed in users - if($id) { # can only email non-anons - $s .= $sep . $this->emailUserLink(); - } + if( $this->showEmailUser( $id ) ) { + $s .= $sep . $this->emailUserLink(); } } - if ( $wgUser->isSysop() && $wgTitle->getArticleId() ) { - $s .= "\n
" . $this->deleteThisPage() . - $sep . $this->protectThisPage() . - $sep . $this->moveThisPage(); + if ( $wgTitle->getArticleId() ) { + $s .= "\n
"; + if($wgUser->isAllowed('delete')) { $s .= $this->deleteThisPage(); } + if($wgUser->isAllowed('protect')) { $s .= $sep . $this->protectThisPage(); } + if($wgUser->isAllowed('move')) { $s .= $sep . $this->moveThisPage(); } } $s .= "
\n" . $this->otherLanguages(); } @@ -881,7 +826,7 @@ class Skin { $oldid = $wgRequest->getVal( 'oldid' ); $diff = $wgRequest->getVal( 'diff' ); - if ( !is_null( $oldid ) && is_null( $diff ) && wfMsg( 'history_copyright' ) !== '-' ) { + if ( !is_null( $oldid ) && is_null( $diff ) && wfMsgForContent( 'history_copyright' ) !== '-' ) { $msg = 'history_copyright'; } else { $msg = 'copyright'; @@ -896,7 +841,7 @@ class Skin { # Give up now return $out; } - $out .= wfMsg( $msg, $link ); + $out .= wfMsgForContent( $msg, $link ); return $out; } @@ -955,153 +900,12 @@ class Skin { return $s; } - function quickBar() { - global $wgOut, $wgTitle, $wgUser, $wgRequest, $wgLang; - global $wgDisableUploads, $wgRemoteUploads; - - $fname = 'Skin::quickBar'; - wfProfileIn( $fname ); - - $action = $wgRequest->getText( 'action' ); - $wpPreview = $wgRequest->getBool( 'wpPreview' ); - $tns=$wgTitle->getNamespace(); - - $s = "\n
"; - $s .= "\n" . $this->logoText() . "\n
"; - - $sep = "\n
"; - $s .= $this->mainPageLink() - . $sep . $this->specialLink( 'recentchanges' ) - . $sep . $this->specialLink( 'randompage' ); - if ($wgUser->getID()) { - $s.= $sep . $this->specialLink( 'watchlist' ) ; - $s .= $sep .$this->makeKnownLink( $wgLang->specialPage( 'Contributions' ), - wfMsg( 'mycontris' ), 'target=' . wfUrlencode($wgUser->getName() ) ); - - } - // only show watchlist link if logged in - if ( wfMsg ( 'currentevents' ) != '-' ) $s .= $sep . $this->makeKnownLink( wfMsg( 'currentevents' ), '' ) ; - $s .= "\n

"; - $articleExists = $wgTitle->getArticleId(); - if ( $wgOut->isArticle() || $action =='edit' || $action =='history' || $wpPreview) { - if($wgOut->isArticle()) { - $s .= '' . $this->editThisPage() . ''; - } else { # backlink to the article in edit or history mode - if($articleExists){ # no backlink if no article - switch($tns) { - case 0: - $text = wfMsg('articlepage'); - break; - case 1: - $text = wfMsg('viewtalkpage'); - break; - case 2: - $text = wfMsg('userpage'); - break; - case 3: - $text = wfMsg('viewtalkpage'); - break; - case 4: - $text = wfMsg('wikipediapage'); - break; - case 5: - $text = wfMsg('viewtalkpage'); - break; - case 6: - $text = wfMsg('imagepage'); - break; - case 7: - $text = wfMsg('viewtalkpage'); - break; - default: - $text= wfMsg('articlepage'); - } - - $link = $wgTitle->getText(); - if ($nstext = $wgLang->getNsText($tns) ) { # add namespace if necessary - $link = $nstext . ':' . $link ; - } - - $s .= $this->makeLink( $link, $text ); - } elseif( $wgTitle->getNamespace() != Namespace::getSpecial() ) { - # we just throw in a "New page" text to tell the user that he's in edit mode, - # and to avoid messing with the separator that is prepended to the next item - $s .= '' . wfMsg('newpage') . ''; - } - - } - - - if( $tns%2 && $action!='edit' && !$wpPreview) { - $s.= '
'.$this->makeKnownLink($wgTitle->getPrefixedText(),wfMsg('postcomment'),'action=edit§ion=new'); - } - - /* - watching could cause problems in edit mode: - if user edits article, then loads "watch this article" in background and then saves - article with "Watch this article" checkbox disabled, the article is transparently - unwatched. Therefore we do not show the "Watch this page" link in edit mode - */ - if ( 0 != $wgUser->getID() && $articleExists) { - if($action!='edit' && $action != 'submit' ) - { - $s .= $sep . $this->watchThisPage(); - } - if ( $wgTitle->userCanEdit() ) - $s .= $sep . $this->moveThisPage(); - } - if ( $wgUser->isSysop() and $articleExists ) { - $s .= $sep . $this->deleteThisPage() . - $sep . $this->protectThisPage(); - } - $s .= $sep . $this->talkLink(); - if ($articleExists && $action !='history') { - $s .= $sep . $this->historyLink(); - } - $s.=$sep . $this->whatLinksHere(); - - if($wgOut->isArticleRelated()) { - $s .= $sep . $this->watchPageLinksLink(); - } - - if ( Namespace::getUser() == $wgTitle->getNamespace() - || $wgTitle->getNamespace() == Namespace::getTalk(Namespace::getUser()) - ) { - - $id=User::idFromName($wgTitle->getText()); - $ip=User::isIP($wgTitle->getText()); - - if($id||$ip) { - $s .= $sep . $this->userContribsLink(); - } - if ( 0 != $wgUser->getID() ) { - if($id) { # can only email real users - $s .= $sep . $this->emailUserLink(); - } - } - } - $s .= "\n

"; - } - - if ( 0 != $wgUser->getID() && ( !$wgDisableUploads || $wgRemoteUploads ) ) { - $s .= $this->specialLink( 'upload' ) . $sep; - } - $s .= $this->specialLink( 'specialpages' ) - . $sep . $this->bugReportsLink(); - - global $wgSiteSupportPage; - if( $wgSiteSupportPage ) { - $s .= "\n
' . wfMsg( 'sitesupport' ) . ''; - } - - $s .= "\n
\n"; - wfProfileOut( $fname ); - return $s; - } - + /** + * show a drop-down box of special pages + * @TODO crash bug913. Need to be rewrote completly. + */ function specialPagesList() { - global $wgUser, $wgOut, $wgLang, $wgServer, $wgRedirectScript; + global $wgUser, $wgOut, $wgContLang, $wgServer, $wgRedirectScript; require_once('SpecialPage.php'); $a = array(); $pages = SpecialPage::getPages(); @@ -1123,7 +927,7 @@ class Skin { } $go = wfMsg( 'go' ); $sp = wfMsg( 'specialpages' ); - $spp = $wgLang->specialPage( 'Specialpages' ); + $spp = $wgContLang->specialPage( 'Specialpages' ); $s = '
\n"; @@ -1131,7 +935,7 @@ class Skin { $s .= "\n"; foreach ( $a as $name => $desc ) { - $p = $wgLang->specialPage( $name ); + $p = $wgContLang->specialPage( $name ); $s .= "\n"; } $s .= "\n"; @@ -1141,28 +945,33 @@ class Skin { } function mainPageLink() { - $mp = wfMsg( 'mainpage' ); - $s = $this->makeKnownLink( $mp, $mp ); + $mp = wfMsgForContent( 'mainpage' ); + $mptxt = wfMsg( 'mainpage'); + $s = $this->makeKnownLink( $mp, $mptxt ); return $s; } function copyrightLink() { - $s = $this->makeKnownLink( wfMsg( 'copyrightpage' ), + $s = $this->makeKnownLink( wfMsgForContent( 'copyrightpage' ), wfMsg( 'copyrightpagename' ) ); return $s; } function aboutLink() { - $s = $this->makeKnownLink( wfMsg( 'aboutpage' ), + $s = $this->makeKnownLink( wfMsgForContent( 'aboutpage' ), wfMsg( 'aboutsite' ) ); return $s; } function disclaimerLink() { - $s = $this->makeKnownLink( wfMsg( 'disclaimerpage' ), - wfMsg( 'disclaimers' ) ); - return $s; + $disclaimers = wfMsg( 'disclaimers' ); + if ($disclaimers == '-') { + return ""; + } else { + return $this->makeKnownLink( wfMsgForContent( 'disclaimerpage' ), + $disclaimers ); + } } function editThisPage() { @@ -1197,7 +1006,7 @@ class Skin { global $wgUser, $wgOut, $wgTitle, $wgRequest; $diff = $wgRequest->getVal( 'diff' ); - if ( $wgTitle->getArticleId() && ( ! $diff ) && $wgUser->isSysop() ) { + if ( $wgTitle->getArticleId() && ( ! $diff ) && $wgUser->isAllowed('delete') ) { $n = $wgTitle->getPrefixedText(); $t = wfMsg( 'deletethispage' ); @@ -1212,7 +1021,7 @@ class Skin { global $wgUser, $wgOut, $wgTitle, $wgRequest; $diff = $wgRequest->getVal( 'diff' ); - if ( $wgTitle->getArticleId() && ( ! $diff ) && $wgUser->isSysop() ) { + if ( $wgTitle->getArticleId() && ( ! $diff ) && $wgUser->isAllowed('protect') ) { $n = $wgTitle->getPrefixedText(); if ( $wgTitle->isProtected() ) { @@ -1250,10 +1059,10 @@ class Skin { } function moveThisPage() { - global $wgTitle, $wgLang; + global $wgTitle, $wgContLang; - if ( $wgTitle->userCanEdit() ) { - $s = $this->makeKnownLink( $wgLang->specialPage( 'Movepage' ), + if ( $wgTitle->userCanMove() ) { + $s = $this->makeKnownLink( $wgContLang->specialPage( 'Movepage' ), wfMsg( 'movethispage' ), 'target=' . $wgTitle->getPrefixedURL() ); } // no message if page is protected - would be redundant return $s; @@ -1268,36 +1077,44 @@ class Skin { } function whatLinksHere() { - global $wgTitle, $wgLang; + global $wgTitle, $wgContLang; - $s = $this->makeKnownLink( $wgLang->specialPage( 'Whatlinkshere' ), + $s = $this->makeKnownLink( $wgContLang->specialPage( 'Whatlinkshere' ), wfMsg( 'whatlinkshere' ), 'target=' . $wgTitle->getPrefixedURL() ); return $s; } function userContribsLink() { - global $wgTitle, $wgLang; + global $wgTitle, $wgContLang; - $s = $this->makeKnownLink( $wgLang->specialPage( 'Contributions' ), + $s = $this->makeKnownLink( $wgContLang->specialPage( 'Contributions' ), wfMsg( 'contributions' ), 'target=' . $wgTitle->getPartialURL() ); return $s; } + function showEmailUser( $id ) { + global $wgEnableEmail, $wgEnableUserEmail, $wgUser; + return $wgEnableEmail && + $wgEnableUserEmail && + 0 != $wgUser->getID() && # show only to signed in users + 0 != $id; # can only email non-anons + } + function emailUserLink() { - global $wgTitle, $wgLang; + global $wgTitle, $wgContLang; - $s = $this->makeKnownLink( $wgLang->specialPage( 'Emailuser' ), + $s = $this->makeKnownLink( $wgContLang->specialPage( 'Emailuser' ), wfMsg( 'emailuser' ), 'target=' . $wgTitle->getPartialURL() ); return $s; } function watchPageLinksLink() { - global $wgOut, $wgTitle, $wgLang; + global $wgOut, $wgTitle, $wgContLang; if ( ! $wgOut->isArticleRelated() ) { $s = '(' . wfMsg( 'notanarticle' ) . ')'; } else { - $s = $this->makeKnownLink( $wgLang->specialPage( + $s = $this->makeKnownLink( $wgContLang->specialPage( 'Recentchangeslinked' ), wfMsg( 'recentchangeslinked' ), 'target=' . $wgTitle->getPrefixedURL() ); } @@ -1305,50 +1122,50 @@ class Skin { } function otherLanguages() { - global $wgOut, $wgLang, $wgTitle, $wgUseNewInterlanguage; + global $wgOut, $wgContLang, $wgTitle, $wgUseNewInterlanguage; $a = $wgOut->getLanguageLinks(); if ( 0 == count( $a ) ) { if ( !$wgUseNewInterlanguage ) return ''; - $ns = $wgLang->getNsIndex ( $wgTitle->getNamespace () ) ; + $ns = $wgContLang->getNsIndex ( $wgTitle->getNamespace () ) ; if ( $ns != 0 AND $ns != 1 ) return '' ; $pn = 'Intl' ; $x = 'mode=addlink&xt='.$wgTitle->getDBkey() ; - return $this->makeKnownLink( $wgLang->specialPage( $pn ), + return $this->makeKnownLink( $wgContLang->specialPage( $pn ), wfMsg( 'intl' ) , $x ); } if ( !$wgUseNewInterlanguage ) { $s = wfMsg( 'otherlanguages' ) . ': '; } else { - global $wgLanguageCode ; + global $wgContLanguageCode ; $x = 'mode=zoom&xt='.$wgTitle->getDBkey() ; - $x .= '&xl='.$wgLanguageCode ; - $s = $this->makeKnownLink( $wgLang->specialPage( 'Intl' ), + $x .= '&xl='.$wgContLanguageCode ; + $s = $this->makeKnownLink( $wgContLang->specialPage( 'Intl' ), wfMsg( 'otherlanguages' ) , $x ) . ': ' ; } $s = wfMsg( 'otherlanguages' ) . ': '; $first = true; - if($wgLang->isRTL()) $s .= ''; + if($wgContLang->isRTL()) $s .= ''; foreach( $a as $l ) { if ( ! $first ) { $s .= ' | '; } $first = false; $nt = Title::newFromText( $l ); $url = $nt->getFullURL(); - $text = $wgLang->getLanguageName( $nt->getInterwiki() ); + $text = $wgContLang->getLanguageName( $nt->getInterwiki() ); if ( '' == $text ) { $text = $l; } $style = $this->getExternalLinkAttributes( $l, $text ); $s .= "{$text}"; } - if($wgLang->isRTL()) $s .= ''; + if($wgContLang->isRTL()) $s .= ''; return $s; } function bugReportsLink() { - $s = $this->makeKnownLink( wfMsg( 'bugreportspage' ), + $s = $this->makeKnownLink( wfMsgForContent( 'bugreportspage' ), wfMsg( 'bugreports' ) ); return $s; } @@ -1382,7 +1199,7 @@ class Skin { } function talkLink() { - global $wgLang, $wgTitle, $wgLinkCache; + global $wgContLang, $wgTitle, $wgLinkCache; $tns = $wgTitle->getNamespace(); if ( -1 == $tns ) { return ''; } @@ -1412,7 +1229,7 @@ class Skin { $lns = Namespace::getTalk( $tns ); $text=$tp; } - $n = $wgLang->getNsText( $lns ); + $n = $wgContLang->getNsText( $lns ); if ( '' == $n ) { $link = $pn; } else { $link = $n.':'.$pn; } @@ -1424,7 +1241,7 @@ class Skin { } function commentLink() { - global $wgLang, $wgTitle, $wgLinkCache; + global $wgContLang, $wgTitle, $wgLinkCache; $tns = $wgTitle->getNamespace(); if ( -1 == $tns ) { return ''; } @@ -1433,7 +1250,7 @@ class Skin { # assert Namespace::isTalk( $lns ) - $n = $wgLang->getNsText( $lns ); + $n = $wgContLang->getNsText( $lns ); $pn = $wgTitle->getText(); $link = $n.':'.$pn; @@ -1508,11 +1325,17 @@ class Skin { function makeLinkObj( &$nt, $text= '', $query = '', $trail = '', $prefix = '' ) { global $wgOut, $wgUser, $wgLinkHolders; $fname = 'Skin::makeLinkObj'; + wfProfileIn( $fname ); # Fail gracefully - if ( ! isset($nt) ) + if ( ! isset($nt) ) { + # wfDebugDieBacktrace(); + wfProfileOut( $fname ); return "{$prefix}{$text}{$trail}"; + } + $ns = $nt->getNamespace(); + $dbkey = $nt->getDBkey(); if ( $nt->isExternal() ) { $u = $nt->getFullURL(); $link = $nt->getPrefixedURL(); @@ -1526,61 +1349,75 @@ class Skin { $trail = $m[2]; } } - $retVal = "{$text}{$inside}{$trail}"; - } elseif ( 0 == $nt->getNamespace() && "" == $nt->getText() ) { + # Assume $this->postParseLinkColour(). This prevents + # interwiki links from being parsed as external links. + global $wgInterwikiLinkHolders; + $t = "{$text}{$inside}"; + $nr = array_push($wgInterwikiLinkHolders, $t); + $retVal = '{$trail}"; + } elseif ( 0 == $ns && "" == $dbkey ) { + # A self-link with a fragment; skip existence check. $retVal = $this->makeKnownLinkObj( $nt, $text, $query, $trail, $prefix ); - } elseif ( ( -1 == $nt->getNamespace() ) || - ( Namespace::getImage() == $nt->getNamespace() ) ) { + } elseif ( ( NS_SPECIAL == $ns ) || ( NS_IMAGE == $ns ) ) { + # These are always shown as existing, currently. + # Special pages don't exist in the database; images may + # occasionally be present when there is no description + # page per se, so we always shown them. $retVal = $this->makeKnownLinkObj( $nt, $text, $query, $trail, $prefix ); - } else { - if ( $this->postParseLinkColour() ) { - $inside = ''; - if ( '' != $trail ) { - if ( preg_match( $this->linktrail, $trail, $m ) ) { - $inside = $m[1]; - $trail = $m[2]; - } + } elseif ( $this->postParseLinkColour ) { + wfProfileIn( $fname.'-postparse' ); + # Insert a placeholder, and we'll work out the existence checks + # in a big lump later. + $inside = ''; + if ( '' != $trail ) { + if ( preg_match( $this->linktrail, $trail, $m ) ) { + $inside = $m[1]; + $trail = $m[2]; } + } - # Allows wiki to bypass using linkcache, see OutputPage::parseLinkHolders() - $nr = array_push( $wgLinkHolders['namespaces'], $nt->getNamespace() ); - $wgLinkHolders['dbkeys'][] = $nt->getDBkey(); - $wgLinkHolders['queries'][] = $query; - $wgLinkHolders['texts'][] = $prefix.$text.$inside; - $wgLinkHolders['titles'][] = $nt; + # These get picked up by Parser::replaceLinkHolders() + $nr = array_push( $wgLinkHolders['namespaces'], $nt->getNamespace() ); + $wgLinkHolders['dbkeys'][] = $dbkey; + $wgLinkHolders['queries'][] = $query; + $wgLinkHolders['texts'][] = $prefix.$text.$inside; + $wgLinkHolders['titles'][] =& $nt; - $retVal = '{$trail}"; + $retVal = '{$trail}"; + wfProfileOut( $fname.'-postparse' ); + } else { + wfProfileIn( $fname.'-immediate' ); + # Work out link colour immediately + $aid = $nt->getArticleID() ; + if ( 0 == $aid ) { + $retVal = $this->makeBrokenLinkObj( $nt, $text, $query, $trail, $prefix ); } else { - # Work out link colour immediately - $aid = $nt->getArticleID() ; - if ( 0 == $aid ) { - $retVal = $this->makeBrokenLinkObj( $nt, $text, $query, $trail, $prefix ); - } else { - $threshold = $wgUser->getOption('stubthreshold') ; - if ( $threshold > 0 ) { - $dbr =& wfGetDB( DB_SLAVE ); - $s = $dbr->selectRow( 'cur', array( 'LENGTH(cur_text) AS x', 'cur_namespace', - 'cur_is_redirect' ), array( 'cur_id' => $aid ), $fname ) ; - if ( $s !== false ) { - $size = $s->x; - if ( $s->cur_is_redirect OR $s->cur_namespace != 0 ) { - $size = $threshold*2 ; # Really big - } - $dbr->freeResult( $res ); - } else { + $threshold = $wgUser->getOption('stubthreshold') ; + if ( $threshold > 0 ) { + $dbr =& wfGetDB( DB_SLAVE ); + $s = $dbr->selectRow( 'cur', array( 'LENGTH(cur_text) AS x', 'cur_namespace', + 'cur_is_redirect' ), array( 'cur_id' => $aid ), $fname ) ; + if ( $s !== false ) { + $size = $s->x; + if ( $s->cur_is_redirect OR $s->cur_namespace != 0 ) { $size = $threshold*2 ; # Really big } + $dbr->freeResult( $res ); } else { - $size = 1 ; - } - if ( $size < $threshold ) { - $retVal = $this->makeStubLinkObj( $nt, $text, $query, $trail, $prefix ); - } else { - $retVal = $this->makeKnownLinkObj( $nt, $text, $query, $trail, $prefix ); + $size = $threshold*2 ; # Really big } + } else { + $size = 1 ; + } + if ( $size < $threshold ) { + $retVal = $this->makeStubLinkObj( $nt, $text, $query, $trail, $prefix ); + } else { + $retVal = $this->makeKnownLinkObj( $nt, $text, $query, $trail, $prefix ); } } + wfProfileOut( $fname.'-immediate' ); } + wfProfileOut( $fname ); return $retVal; } @@ -1594,21 +1431,18 @@ class Skin { wfProfileIn( $fname ); if ( !is_object( $nt ) ) { + wfProfileIn( $fname ); return $text; } - $link = $nt->getPrefixedURL(); -# if ( '' != $section && substr($section,0,1) != "#" ) { -# $section = '' - - if ( '' == $link ) { - $u = ''; - if ( '' == $text ) { - $text = htmlspecialchars( $nt->getFragment() ); - } - } else { - $u = $nt->escapeLocalURL( $query ); - } + + $u = $nt->escapeLocalURL( $query ); if ( '' != $nt->getFragment() ) { + if( $nt->getPrefixedDbkey() == '' ) { + $u = ''; + if ( '' == $text ) { + $text = htmlspecialchars( $nt->getFragment() ); + } + } $anchor = urlencode( do_html_entity_decode( str_replace(' ', '_', $nt->getFragment()), ENT_COMPAT, $wgInputEncoding ) ); $replacearray = array( '%3A' => ':', @@ -1637,11 +1471,11 @@ class Skin { * Pass a title object, not a title string */ function makeBrokenLinkObj( &$nt, $text = '', $query = '', $trail = '', $prefix = '' ) { - global $wgOut, $wgUser; - # Fail gracefully - if ( ! isset($nt) ) + if ( ! isset($nt) ) { + # wfDebugDieBacktrace(); return "{$prefix}{$text}{$trail}"; + } $fname = 'Skin::makeBrokenLinkObj'; wfProfileIn( $fname ); @@ -1665,7 +1499,7 @@ class Skin { $trail = $m[2]; } } - if ( $wgUser->getOption( 'highlightbroken' ) ) { + if ( $this->mOptions['highlightbroken'] ) { $s = "{$prefix}{$text}{$inside}{$trail}"; } else { $s = "{$prefix}{$text}{$inside}?{$trail}"; @@ -1679,8 +1513,6 @@ class Skin { * Pass a title object, not a title string */ function makeStubLinkObj( &$nt, $text = '', $query = '', $trail = '', $prefix = '' ) { - global $wgOut, $wgUser; - $link = $nt->getPrefixedURL(); $u = $nt->escapeLocalURL( $query ); @@ -1697,7 +1529,7 @@ class Skin { $trail = $m[2]; } } - if ( $wgUser->getOption( 'highlightbroken' ) ) { + if ( $this->mOptions['highlightbroken'] ) { $s = "{$prefix}{$text}{$inside}{$trail}"; } else { $s = "{$prefix}{$text}{$inside}!{$trail}"; @@ -1748,6 +1580,17 @@ class Skin { $this->checkTitle($title, $name); return $title->getLocalURL( $urlaction ); } + + # If url string starts with http, consider as external URL, else + # internal + /*static*/ function makeInternalOrExternalUrl( $name ) { + if ( strncmp( $name, 'http', 4 ) == 0 ) { + return $name; + } else { + return $this->makeUrl( $name ); + } + } + # this can be passed the NS number as defined in Language.php /*static*/ function makeNSUrl( $name, $urlaction='', $namespace=0 ) { $title = Title::makeTitleSafe( $namespace, $name ); @@ -1813,7 +1656,6 @@ class Skin { function makeImage( $url, $alt = '' ) { global $wgOut; - if ( '' == $alt ) { $alt = $this->fnamePart( $url ); } @@ -1827,123 +1669,119 @@ class Skin { } function makeImageLinkObj( $nt, $alt = '' ) { - global $wgLang, $wgUseImageResize; + global $wgContLang, $wgUseImageResize; $img = Image::newFromTitle( $nt ); - $url = $img->getURL(); + $url = $img->getViewURL(); $align = ''; $prefix = $postfix = ''; - if ( $wgUseImageResize ) { - # Check if the alt text is of the form "options|alt text" - # Options are: - # * thumbnail make a thumbnail with enlarge-icon and caption, alignment depends on lang - # * left no resizing, just left align. label is used for alt= only - # * right same, but right aligned - # * none same, but not aligned - # * ___px scale to ___ pixels width, no aligning. e.g. use in taxobox - # * center center the image - # * framed Keep original image size, no magnify-button. - - $part = explode( '|', $alt); - - $mwThumb =& MagicWord::get( MAG_IMG_THUMBNAIL ); - $mwLeft =& MagicWord::get( MAG_IMG_LEFT ); - $mwRight =& MagicWord::get( MAG_IMG_RIGHT ); - $mwNone =& MagicWord::get( MAG_IMG_NONE ); - $mwWidth =& MagicWord::get( MAG_IMG_WIDTH ); - $mwCenter =& MagicWord::get( MAG_IMG_CENTER ); - $mwFramed =& MagicWord::get( MAG_IMG_FRAMED ); - $alt = $part[count($part)-1]; - - $height = $framed = $thumb = false; - $manual_thumb = "" ; - - foreach( $part as $key => $val ) { - $val_parts = explode ( "=" , $val , 2 ) ; - $left_part = array_shift ( $val_parts ) ; - if ( ! is_null( $mwThumb->matchVariableStartToEnd($val) ) ) { - $thumb=true; - } elseif ( count ( $val_parts ) == 1 && ! is_null( $mwThumb->matchVariableStartToEnd($left_part) ) ) { - # use manually specified thumbnail - $thumb=true; - $manual_thumb = array_shift ( $val_parts ) ; - } elseif ( ! is_null( $mwRight->matchVariableStartToEnd($val) ) ) { - # remember to set an alignment, don't render immediately - $align = 'right'; - } elseif ( ! is_null( $mwLeft->matchVariableStartToEnd($val) ) ) { - # remember to set an alignment, don't render immediately - $align = 'left'; - } elseif ( ! is_null( $mwCenter->matchVariableStartToEnd($val) ) ) { - # remember to set an alignment, don't render immediately - $align = 'center'; - } elseif ( ! is_null( $mwNone->matchVariableStartToEnd($val) ) ) { - # remember to set an alignment, don't render immediately - $align = 'none'; - } elseif ( ! is_null( $match = $mwWidth->matchVariableStartToEnd($val) ) ) { - # $match is the image width in pixels - if ( preg_match( '/^([0-9]*)x([0-9]*)$/', $match, $m ) ) { - $width = intval( $m[1] ); - $height = intval( $m[2] ); - } else { - $width = intval($match); - } - } elseif ( ! is_null( $mwFramed->matchVariableStartToEnd($val) ) ) { - $framed=true; + # Check if the alt text is of the form "options|alt text" + # Options are: + # * thumbnail make a thumbnail with enlarge-icon and caption, alignment depends on lang + # * left no resizing, just left align. label is used for alt= only + # * right same, but right aligned + # * none same, but not aligned + # * ___px scale to ___ pixels width, no aligning. e.g. use in taxobox + # * center center the image + # * framed Keep original image size, no magnify-button. + + $part = explode( '|', $alt); + + $mwThumb =& MagicWord::get( MAG_IMG_THUMBNAIL ); + $mwLeft =& MagicWord::get( MAG_IMG_LEFT ); + $mwRight =& MagicWord::get( MAG_IMG_RIGHT ); + $mwNone =& MagicWord::get( MAG_IMG_NONE ); + $mwWidth =& MagicWord::get( MAG_IMG_WIDTH ); + $mwCenter =& MagicWord::get( MAG_IMG_CENTER ); + $mwFramed =& MagicWord::get( MAG_IMG_FRAMED ); + $alt = ''; + + $height = $framed = $thumb = false; + $manual_thumb = "" ; + + foreach( $part as $key => $val ) { + $val_parts = explode ( "=" , $val , 2 ) ; + $left_part = array_shift ( $val_parts ) ; + if ( $wgUseImageResize && ! is_null( $mwThumb->matchVariableStartToEnd($val) ) ) { + $thumb=true; + } elseif ( $wgUseImageResize && count ( $val_parts ) == 1 && ! is_null( $mwThumb->matchVariableStartToEnd($left_part) ) ) { + # use manually specified thumbnail + $thumb=true; + $manual_thumb = array_shift ( $val_parts ) ; + } elseif ( ! is_null( $mwRight->matchVariableStartToEnd($val) ) ) { + # remember to set an alignment, don't render immediately + $align = 'right'; + } elseif ( ! is_null( $mwLeft->matchVariableStartToEnd($val) ) ) { + # remember to set an alignment, don't render immediately + $align = 'left'; + } elseif ( ! is_null( $mwCenter->matchVariableStartToEnd($val) ) ) { + # remember to set an alignment, don't render immediately + $align = 'center'; + } elseif ( ! is_null( $mwNone->matchVariableStartToEnd($val) ) ) { + # remember to set an alignment, don't render immediately + $align = 'none'; + } elseif ( $wgUseImageResize && ! is_null( $match = $mwWidth->matchVariableStartToEnd($val) ) ) { + # $match is the image width in pixels + if ( preg_match( '/^([0-9]*)x([0-9]*)$/', $match, $m ) ) { + $width = intval( $m[1] ); + $height = intval( $m[2] ); + } else { + $width = intval($match); } + } elseif ( ! is_null( $mwFramed->matchVariableStartToEnd($val) ) ) { + $framed=true; + } else { + $alt = $val; } - if ( 'center' == $align ) - { - $prefix = ''; - $postfix = ''; - $align = 'none'; + } + if ( 'center' == $align ) + { + $prefix = '
'; + $postfix = '
'; + $align = 'none'; + } + + if ( $thumb || $framed ) { + + # Create a thumbnail. Alignment depends on language + # writing direction, # right aligned for left-to-right- + # languages ("Western languages"), left-aligned + # for right-to-left-languages ("Semitic languages") + # + # If thumbnail width has not been provided, it is set + # here to 180 pixels + if ( $align == '' ) { + $align = $wgContLang->isRTL() ? 'left' : 'right'; } + if ( ! isset($width) ) { + $width = 180; + } + return $prefix.$this->makeThumbLinkObj( $img, $alt, $align, $width, $height, $framed, $manual_thumb ).$postfix; - if ( $thumb || $framed ) { - - # Create a thumbnail. Alignment depends on language - # writing direction, # right aligned for left-to-right- - # languages ("Western languages"), left-aligned - # for right-to-left-languages ("Semitic languages") - # - # If thumbnail width has not been provided, it is set - # here to 180 pixels - if ( $align == '' ) { - $align = $wgLang->isRTL() ? 'left' : 'right'; - } - if ( ! isset($width) ) { - $width = 180; - } - return $prefix.$this->makeThumbLinkObj( $img, $alt, $align, $width, $height, $framed, $manual_thumb ).$postfix; - - } elseif ( isset($width) ) { + } elseif ( isset($width) ) { - # Create a resized image, without the additional thumbnail - # features + # Create a resized image, without the additional thumbnail + # features - if ( ( ! $height === false ) - && ( $img->getHeight() * $width / $img->getWidth() > $height ) ) { - print "height=$height
\nimg->getHeight() = ".$img->getHeight()."
\n"; - print 'rescaling by factor '. $height / $img->getHeight() . "
\n"; - $width = $img->getWidth() * $height / $img->getHeight(); - } - if ( '' == $manual_thumb ) $url = $img->createThumb( $width ); + if ( ( ! $height === false ) + && ( $img->getHeight() * $width / $img->getWidth() > $height ) ) { + $width = $img->getWidth() * $height / $img->getHeight(); } - } # endif $wgUseImageResize - - if ( empty( $alt ) ) { - $alt = preg_replace( '/\.(.+?)^/', '', $img->getName() ); + if ( '' == $manual_thumb ) $url = $img->createThumb( $width ); } - $alt = htmlspecialchars( $alt ); + + $alt = preg_replace( '/<[^>]*>/', '', $alt ); + $alt = preg_replace('/&(?!:amp;|#[Xx][0-9A-fa-f]+;|#[0-9]+;|[a-zA-Z0-9]+;)/', '&', $alt); + $alt = str_replace( array('<', '>', '"'), array('<', '>', '"'), $alt ); $u = $nt->escapeLocalURL(); - if ( $url == '' ) - { + if ( $url == '' ) { $s = wfMsg( 'missingimage', $img->getName() ); $s .= "
{$alt}
{$url}
\n"; } else { $s = '' . - ''.$alt.''; + ''.$alt.''; } if ( '' != $align ) { $s = "
{$s}
"; @@ -1956,13 +1794,14 @@ class Skin { * $img is an Image object */ function makeThumbLinkObj( $img, $label = '', $align = 'right', $boxwidth = 180, $boxheight=false, $framed=false , $manual_thumb = "" ) { - global $wgStylePath, $wgLang; + global $wgStylePath, $wgContLang; # $image = Title::makeTitleSafe( NS_IMAGE, $name ); - $url = $img->getURL(); + $url = $img->getViewURL(); #$label = htmlspecialchars( $label ); $alt = preg_replace( '/<[^>]*>/', '', $label); - $alt = htmlspecialchars( $alt ); + $alt = preg_replace('/&(?!:amp;|#[Xx][0-9A-fa-f]+;|#[0-9]+;|[a-zA-Z0-9]+;)/', '&', $alt); + $alt = str_replace( array('<', '>', '"'), array('<', '>', '"'), $alt ); $width = $height = 0; if ( $img->exists() ) @@ -2001,7 +1840,7 @@ class Skin { { $manual_title = Title::makeTitleSafe( NS_IMAGE, $manual_thumb ); #new Title ( $manual_thumb ) ; $manual_img = Image::newFromTitle( $manual_title ); - $thumbUrl = $manual_img->getURL(); + $thumbUrl = $manual_img->getViewURL(); if ( $manual_img->exists() ) { $width = $manual_img->getWidth(); @@ -2015,8 +1854,8 @@ class Skin { $u = $img->getEscapeLocalURL(); $more = htmlspecialchars( wfMsg( 'thumbnail-more' ) ); - $magnifyalign = $wgLang->isRTL() ? 'left' : 'right'; - $textalign = $wgLang->isRTL() ? ' style="text-align:right"' : ''; + $magnifyalign = $wgContLang->isRTL() ? 'left' : 'right'; + $textalign = $wgContLang->isRTL() ? ' style="text-align:right"' : ''; $s = "
"; if ( $thumbUrl == '' ) { @@ -2025,7 +1864,8 @@ class Skin { } else { $s .= ''. ''.$alt.''; + 'width="'.$boxwidth.'" height="'.$boxheight.'" ' . + 'longdesc="'.$u.'" />'; if ( $framed ) { $zoomicon=""; } else { @@ -2040,34 +1880,39 @@ class Skin { } function makeMediaLink( $name, $url, $alt = '' ) { - $nt = Title::makeTitleSafe( Namespace::getMedia(), $name ); + $nt = Title::makeTitleSafe( NS_IMAGE, $name ); return $this->makeMediaLinkObj( $nt, $alt ); } - function makeMediaLinkObj( $nt, $alt = '' ) { + function makeMediaLinkObj( $nt, $alt = '', $nourl=false ) { if ( ! isset( $nt ) ) { ### HOTFIX. Instead of breaking, return empty string. $s = $alt; } else { - $name = $nt->getDBKey(); - $url = Image::wfImageUrl( $name ); + $name = $nt->getDBKey(); + $img = Image::newFromTitle( $nt ); + $url = $img->getURL(); + # $nourl can be set by the parser + # this is a hack to mask absolute URLs, so the parser doesn't + # linkify them (it is currently not context-aware) + # 2004-10-25 + if ($nourl) { $url=str_replace("http://","http-noparse://",$url) ; } if ( empty( $alt ) ) { $alt = preg_replace( '/\.(.+?)^/', '', $name ); } - $u = htmlspecialchars( $url ); - $s = "{$alt}"; + $s = "{$alt}"; } return $s; } function specialLink( $name, $key = '' ) { - global $wgLang; + global $wgContLang; if ( '' == $key ) { $key = strtolower( $name ); } - $pn = $wgLang->ucfirst( $name ); - return $this->makeKnownLink( $wgLang->specialPage( $pn ), + $pn = $wgContLang->ucfirst( $name ); + return $this->makeKnownLink( $wgContLang->specialPage( $pn ), wfMsg( $key ) ); } @@ -2080,487 +1925,6 @@ class Skin { return ''.$text.''; } - # Called by history lists and recent changes - # - - # Returns text for the start of the tabular part of RC - function beginRecentChangesList() { - $this->rc_cache = array() ; - $this->rcMoveIndex = 0; - $this->rcCacheIndex = 0 ; - $this->lastdate = ''; - $this->rclistOpen = false; - return ''; - } - - function beginImageHistoryList() { - $s = "\n

" . wfMsg( 'imghistory' ) . "

\n" . - "

" . wfMsg( 'imghistlegend' ) . "

\n".'
    '; - return $s; - } - - /** - * Returns text for the end of RC - * If enhanced RC is in use, returns pretty much all the text - */ - function endRecentChangesList() { - $s = $this->recentChangesBlock() ; - if( $this->rclistOpen ) { - $s .= "
\n"; - } - return $s; - } - - /** - * Enhanced RC ungrouped line - */ - function recentChangesBlockLine ( $rcObj ) { - global $wgStylePath, $wgLang ; - - # Get rc_xxxx variables - extract( $rcObj->mAttribs ) ; - $curIdEq = 'curid='.$rc_cur_id; - - # Spacer image - $r = '' ; - - $r .= '' ; - $r .= '' ; - - if ( $rc_type == RC_MOVE || $rc_type == RC_MOVE_OVER_REDIRECT ) { - $r .= '  '; - } else { - # M & N (minor & new) - $M = wfMsg( 'minoreditletter' ); - $N = wfMsg( 'newpageletter' ); - - if ( $rc_type == RC_NEW ) { - $r .= $N ; - } else { - $r .= ' ' ; - } - if ( $rc_minor ) { - $r .= $M ; - } else { - $r .= ' ' ; - } - } - - # Timestamp - $r .= ' '.$rcObj->timestamp.' ' ; - $r .= '' ; - - # Article link - $link = $rcObj->link ; - if ( $rcObj->watched ) $link = ''.$link.'' ; - $r .= $link ; - - # Diff - $r .= ' (' ; - $r .= $rcObj->difflink ; - $r .= '; ' ; - - # Hist - $r .= $this->makeKnownLinkObj( $rcObj->getTitle(), wfMsg( 'hist' ), $curIdEq.'&action=history' ); - - # User/talk - $r .= ') . . '.$rcObj->userlink ; - $r .= $rcObj->usertalklink ; - - # Comment - if ( $rc_comment != '' && $rc_type != RC_MOVE && $rc_type != RC_MOVE_OVER_REDIRECT ) { - $rc_comment=$this->formatComment($rc_comment, $rcObj->getTitle()); - $r .= $wgLang->emphasize( ' ('.$rc_comment.')' ); - } - - $r .= "
\n" ; - return $r ; - } - - /** - * Enhanced RC group - */ - function recentChangesBlockGroup ( $block ) { - global $wgStylePath, $wgLang ; - - $r = '' ; - $M = wfMsg( 'minoreditletter' ); - $N = wfMsg( 'newpageletter' ); - - # Collate list of users - $isnew = false ; - $userlinks = array () ; - foreach ( $block AS $rcObj ) { - $oldid = $rcObj->mAttribs['rc_last_oldid']; - if ( $rcObj->mAttribs['rc_new'] ) $isnew = true ; - $u = $rcObj->userlink ; - if ( !isset ( $userlinks[$u] ) ) $userlinks[$u] = 0 ; - $userlinks[$u]++ ; - } - - # Sort the list and convert to text - krsort ( $userlinks ) ; - asort ( $userlinks ) ; - $users = array () ; - foreach ( $userlinks as $userlink => $count) { - $text = $userlink ; - if ( $count > 1 ) $text .= " ({$count}×)" ; - array_push ( $users , $text ) ; - } - $users = ' ['.implode('; ',$users).']' ; - - # Arrow - $rci = 'RCI'.$this->rcCacheIndex ; - $rcl = 'RCL'.$this->rcCacheIndex ; - $rcm = 'RCM'.$this->rcCacheIndex ; - $toggleLink = "javascript:toggleVisibility('$rci','$rcm','$rcl')" ; - $arrowdir = $wgLang->isRTL() ? 'l' : 'r'; - $tl = '' ; - $tl .= '' ; - $r .= $tl ; - - # Main line - # M/N - $r .= '' ; - if ( $isnew ) $r .= $N ; - else $r .= ' ' ; - $r .= ' ' ; # Minor - - # Timestamp - $r .= ' '.$block[0]->timestamp.' ' ; - $r .= '' ; - - # Article link - $link = $block[0]->link ; - if ( $block[0]->watched ) $link = ''.$link.'' ; - $r .= $link ; - - $curIdEq = 'curid=' . $block[0]->mAttribs['rc_cur_id']; - if ( $block[0]->mAttribs['rc_type'] != RC_LOG ) { - # Changes - $r .= ' ('.count($block).' ' ; - if ( $isnew ) $r .= wfMsg('changes'); - else $r .= $this->makeKnownLinkObj( $block[0]->getTitle() , wfMsg('changes') , - $curIdEq.'&diff=0&oldid='.$oldid ) ; - $r .= '; ' ; - - # History - $r .= $this->makeKnownLinkObj( $block[0]->getTitle(), wfMsg( 'history' ), $curIdEq.'&action=history' ); - $r .= ')' ; - } - - $r .= $users ; - $r .= "
\n" ; - - # Sub-entries - $r .= '\n" ; - - $this->rcCacheIndex++ ; - return $r ; - } - - /** - * If enhanced RC is in use, this function takes the previously cached - * RC lines, arranges them, and outputs the HTML - */ - function recentChangesBlock () { - global $wgStylePath ; - if ( count ( $this->rc_cache ) == 0 ) return '' ; - $blockOut = ''; - foreach ( $this->rc_cache AS $secureName => $block ) { - if ( count ( $block ) < 2 ) { - $blockOut .= $this->recentChangesBlockLine ( array_shift ( $block ) ) ; - } else { - $blockOut .= $this->recentChangesBlockGroup ( $block ) ; - } - } - - return '
'.$blockOut.'
' ; - } - - /** - * Called in a loop over all displayed RC entries - * Either returns the line, or caches it for later use - */ - function recentChangesLine( &$rc, $watched = false ) { - global $wgUser ; - $usenew = $wgUser->getOption( 'usenewrc' ); - if ( $usenew ) - $line = $this->recentChangesLineNew ( $rc, $watched ) ; - else - $line = $this->recentChangesLineOld ( $rc, $watched ) ; - return $line ; - } - - function recentChangesLineOld( &$rc, $watched = false ) { - global $wgTitle, $wgLang, $wgUser, $wgRCSeconds, $wgUseRCPatrol, $wgOnlySysopsCanPatrol; - - # Extract DB fields into local scope - extract( $rc->mAttribs ); - $curIdEq = 'curid=' . $rc_cur_id; - - # Make date header if necessary - $date = $wgLang->date( $rc_timestamp, true); - $s = ''; - if ( $date != $this->lastdate ) { - if ( '' != $this->lastdate ) { $s .= "\n"; } - $s .= "

{$date}

\n
    "; - $this->lastdate = $date; - $this->rclistOpen = true; - } - - # If this edit has not yet been patrolled, make it stick out - $s .= ( ! $wgUseRCPatrol || $rc_patrolled ) ? '
  • ' : '
  • '; - - if ( $rc_type == RC_MOVE || $rc_type == RC_MOVE_OVER_REDIRECT ) { - # Diff - $s .= '(' . wfMsg( 'diff' ) . ') ('; - # Hist - $s .= $this->makeKnownLinkObj( $rc->getMovedToTitle(), wfMsg( 'hist' ), 'action=history' ) . - ') . . '; - - # "[[x]] moved to [[y]]" - $msg = ( $rc_type == RC_MOVE ) ? '1movedto2' : '1movedto2_redir'; - $s .= wfMsg( $msg, $this->makeKnownLinkObj( $rc->getTitle(), '', 'redirect=no' ), - $this->makeKnownLinkObj( $rc->getMovedToTitle(), '' ) ); - } elseif( $rc_namespace == NS_SPECIAL && preg_match( '!^Log/(.*)$!', $rc_title, $matches ) ) { - # Log updates, etc - $logtype = $matches[1]; - $logname = LogPage::logName( $logtype ); - $s .= '(' . $this->makeKnownLinkObj( $rc->getTitle(), $logname ) . ')'; - } else { - # Diff link - if ( $rc_type == RC_NEW || $rc_type == RC_LOG ) { - $diffLink = wfMsg( 'diff' ); - } else { - if ( $wgUseRCPatrol && $rc_patrolled == 0 && $wgUser->getID() != 0 && - ( $wgUser->isSysop() || !$wgOnlySysopsCanPatrol ) ) - $rcidparam = "&rcid={$rc_id}"; - else - $rcidparam = ""; - $diffLink = $this->makeKnownLinkObj( $rc->getTitle(), wfMsg( 'diff' ), - "{$curIdEq}&diff={$rc_this_oldid}&oldid={$rc_last_oldid}{$rcidparam}", - '', '', ' tabindex="'.$rc->counter.'"'); - } - $s .= '('.$diffLink.') ('; - - # History link - $s .= $this->makeKnownLinkObj( $rc->getTitle(), wfMsg( 'hist' ), $curIdEq.'&action=history' ); - $s .= ') . . '; - - # M and N (minor and new) - if ( $rc_minor ) { $s .= ' '.wfMsg( "minoreditletter" ).''; } - if ( $rc_type == RC_NEW ) { $s .= ''.wfMsg( "newpageletter" ).''; } - - # Article link - # If it's a new article, there is no diff link, but if it hasn't been - # patrolled yet, we need to give users a way to do so - if ( $wgUseRCPatrol && $rc_type == RC_NEW && $rc_patrolled == 0 && - $wgUser->getID() != 0 && ( $wgUser->isSysop() || !$wgOnlySysopsCanPatrol ) ) - $articleLink = $this->makeKnownLinkObj( $rc->getTitle(), '', "rcid={$rc_id}" ); - else - $articleLink = $this->makeKnownLinkObj( $rc->getTitle(), '' ); - - if ( $watched ) { - $articleLink = ''.$articleLink.''; - } - $s .= ' '.$articleLink; - - } - - # Timestamp - $s .= '; ' . $wgLang->time( $rc_timestamp, true, $wgRCSeconds ) . ' . . '; - - # User link (or contributions for unregistered users) - if ( 0 == $rc_user ) { - $userLink = $this->makeKnownLink( $wgLang->specialPage( 'Contributions' ), - $rc_user_text, 'target=' . $rc_user_text ); - } else { - $userLink = $this->makeLink( $wgLang->getNsText( NS_USER ) . ':'.$rc_user_text, $rc_user_text ); - } - $s .= $userLink; - - # User talk link - $talkname=$wgLang->getNsText(NS_TALK); # use the shorter name - global $wgDisableAnonTalk; - if( 0 == $rc_user && $wgDisableAnonTalk ) { - $userTalkLink = ''; - } else { - $utns=$wgLang->getNsText(NS_USER_TALK); - $userTalkLink= $this->makeLink($utns . ':'.$rc_user_text, $talkname ); - } - # Block link - $blockLink=''; - if ( ( 0 == $rc_user ) && $wgUser->isSysop() ) { - $blockLink = $this->makeKnownLink( $wgLang->specialPage( - 'Blockip' ), wfMsg( 'blocklink' ), 'ip='.$rc_user_text ); - - } - if($blockLink) { - if($userTalkLink) $userTalkLink .= ' | '; - $userTalkLink .= $blockLink; - } - if($userTalkLink) $s.=' ('.$userTalkLink.')'; - - # Add comment - if ( '' != $rc_comment && '*' != $rc_comment && $rc_type != RC_MOVE && $rc_type != RC_MOVE_OVER_REDIRECT ) { - $rc_comment=$this->formatComment($rc_comment,$rc->getTitle()); - $s .= $wgLang->emphasize(' (' . $rc_comment . ')'); - } - $s .= "
  • \n"; - - return $s; - } - - function recentChangesLineNew( &$baseRC, $watched = false ) { - global $wgTitle, $wgLang, $wgUser, $wgRCSeconds; - - # Create a specialised object - $rc = RCCacheEntry::newFromParent( $baseRC ) ; - - # Extract fields from DB into the function scope (rc_xxxx variables) - extract( $rc->mAttribs ); - $curIdEq = 'curid=' . $rc_cur_id; - - # If it's a new day, add the headline and flush the cache - $date = $wgLang->date( $rc_timestamp, true); - $ret = ''; - if ( $date != $this->lastdate ) { - # Process current cache - $ret = $this->recentChangesBlock () ; - $this->rc_cache = array() ; - $ret .= "

    {$date}

    \n"; - $this->lastdate = $date; - } - - # Make article link - if ( $rc_type == RC_MOVE || $rc_type == RC_MOVE_OVER_REDIRECT ) { - $msg = ( $rc_type == RC_MOVE ) ? "1movedto2" : "1movedto2_redir"; - $clink = wfMsg( $msg, $this->makeKnownLinkObj( $rc->getTitle(), '', 'redirect=no' ), - $this->makeKnownLinkObj( $rc->getMovedToTitle(), '' ) ); - } elseif( $rc_namespace == NS_SPECIAL && preg_match( '!^Log/(.*)$!', $rc_title, $matches ) ) { - # Log updates, etc - $logtype = $matches[1]; - $logname = LogPage::logName( $logtype ); - $clink = '(' . $this->makeKnownLinkObj( $rc->getTitle(), $logname ) . ')'; - } else { - $clink = $this->makeKnownLinkObj( $rc->getTitle(), '' ) ; - } - - $time = $wgLang->time( $rc_timestamp, true, $wgRCSeconds ); - $rc->watched = $watched ; - $rc->link = $clink ; - $rc->timestamp = $time; - - # Make "cur" and "diff" links - if ( ( $rc_type == RC_NEW && $rc_this_oldid == 0 ) || $rc_type == RC_LOG || $rc_type == RC_MOVE || $rc_type == RC_MOVE_OVER_REDIRECT ) { - $curLink = wfMsg( 'cur' ); - $diffLink = wfMsg( 'diff' ); - } else { - $query = $curIdEq.'&diff=0&oldid='.$rc_this_oldid; - $aprops = ' tabindex="'.$baseRC->counter.'"'; - $curLink = $this->makeKnownLinkObj( $rc->getTitle(), wfMsg( 'cur' ), $query, '' ,'' , $aprops ); - $diffLink = $this->makeKnownLinkObj( $rc->getTitle(), wfMsg( 'diff'), $query, '' ,'' , $aprops ); - } - - # Make "last" link - $titleObj = $rc->getTitle(); - if ( $rc_last_oldid == 0 || $rc_type == RC_LOG || $rc_type == RC_MOVE || $rc_type == RC_MOVE_OVER_REDIRECT ) { - $lastLink = wfMsg( 'last' ); - } else { - $lastLink = $this->makeKnownLinkObj( $rc->getTitle(), wfMsg( 'last' ), - $curIdEq.'&diff='.$rc_this_oldid.'&oldid='.$rc_last_oldid ); - } - - # Make user link (or user contributions for unregistered users) - if ( $rc_user == 0 ) { - $userLink = $this->makeKnownLink( $wgLang->specialPage( 'Contributions' ), - $rc_user_text, 'target=' . $rc_user_text ); - } else { - $userLink = $this->makeLink( $wgLang->getNsText( - Namespace::getUser() ) . ':'.$rc_user_text, $rc_user_text ); - } - - $rc->userlink = $userLink; - $rc->lastlink = $lastLink; - $rc->curlink = $curLink; - $rc->difflink = $diffLink; - - # Make user talk link - $utns=$wgLang->getNsText(NS_USER_TALK); - $talkname=$wgLang->getNsText(NS_TALK); # use the shorter name - $userTalkLink= $this->makeLink($utns . ':'.$rc_user_text, $talkname ); - - global $wgDisableAnonTalk; - if ( ( 0 == $rc_user ) && $wgUser->isSysop() ) { - $blockLink = $this->makeKnownLink( $wgLang->specialPage( - 'Blockip' ), wfMsg( 'blocklink' ), 'ip='.$rc_user_text ); - if( $wgDisableAnonTalk ) - $rc->usertalklink = ' ('.$blockLink.')'; - else - $rc->usertalklink = ' ('.$userTalkLink.' | '.$blockLink.')'; - } else { - if( $wgDisableAnonTalk && ($rc_user == 0) ) - $rc->usertalklink = ''; - else - $rc->usertalklink = ' ('.$userTalkLink.')'; - } - - # Put accumulated information into the cache, for later display - # Page moves go on their own line - $title = $rc->getTitle(); - $secureName = $title->getPrefixedDBkey(); - if ( $rc_type == RC_MOVE || $rc_type == RC_MOVE_OVER_REDIRECT ) { - # Use an @ character to prevent collision with page names - $this->rc_cache['@@' . ($this->rcMoveIndex++)] = array($rc); - } else { - if ( !isset ( $this->rc_cache[$secureName] ) ) $this->rc_cache[$secureName] = array() ; - array_push ( $this->rc_cache[$secureName] , $rc ) ; - } - return $ret; - } - - function endImageHistoryList() { - $s = "
\n"; - return $s; - } /** * This function is called by all recent changes variants, by the page history, @@ -2577,7 +1941,10 @@ class Skin { * temporarily to a value pass. Should be adjusted further. --brion */ function formatComment($comment, $title = NULL) { - global $wgLang; + $fname = 'Skin::formatComment'; + wfProfileIn( $fname ); + + global $wgContLang; $comment = htmlspecialchars( $comment ); # The pattern for autogen comments is / * foo * /, which makes for @@ -2608,7 +1975,7 @@ class Skin { # format regular and media links - all other wiki formatting # is ignored - $medians = $wgLang->getNsText(Namespace::getMedia()).':'; + $medians = $wgContLang->getNsText(Namespace::getMedia()).':'; while(preg_match('/\[\[(.*?)(\|(.*?))*\]\](.*)$/',$comment,$match)) { # Handle link renaming [[foo|text]] will show link as "text" if( "" != $match[3] ) { @@ -2622,7 +1989,7 @@ class Skin { $thelink = $this->makeMediaLink( $submatch[1], "", $text ); } else { # Other kind of link - if( preg_match( wfMsg( "linktrail" ), $match[4], $submatch ) ) { + if( preg_match( wfMsgForContent( "linktrail" ), $match[4], $submatch ) ) { $trail = $submatch[1]; } else { $trail = ""; @@ -2634,65 +2001,10 @@ class Skin { } $comment = preg_replace( $linkRegexp, $thelink, $comment, 1 ); } + wfProfileOut( $fname ); return $comment; } - - function imageHistoryLine( $iscur, $timestamp, $img, $user, $usertext, $size, $description ) { - global $wgUser, $wgLang, $wgTitle; - - $datetime = $wgLang->timeanddate( $timestamp, true ); - $del = wfMsg( 'deleteimg' ); - $delall = wfMsg( 'deleteimgcompletely' ); - $cur = wfMsg( 'cur' ); - - if ( $iscur ) { - $url = Image::wfImageUrl( $img ); - $rlink = $cur; - if ( $wgUser->isSysop() ) { - $link = $wgTitle->escapeLocalURL( 'image=' . $wgTitle->getPartialURL() . - '&action=delete' ); - $style = $this->getInternalLinkAttributes( $link, $delall ); - - $dlink = ''.$delall.''; - } else { - $dlink = $del; - } - } else { - $url = htmlspecialchars( wfImageArchiveUrl( $img ) ); - if( $wgUser->getID() != 0 && $wgTitle->userCanEdit() ) { - $rlink = $this->makeKnownLink( $wgTitle->getPrefixedText(), - wfMsg( 'revertimg' ), 'action=revert&oldimage=' . - urlencode( $img ) ); - $dlink = $this->makeKnownLink( $wgTitle->getPrefixedText(), - $del, 'action=delete&oldimage=' . urlencode( $img ) ); - } else { - # Having live active links for non-logged in users - # means that bots and spiders crawling our site can - # inadvertently change content. Baaaad idea. - $rlink = wfMsg( 'revertimg' ); - $dlink = $del; - } - } - if ( 0 == $user ) { - $userlink = $usertext; - } else { - $userlink = $this->makeLink( $wgLang->getNsText( Namespace::getUser() ) . - ':'.$usertext, $usertext ); - } - $nbytes = wfMsg( 'nbytes', $size ); - $style = $this->getInternalLinkAttributes( $url, $datetime ); - - $s = "
  • ({$dlink}) ({$rlink}) {$datetime}" - . " . . {$userlink} ({$nbytes})"; - - if ( '' != $description && '*' != $description ) { - $sk=$wgUser->getSkin(); - $s .= $wgLang->emphasize(' (' . $sk->formatComment($description,$wgTitle) . ')'); - } - $s .= "
  • \n"; - return $s; - } - + function tocIndent($level) { return str_repeat( '
    '."\n", $level>0 ? $level : 0 ); } @@ -2720,7 +2032,7 @@ class Skin { $hideline = ' '; return '
    '."\n". - ''.wfMsg('toc').'' . + ''.wfMsgForContent('toc').'' . $hideline . '
    '."\n". $toc."
    \n"; @@ -2736,24 +2048,24 @@ class Skin { return ''.$head.''; } - function editSectionScript( $section, $head ) { - global $wgTitle, $wgRequest; + function editSectionScript( $nt, $section, $head ) { + global $wgRequest; if( $wgRequest->getInt( 'oldid' ) && ( $wgRequest->getVal( 'diff' ) != '0' ) ) { return $head; } - $url = $wgTitle->escapeLocalURL( 'action=edit§ion='.$section ); + $url = $nt->escapeLocalURL( 'action=edit§ion='.$section ); return ''.$head.''; } function editSectionLinkForOther( $title, $section ) { global $wgRequest; - global $wgUser, $wgLang; + global $wgContLang; $title = Title::newFromText($title); $editurl = '§ion='.$section; $url = $this->makeKnownLink($title->getPrefixedText(),wfMsg('editsection'),'action=edit'.$editurl); - if( $wgLang->isRTL() ) { + if( $wgContLang->isRTL() ) { $farside = 'left'; $nearside = 'right'; } else { @@ -2764,9 +2076,9 @@ class Skin { } - function editSectionLink( $section ) { + function editSectionLink( $nt, $section ) { global $wgRequest; - global $wgTitle, $wgUser, $wgLang; + global $wgContLang; if( $wgRequest->getInt( 'oldid' ) && ( $wgRequest->getVal( 'diff' ) != '0' ) ) { # Section edit links would be out of sync on an old page. @@ -2776,9 +2088,9 @@ class Skin { } $editurl = '§ion='.$section; - $url = $this->makeKnownLink($wgTitle->getPrefixedText(),wfMsg('editsection'),'action=edit'.$editurl); + $url = $this->makeKnownLink($nt->getPrefixedText(),wfMsg('editsection'),'action=edit'.$editurl); - if( $wgLang->isRTL() ) { + if( $wgContLang->isRTL() ) { $farside = 'left'; $nearside = 'right'; } else { @@ -2789,133 +2101,6 @@ class Skin { } - /** - * This function is called by EditPage.php and shows a bulletin board style - * toolbar for common editing functions. It can be disabled in the user - * preferences. - * The necessary JavaScript code can be found in style/wikibits.js. - */ - function getEditToolbar() { - global $wgStylePath, $wgLang, $wgMimeType; - - /** - * toolarray an array of arrays which each include the filename of - * the button image (without path), the opening tag, the closing tag, - * and optionally a sample text that is inserted between the two when no - * selection is highlighted. - * The tip text is shown when the user moves the mouse over the button. - * - * Already here are accesskeys (key), which are not used yet until someone - * can figure out a way to make them work in IE. However, we should make - * sure these keys are not defined on the edit page. - */ - $toolarray=array( - array( 'image'=>'button_bold.png', - 'open' => "\'\'\'", - 'close' => "\'\'\'", - 'sample'=> wfMsg('bold_sample'), - 'tip' => wfMsg('bold_tip'), - 'key' => 'B' - ), - array( 'image'=>'button_italic.png', - 'open' => "\'\'", - 'close' => "\'\'", - 'sample'=> wfMsg('italic_sample'), - 'tip' => wfMsg('italic_tip'), - 'key' => 'I' - ), - array( 'image'=>'button_link.png', - 'open' => '[[', - 'close' => ']]', - 'sample'=> wfMsg('link_sample'), - 'tip' => wfMsg('link_tip'), - 'key' => 'L' - ), - array( 'image'=>'button_extlink.png', - 'open' => '[', - 'close' => ']', - 'sample'=> wfMsg('extlink_sample'), - 'tip' => wfMsg('extlink_tip'), - 'key' => 'X' - ), - array( 'image'=>'button_headline.png', - 'open' => "\\n== ", - 'close' => " ==\\n", - 'sample'=> wfMsg('headline_sample'), - 'tip' => wfMsg('headline_tip'), - 'key' => 'H' - ), - array( 'image'=>'button_image.png', - 'open' => '[['.$wgLang->getNsText(NS_IMAGE).":", - 'close' => ']]', - 'sample'=> wfMsg('image_sample'), - 'tip' => wfMsg('image_tip'), - 'key' => 'D' - ), - array( 'image' => 'button_media.png', - 'open' => '[['.$wgLang->getNsText(NS_MEDIA).':', - 'close' => ']]', - 'sample'=> wfMsg('media_sample'), - 'tip' => wfMsg('media_tip'), - 'key' => 'M' - ), - array( 'image' => 'button_math.png', - 'open' => "\\", - 'close' => "\\", - 'sample'=> wfMsg('math_sample'), - 'tip' => wfMsg('math_tip'), - 'key' => 'C' - ), - array( 'image' => 'button_nowiki.png', - 'open' => "\\", - 'close' => "\\", - 'sample'=> wfMsg('nowiki_sample'), - 'tip' => wfMsg('nowiki_tip'), - 'key' => 'N' - ), - array( 'image' => 'button_sig.png', - 'open' => '--~~~~', - 'close' => '', - 'sample'=> '', - 'tip' => wfMsg('sig_tip'), - 'key' => 'Y' - ), - array( 'image' => 'button_hr.png', - 'open' => "\\n----\\n", - 'close' => '', - 'sample'=> '', - 'tip' => wfMsg('hr_tip'), - 'key' => 'R' - ) - ); - $toolbar =""; - return $toolbar; - } - /** * @access public */