diff options
Diffstat (limited to 'skins/disabled')
-rw-r--r-- | skins/disabled/HTMLDump.php | 228 | ||||
-rw-r--r-- | skins/disabled/MonoBook.tpl | 200 | ||||
-rw-r--r-- | skins/disabled/MonoBookCBT.php | 1390 |
3 files changed, 1818 insertions, 0 deletions
diff --git a/skins/disabled/HTMLDump.php b/skins/disabled/HTMLDump.php new file mode 100644 index 00000000..20ec01e3 --- /dev/null +++ b/skins/disabled/HTMLDump.php @@ -0,0 +1,228 @@ +<?php + +/** + * Default skin for HTML dumps, based on MonoBook.php + */ + +if( !defined( 'MEDIAWIKI' ) ) + die( -1 ); + +/** */ +require_once( 'includes/SkinTemplate.php' ); + +/** + * Inherit main code from SkinTemplate, set the CSS and template filter. + * @todo document + * @package MediaWiki + * @subpackage Skins + */ +class SkinHTMLDump extends SkinTemplate { + /** Using monobook. */ + function initPage( &$out ) { + SkinTemplate::initPage( $out ); + $this->template = 'HTMLDumpTemplate'; + } + + function buildSidebar() { + $sections = parent::buildSidebar(); + $badMessages = array( 'recentchanges-url', 'randompage-url' ); + $badUrls = array(); + foreach ( $badMessages as $msg ) { + $badUrls[] = $this->makeInternalOrExternalUrl( wfMsgForContent( $msg ) ); + } + + foreach ( $sections as $heading => $section ) { + foreach ( $section as $index => $link ) { + if ( in_array( $link['href'], $badUrls ) ) { + unset( $sections[$heading][$index] ); + } + } + } + return $sections; + } + + function buildContentActionUrls() { + global $wgHTMLDump; + + $content_actions = array(); + $nskey = $this->getNameSpaceKey(); + $content_actions[$nskey] = $this->tabAction( + $this->mTitle->getSubjectPage(), + $nskey, + !$this->mTitle->isTalkPage() ); + + $content_actions['talk'] = $this->tabAction( + $this->mTitle->getTalkPage(), + 'talk', + $this->mTitle->isTalkPage(), + '', + true); + + if ( isset( $wgHTMLDump ) ) { + $content_actions['current'] = array( + 'text' => wfMsg( 'currentrev' ), + 'href' => str_replace( '$1', wfUrlencode( $this->mTitle->getPrefixedDBkey() ), + $wgHTMLDump->oldArticlePath ), + 'class' => false + ); + } + return $content_actions; + } + + function makeBrokenLinkObj( &$nt, $text = '', $query = '', $trail = '', $prefix = '' ) { + if ( !isset( $nt ) ) { + return "<!-- ERROR -->{$prefix}{$text}{$trail}"; + } + + if ( $nt->getNamespace() == NS_CATEGORY ) { + return $this->makeKnownLinkObj( $nt, $text, $query, $trail, $prefix ); + } + + if ( $text == '' ) { + $text = $nt->getPrefixedText(); + } + return $prefix . $text . $trail; + } +} + +/** + * @todo document + * @package MediaWiki + * @subpackage Skins + */ +class HTMLDumpTemplate extends QuickTemplate { + /** + * Template filter callback for MonoBook skin. + * Takes an associative array of data set from a SkinTemplate-based + * class, and a wrapper for MediaWiki's localization database, and + * outputs a formatted page. + * + * @access private + */ + function execute() { + wfSuppressWarnings(); +?><!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="<?php $this->text('lang') ?>" lang="<?php $this->text('lang') ?>" dir="<?php $this->text('dir') ?>"> + <head> + <meta http-equiv="Content-Type" content="<?php $this->text('mimetype') ?>; charset=<?php $this->text('charset') ?>" /> + <?php $this->html('headlinks') ?> + <title><?php $this->text('pagetitle') ?></title> + <style type="text/css">/*<![CDATA[*/ @import "<?php $this->text('stylepath') ?>/htmldump/main.css"; /*]]>*/</style> + <link rel="stylesheet" type="text/css" media="print" href="<?php $this->text('stylepath') ?>/common/commonPrint.css" /> + <!--[if lt IE 5.5000]><style type="text/css">@import "<?php $this->text('stylepath') ?>/<?php $this->text('stylename') ?>/IE50Fixes.css";</style><![endif]--> + <!--[if IE 5.5000]><style type="text/css">@import "<?php $this->text('stylepath') ?>/<?php $this->text('stylename') ?>/IE55Fixes.css";</style><![endif]--> + <!--[if IE 6]><style type="text/css">@import "<?php $this->text('stylepath') ?>/<?php $this->text('stylename') ?>/IE60Fixes.css";</style><![endif]--> + <!--[if IE]><script type="<?php $this->text('jsmimetype') ?>" src="<?php $this->text('stylepath') ?>/common/IEFixes.js"></script> + <meta http-equiv="imagetoolbar" content="no" /><![endif]--> + <script type="<?php $this->text('jsmimetype') ?>" src="<?php $this->text('stylepath' ) ?>/common/wikibits.js"></script> + <script type="<?php $this->text('jsmimetype') ?>" src="<?php $this->text('stylepath' ) ?>/htmldump/md5.js"></script> + <script type="<?php $this->text('jsmimetype') ?>" src="<?php $this->text('stylepath' ) ?>/htmldump/utf8.js"></script> + <script type="<?php $this->text('jsmimetype') ?>" src="<?php $this->text('stylepath' ) ?>/htmldump/lookup.js"></script> + <?php if($this->data['jsvarurl' ]) { ?><script type="<?php $this->text('jsmimetype') ?>" src="<?php $this->text('jsvarurl' ) ?>"></script><?php } ?> + <?php if($this->data['pagecss' ]) { ?><style type="text/css"><?php $this->html('pagecss' ) ?></style><?php } ?> + <?php if($this->data['usercss' ]) { ?><style type="text/css"><?php $this->html('usercss' ) ?></style><?php } ?> + <?php if($this->data['userjs' ]) { ?><script type="<?php $this->text('jsmimetype') ?>" src="<?php $this->text('userjs' ) ?>"></script><?php } ?> + <?php if($this->data['userjsprev']) { ?><script type="<?php $this->text('jsmimetype') ?>"><?php $this->html('userjsprev') ?></script><?php } ?> + </head> + <body + <?php if($this->data['nsclass' ]) { ?>class="<?php $this->text('nsclass') ?>"<?php } ?>> + <div id="globalWrapper"> + <div id="column-content"> + <div id="content"> + <a name="top" id="contentTop"></a> + <?php if($this->data['sitenotice']) { ?><div id="siteNotice"><?php $this->html('sitenotice') ?></div><?php } ?> + <h1 class="firstHeading"><?php $this->text('title') ?></h1> + <div id="bodyContent"> + <h3 id="siteSub"><?php $this->msg('tagline') ?></h3> + <div id="contentSub"><?php $this->html('subtitle') ?></div> + <?php if($this->data['undelete']) { ?><div id="contentSub"><?php $this->html('undelete') ?></div><?php } ?> + <?php if($this->data['newtalk'] ) { ?><div class="usermessage"><?php $this->html('newtalk') ?></div><?php } ?> + <!-- start content --> + <?php $this->html('bodytext') ?> + <?php if($this->data['catlinks']) { ?><div id="catlinks"><?php $this->html('catlinks') ?></div><?php } ?> + <!-- end content --> + <div class="visualClear"></div> + </div> + </div> + </div> + <div id="column-one"> + <div id="p-cactions" class="portlet"> + <h5>Views</h5> + <ul> + <?php foreach($this->data['content_actions'] as $key => $action) { + ?><li id="ca-<?php echo htmlspecialchars($key) ?>" + <?php if($action['class']) { ?>class="<?php echo htmlspecialchars($action['class']) ?>"<?php } ?> + ><a href="<?php echo htmlspecialchars($action['href']) ?>"><?php + echo htmlspecialchars($action['text']) ?></a></li><?php + } ?> + </ul> + </div> + <div class="portlet" id="p-logo"> + <a style="background-image: url(<?php $this->text('logopath') ?>);" + href="<?php echo htmlspecialchars($this->data['nav_urls']['mainpage']['href'])?>" + title="<?php $this->msg('mainpage') ?>"></a> + </div> + <script type="<?php $this->text('jsmimetype') ?>"> if (window.isMSIE55) fixalpha(); </script> + <?php foreach ($this->data['sidebar'] as $bar => $cont) { ?> + <div class='portlet' id='p-<?php echo htmlspecialchars($bar) ?>'> + <h5><?php $this->msg( $bar ) ?></h5> + <div class='pBody'> + <ul> + <?php foreach($cont as $key => $val) { ?> + <li id="<?php echo htmlspecialchars($val['id']) ?>"><a href="<?php echo htmlspecialchars($val['href']) ?>"><?php echo htmlspecialchars($val['text'])?></a></li> + <?php } ?> + </ul> + </div> + </div> + <?php } ?> + <div id="p-search" class="portlet"> + <h5><label for="searchInput"><?php $this->msg('search') ?></label></h5> + <div class="pBody"> + <form action="javascript:goToStatic(3)" id="searchform"><div> + <input id="searchInput" name="search" type="text" + <?php if($this->haveMsg('accesskey-search')) { + ?>accesskey="<?php $this->msg('accesskey-search') ?>"<?php } + if( isset( $this->data['search'] ) ) { + ?> value="<?php $this->text('search') ?>"<?php } ?> /> + <input type='submit' name="go" class="searchButton" id="searchGoButton" + value="<?php $this->msg('go') ?>" /> + </div></form> + </div> + </div> + <?php if( $this->data['language_urls'] ) { ?><div id="p-lang" class="portlet"> + <h5><?php $this->msg('otherlanguages') ?></h5> + <div class="pBody"> + <ul> + <?php foreach($this->data['language_urls'] as $langlink) { ?> + <li> + <a href="<?php echo htmlspecialchars($langlink['href']) + ?>"><?php echo $langlink['text'] ?></a> + </li> + <?php } ?> + </ul> + </div> + </div> + <?php } ?> + </div><!-- end of the left (by default at least) column --> + <div class="visualClear"></div> + <div id="footer"> + <?php if($this->data['poweredbyico']) { ?><div id="f-poweredbyico"><?php $this->html('poweredbyico') ?></div><?php } ?> + <?php if($this->data['copyrightico']) { ?><div id="f-copyrightico"><?php $this->html('copyrightico') ?></div><?php } ?> + <ul id="f-list"> + <?php if($this->data['lastmod' ]) { ?><li id="f-lastmod"><?php $this->html('lastmod') ?></li><?php } ?> + <?php if($this->data['numberofwatchingusers' ]) { ?><li id="f-numberofwatchingusers"><?php $this->html('numberofwatchingusers') ?></li><?php } ?> + <?php if($this->data['credits' ]) { ?><li id="f-credits"><?php $this->html('credits') ?></li><?php } ?> + <?php if($this->data['copyright' ]) { ?><li id="f-copyright"><?php $this->html('copyright') ?></li><?php } ?> + <?php if($this->data['about' ]) { ?><li id="f-about"><?php $this->html('about') ?></li><?php } ?> + <?php if($this->data['disclaimer']) { ?><li id="f-disclaimer"><?php $this->html('disclaimer') ?></li><?php } ?> + <?php if($this->data['tagline']) { ?><li id="f-tagline"><?php echo $this->data['tagline'] ?></li><?php } ?> + </ul> + </div> + </div> + </body> +</html> +<?php + wfRestoreWarnings(); + } +} +?> diff --git a/skins/disabled/MonoBook.tpl b/skins/disabled/MonoBook.tpl new file mode 100644 index 00000000..a5a259c8 --- /dev/null +++ b/skins/disabled/MonoBook.tpl @@ -0,0 +1,200 @@ +<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> +<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="{lang}" lang="{lang}" dir="{dir}"> +<head> + <meta http-equiv="Content-Type" content="{~ mimetype}; charset={~ charset}" /> + {headlinks} + {headscripts} + <title>{pagetitle}</title> + <style type="text/css" media="screen,projection">/*<![CDATA[*/ @import "{~ stylepath}/{~ stylename}/main.css?5"; /*]]>*/</style> + <link rel="stylesheet" type="text/css" {if notprintable {media="print"}} href="{~ stylepath}/common/commonPrint.css" /> + <!--[if lt IE 5.5000]><style type="text/css">@import "{~ stylepath}/{~ stylename}/IE50Fixes.css";</style><![endif]--> + <!--[if IE 5.5000]><style type="text/css">@import "{~ stylepath}/{~ stylename}/IE55Fixes.css";</style><![endif]--> + <!--[if IE 6]><style type="text/css">@import "{~ stylepath}/{~ stylename}/IE60Fixes.css";</style><![endif]--> + <!--[if IE 7]><style type="text/css">@import "{~ stylepath}/{~ stylename}/IE70Fixes.css?1";</style><![endif]--> + <!--[if lt IE 7]><script type="{jsmimetype}" src="{~ stylepath}/common/IEFixes.js"></script> + <meta http-equiv="imagetoolbar" content="no" /><![endif]--> + <script type="{jsmimetype}">var skin = '{~ skinname}';var stylepath = '{~ stylepath}';</script> + <script type="{jsmimetype}" src="{~ stylepath}/common/wikibits.js"><!-- wikibits js --></script> + {if jsvarurl {<script type="{jsmimetype}" src="{jsvarurl}"><!-- site js --></script>}} + {if pagecss {<style type="text/css">{pagecss}</style>}} + {usercss} + {sitecss} + {gencss} + {if userjs {<script type="{jsmimetype}" src="{userjs}"></script>}} + {if userjsprev {<script type="{jsmimetype}">{userjsprev}</script>}} + {trackbackhtml} +</head> +<body {if body_ondblclick {ondblclick="{body_ondblclick}"}} {if body_onload {onload="{body_onload}" }} class="{~ nsclass} {~ dir}"> +<div id="globalWrapper"> + <div id="column-content"> + <div id="content"> + <a name="top" id="top"></a> + {if sitenotice {<div id="siteNotice">{sitenotice}</div> }} + <h1 class="firstHeading">{title}</h1> + <div id="bodyContent"> + <h3 id="siteSub">{msg {tagline}}</h3> + <div id="contentSub">{subtitle}</div> + {if undelete {<div id="contentSub2"><span class="subpages">{undelete}</span></div> }} + {if newtalk {<div class="usermessage">{newtalk}</div> }} + {if showjumplinks { + <div id="jump-to-nav">{msg {jumpto}} <a href="#column-one">{msg {jumptonavigation}}</a>, + <a href="#searchInput">{msg {jumptosearch}}</a></div> + }} + <!-- start content --> + {bodytext} + {if catlinks {<div id="catlinks">{catlinks}</div> }} + <!-- end content --> + <div class="visualClear"></div> + </div> + </div> + </div> + <div id="column-one"> + <div id="p-cactions" class="portlet"> + <h5>{msg {views}}</h5> + <ul> + {if is_special { + <li id="ca-article" class="selected"><a href="{request_url}">{msg {specialpage}}</a></li> + } { + <li id="ca-{nskey}" {selecttab {subject} subject_newclass}><a href="{subject_url}">{msg nskey}</a></li> + <li id="ca-talk" {selecttab {talk} talk_newclass}><a href="{talk_url}">{msg {talk}}</a></li> + {if can_edit { + {if is_talk { + <li id="ca-edit" {selecttab {edit} {istalk}}><a href="{edit_url}">{msg {edit}}</a></li> + <li id="ca-addsection" {selecttab {addsection}}><a href="{localurl {action=edit§ion=new}}">{msg {addsection}}</a></li> + } { + <li id="ca-edit" {selecttab {edit}}><a href="{edit_url}">{msg {edit}}</a></li> + }} + } { + <li id="ca-viewsource" {selecttab {edit}}><a href="{edit_url}">{msg {viewsource}}</a></li> + }} + + {if article_exists { + <li id="ca-history" {selecttab {history}}><a href="{localurl {action=history}}">{msg {history_short}}</a></li> + {if {{ is_allowed {protect} }} { + {if is_ns_mediawiki {} { + {if is_protected { + <li id="ca-protect" {selecttab {protect}}><a href="{localurl {action=unprotect}}">{msg {unprotect}}</a></li> + } { + <li id="ca-protect" {selecttab {protect}}><a href="{localurl {action=protect}}">{msg {protect}}</a></li> + }} + }} + }} + + {if {{ is_allowed {delete} }} { + <li id="ca-delete" {selecttab {delete}}><a href="{localurl {action=delete}}">{msg {delete}}</a></li> + }} + {if {{ is_allowed {move} }} { + {if can_move { + <li id="ca-move" {selecttab {move}}><a href="{move_url}">{msg {move}}</a></li> + }} + }} + {if is_loggedin { + {if is_watching { + <li id="ca-unwatch" {selecttab {watch}}><a href="{localurl {action=unwatch}}">{msg {unwatch}}</a></li> + } { + <li id="ca-watch" {selecttab {watch}}><a href="{localurl {action=watch}}">{msg {watch}}</a></li> + }} + }} + }} + }} + {extratabs {<li id="ca-$id" $class><a href="$href">$text</a></li>}} + </ul> + </div> + <div class="portlet" id="p-personal"> + <h5>{msg {personaltools}}</h5> + <div class="pBody"> + <ul> + {personal_urls { <li id="pt-$key" $classactive ><a href="$href" $class>$text</a></li> }} + </ul> + </div> + </div> + <div class="portlet" id="p-logo"> + <a style="background-image: url({~ logopath});" href="{mainpage}" title="{msg {mainpage}}"></a> + </div> + <script type="{jsmimetype}"> if (window.isMSIE55) fixalpha(); </script> + {sidebar { + <div class='portlet' id="p-$bar"> + <h5>$barname</h5> + <div class='pBody'> + <ul> + } { + </ul> + </div> + </div> + } {<li id="$id" $classactive><a href="$href">$text</a></li> + } + } + + <div id="p-search" class="portlet"> + <h5><label for="searchInput">{msg {search}}</label></h5> + <div id="searchBody" class="pBody"> + <form action="{searchaction}" id="searchform"><div> + <input id="searchInput" name="search" type="text" { + }{if {{fallbackmsg {accesskey-search} {} }} {accesskey="{fallbackmsg {accesskey-search} {} }"}}{ + }{if search { value="{search}"}} /> + <input type='submit' name="go" class="searchButton" id="searchGoButton" value="{msg {go}}" /> + <input type='submit' name="fulltext" class="searchButton" value="{msg {search}}" /> + </div></form> + </div> + </div> + <div class="portlet" id="p-tb"> + <h5>{msg {toolbox}}</h5> + <div class="pBody"> + <ul> + {if notspecialpage {<li id="t-whatlinkshere"><a href="{nav_whatlinkshere}">{msg {whatlinkshere}}</a></li> }} + {if article_exists {<li id="t-recentchangeslinked"><a href="{nav_recentchangeslinked}">{msg {recentchangeslinked}}</a></li> }} + {if nav_trackbacklink {<li id="t-trackbacklink"><a href="{nav_trackbacklink}">{msg {trackbacklink}}</a></li>}} + {if feeds + {<li id="feedlinks">{feeds {<span id="feed-$key"><a href="$href">$text</a> </span>}} + </li>}} + {if is_userpage { + <li id="t-contributions"><a href="{nav_contributions}">{msg {contributions}}</a></li> + {if {{is_allowed {block}}} {<li id="t-blockip"><a href="{nav_blockip}">{msg {blockip}}</a></li>}} + {if is_loggedin {<li id="t-emailuser"><a href="{nav_emailuser}">{msg {emailuser}}</a></li>}} + }} + {if nav_upload {<li id="t-upload"><a href="{nav_upload}">{msg {upload}}</a></li>}} + {if nav_specialpages {<li id="t-specialpages"><a href="{nav_specialpages}">{msg {specialpages}}</a></li>}} + {if nav_print {<li id="t-print"><a href="{nav_print}">{msg {printableversion}}</a></li>}} + {if nav_permalink {<li id="t-permalink"><a href="{nav_permalink}">{msg {permalink}}</a></li>}} + {if is_permalink {<li id="t-ispermalink">{msg {permalink}}</li>}} + + {toolboxend} + </ul> + </div> + </div> + {language_urls { + <div id="p-lang" class="portlet"> + <h5>{msg {otherlanguages}}</h5> + <div class="pBody"> + <ul> + $body + </ul> + </div> + </div> + } { + <li class="$class"><a href="$href">$text</a></li> + }} + </div><!-- end of the left (by default at least) column --> + <div class="visualClear"></div> + <div id="footer"> + {if poweredbyico { <div id="f-poweredbyico">{poweredbyico}</div> }} + {if copyrightico { <div id="f-copyrightico">{copyrightico}</div> }} + + <ul id="f-list"> + {if lastmod { <li id="lastmod">{lastmod}</li> }} + {if viewcount { <li id="viewcount">{viewcount}</li> }} + {if numberofwatchingusers { <li id="numberofwatchingusers">{numberofwatchingusers}</li> }} + {if credits { <li id="credits">{credits}</li> }} + {if is_currentview { <li id="copyright">{normalcopyright}</li> }} + {if usehistorycopyright { <li id="copyright">{historycopyright}</li> }} + {if privacy { <li id="privacy">{privacy}</li> }} + {if about { <li id="about">{about}</li> }} + {if disclaimer { <li id="disclaimer">{disclaimer}</li> }} + {if tagline { <li id="tagline">{tagline}</li> }} + </ul> + </div> + <script type="text/javascript"> if (window.runOnloadHook) runOnloadHook();</script> +</div> +{reporttime} +{if {} { vim: set syn=html ts=2 : }} +</body></html> diff --git a/skins/disabled/MonoBookCBT.php b/skins/disabled/MonoBookCBT.php new file mode 100644 index 00000000..0474ad7c --- /dev/null +++ b/skins/disabled/MonoBookCBT.php @@ -0,0 +1,1390 @@ +<?php + +if ( !defined( 'MEDIAWIKI' ) ) { + die( "This file is part of MediaWiki, it is not a valid entry point\n" ); +} + +require_once( 'includes/cbt/CBTProcessor.php' ); +require_once( 'includes/cbt/CBTCompiler.php' ); +require_once( 'includes/SkinTemplate.php' ); + +/** + * MonoBook clone using the new dependency-tracking template processor. + * EXPERIMENTAL - use only for testing and profiling at this stage. + * + * See includes/cbt/README for an explanation. + * + * The main thing that's missing is cache invalidation, on change of: + * * messages + * * user preferences + * * source template + * * source code and configuration files + * + * The other thing is that lots of dependencies that are declared in the callbacks + * are not intelligently handled. There's some room for improvement there. + * + * The class is derived from SkinTemplate, but that's only temporary. Eventually + * it'll be derived from Skin, and I've avoided using SkinTemplate functions as + * much as possible. In fact, the only SkinTemplate dependencies I know of at the + * moment are the functions to generate the gen=css and gen=js files. + * + */ +class SkinMonoBookCBT extends SkinTemplate { + var $mOut, $mTitle; + var $mStyleName = 'monobook'; + var $mCompiling = false; + var $mFunctionCache = array(); + + /****************************************************** + * General functions * + ******************************************************/ + + /** Execute the template and write out the result */ + function outputPage( &$out ) { + echo $this->execute( $out ); + } + + function execute( &$out ) { + global $wgTitle, $wgStyleDirectory, $wgParserCacheType; + $fname = 'SkinMonoBookCBT::execute'; + wfProfileIn( $fname ); + wfProfileIn( "$fname-setup" ); + Skin::initPage( $out ); + + $this->mOut =& $out; + $this->mTitle =& $wgTitle; + + $sourceFile = "$wgStyleDirectory/MonoBook.tpl"; + + wfProfileOut( "$fname-setup" ); + + if ( $wgParserCacheType == CACHE_NONE ) { + $template = file_get_contents( $sourceFile ); + $text = $this->executeTemplate( $template ); + } else { + $compiled = $this->getCompiledTemplate( $sourceFile ); + + wfProfileIn( "$fname-eval" ); + $text = eval( $compiled ); + wfProfileOut( "$fname-eval" ); + } + wfProfileOut( $fname ); + return $text; + } + + function getCompiledTemplate( $sourceFile ) { + global $wgDBname, $wgMemc, $wgRequest, $wgUser, $parserMemc; + $fname = 'SkinMonoBookCBT::getCompiledTemplate'; + + $expiry = 3600; + + // Sandbox template execution + if ( $this->mCompiling ) { + return; + } + + wfProfileIn( $fname ); + + // Is the request an ordinary page view? + if ( $wgRequest->wasPosted() || + count( array_diff( array_keys( $_GET ), array( 'title', 'useskin', 'recompile' ) ) ) != 0 ) + { + $type = 'nonview'; + } else { + $type = 'view'; + } + + // Per-user compiled template + // Put all logged-out users on the same cache key + $cacheKey = "$wgDBname:monobookcbt:$type:" . $wgUser->getId(); + + $recompile = $wgRequest->getVal( 'recompile' ); + if ( $recompile == 'user' ) { + $recompileUser = true; + $recompileGeneric = false; + } elseif ( $recompile ) { + $recompileUser = true; + $recompileGeneric = true; + } else { + $recompileUser = false; + $recompileGeneric = false; + } + + if ( !$recompileUser ) { + $php = $parserMemc->get( $cacheKey ); + } + if ( $recompileUser || !$php ) { + if ( $wgUser->isLoggedIn() ) { + // Perform staged compilation + // First compile a generic template for all logged-in users + $genericKey = "$wgDBname:monobookcbt:$type:loggedin"; + if ( !$recompileGeneric ) { + $template = $parserMemc->get( $genericKey ); + } + if ( $recompileGeneric || !$template ) { + $template = file_get_contents( $sourceFile ); + $ignore = array( 'loggedin', '!loggedin dynamic' ); + if ( $type == 'view' ) { + $ignore[] = 'nonview dynamic'; + } + $template = $this->compileTemplate( $template, $ignore ); + $parserMemc->set( $genericKey, $template, $expiry ); + } + } else { + $template = file_get_contents( $sourceFile ); + } + + $ignore = array( 'lang', 'loggedin', 'user' ); + if ( $wgUser->isLoggedIn() ) { + $ignore[] = '!loggedin dynamic'; + } else { + $ignore[] = 'loggedin dynamic'; + } + if ( $type == 'view' ) { + $ignore[] = 'nonview dynamic'; + } + $compiled = $this->compileTemplate( $template, $ignore ); + + // Reduce whitespace + // This is done here instead of in CBTProcessor because we can be + // more sure it is safe here. + $compiled = preg_replace( '/^[ \t]+/m', '', $compiled ); + $compiled = preg_replace( '/[\r\n]+/', "\n", $compiled ); + + // Compile to PHP + $compiler = new CBTCompiler( $compiled ); + $ret = $compiler->compile(); + if ( $ret !== true ) { + echo $ret; + wfErrorExit(); + } + $php = $compiler->generatePHP( '$this' ); + + $parserMemc->set( $cacheKey, $php, $expiry ); + } + wfProfileOut( $fname ); + return $php; + } + + function compileTemplate( $template, $ignore ) { + $tp = new CBTProcessor( $template, $this, $ignore ); + $tp->mFunctionCache = $this->mFunctionCache; + + $this->mCompiling = true; + $compiled = $tp->compile(); + $this->mCompiling = false; + + if ( $tp->getLastError() ) { + // If there was a compile error, don't save the template + // Instead just print the error and exit + echo $compiled; + wfErrorExit(); + } + $this->mFunctionCache = $tp->mFunctionCache; + return $compiled; + } + + function executeTemplate( $template ) { + $fname = 'SkinMonoBookCBT::executeTemplate'; + wfProfileIn( $fname ); + $tp = new CBTProcessor( $template, $this ); + $tp->mFunctionCache = $this->mFunctionCache; + + $this->mCompiling = true; + $text = $tp->execute(); + $this->mCompiling = false; + + $this->mFunctionCache = $tp->mFunctionCache; + wfProfileOut( $fname ); + return $text; + } + + /****************************************************** + * Callbacks * + ******************************************************/ + + function lang() { return $GLOBALS['wgContLanguageCode']; } + + function dir() { + global $wgContLang; + return $wgContLang->isRTL() ? 'rtl' : 'ltr'; + } + + function mimetype() { return $GLOBALS['wgMimeType']; } + function charset() { return $GLOBALS['wgOutputEncoding']; } + function headlinks() { + return cbt_value( $this->mOut->getHeadLinks(), 'dynamic' ); + } + function headscripts() { + return cbt_value( $this->mOut->getScript(), 'dynamic' ); + } + + function pagetitle() { + return cbt_value( $this->mOut->getHTMLTitle(), array( 'title', 'lang' ) ); + } + + function stylepath() { return $GLOBALS['wgStylePath']; } + function stylename() { return $this->mStyleName; } + + function notprintable() { + global $wgRequest; + return cbt_value( !$wgRequest->getBool( 'printable' ), 'nonview dynamic' ); + } + + function jsmimetype() { return $GLOBALS['wgJsMimeType']; } + + function jsvarurl() { + global $wgUseSiteJs, $wgUser; + if ( !$wgUseSiteJs ) return ''; + + if ( $wgUser->isLoggedIn() ) { + $url = $this->makeUrl('-','action=raw&smaxage=0&gen=js'); + } else { + $url = $this->makeUrl('-','action=raw&gen=js'); + } + return cbt_value( $url, 'loggedin' ); + } + + function pagecss() { + global $wgHooks; + + $out = false; + wfRunHooks( 'SkinTemplateSetupPageCss', array( &$out ) ); + + // Unknown dependencies + return cbt_value( $out, 'dynamic' ); + } + + function usercss() { + if ( $this->isCssPreview() ) { + global $wgRequest; + $usercss = $this->makeStylesheetCdata( $wgRequest->getText('wpTextbox1') ); + } else { + $usercss = $this->makeStylesheetLink( $this->makeUrl($this->getUserPageText() . + '/'.$this->mStyleName.'.css', 'action=raw&ctype=text/css' ) ); + } + + // Dynamic when not an ordinary page view, also depends on the username + return cbt_value( $usercss, array( 'nonview dynamic', 'user' ) ); + } + + function sitecss() { + global $wgUseSiteCss; + if ( !$wgUseSiteCss ) { + return ''; + } + + global $wgSquidMaxage, $wgContLang, $wgStylePath; + + $query = "action=raw&ctype=text/css&smaxage=$wgSquidMaxage"; + + $sitecss = ''; + if ( $wgContLang->isRTL() ) { + $sitecss .= $this->makeStylesheetLink( $wgStylePath . '/' . $this->mStyleName . '/rtl.css' ) . "\n"; + } + + $sitecss .= $this->makeStylesheetLink( $this->makeNSUrl('Common.css', $query, NS_MEDIAWIKI) ) . "\n"; + $sitecss .= $this->makeStylesheetLink( $this->makeNSUrl( + ucfirst($this->mStyleName) . '.css', $query, NS_MEDIAWIKI) ) . "\n"; + + // No deps + return $sitecss; + } + + function gencss() { + global $wgUseSiteCss; + if ( !$wgUseSiteCss ) return ''; + + global $wgSquidMaxage, $wgUser, $wgAllowUserCss; + if ( $this->isCssPreview() ) { + $siteargs = '&smaxage=0&maxage=0'; + } else { + $siteargs = '&maxage=' . $wgSquidMaxage; + } + if ( $wgAllowUserCss && $wgUser->isLoggedIn() ) { + $siteargs .= '&ts={user_touched}'; + $isTemplate = true; + } else { + $isTemplate = false; + } + + $link = $this->makeStylesheetLink( $this->makeUrl('-','action=raw&gen=css' . $siteargs) ) . "\n"; + + if ( $wgAllowUserCss ) { + $deps = 'loggedin'; + } else { + $deps = array(); + } + return cbt_value( $link, $deps, $isTemplate ); + } + + function user_touched() { + global $wgUser; + return cbt_value( $wgUser->mTouched, 'dynamic' ); + } + + function userjs() { + global $wgAllowUserJs, $wgJsMimeType; + if ( !$wgAllowUserJs ) return ''; + + if ( $this->isJsPreview() ) { + $url = ''; + } else { + $url = $this->makeUrl($this->getUserPageText().'/'.$this->mStyleName.'.js', 'action=raw&ctype='.$wgJsMimeType.'&dontcountme=s'); + } + return cbt_value( $url, array( 'nonview dynamic', 'user' ) ); + } + + function userjsprev() { + global $wgAllowUserJs, $wgRequest; + if ( !$wgAllowUserJs ) return ''; + if ( $this->isJsPreview() ) { + $js = '/*<![CDATA[*/ ' . $wgRequest->getText('wpTextbox1') . ' /*]]>*/'; + } else { + $js = ''; + } + return cbt_value( $js, array( 'nonview dynamic' ) ); + } + + function trackbackhtml() { + global $wgUseTrackbacks; + if ( !$wgUseTrackbacks ) return ''; + + if ( $this->mOut->isArticleRelated() ) { + $tb = $this->mTitle->trackbackRDF(); + } else { + $tb = ''; + } + return cbt_value( $tb, 'dynamic' ); + } + + function body_ondblclick() { + global $wgUser; + if( $this->isEditable() && $wgUser->getOption("editondblclick") ) { + $js = 'document.location = "' . $this->getEditUrl() .'";'; + } else { + $js = ''; + } + + if ( User::getDefaultOption('editondblclick') ) { + return cbt_value( $js, 'user', 'title' ); + } else { + // Optimise away for logged-out users + return cbt_value( $js, 'loggedin dynamic' ); + } + } + + function body_onload() { + global $wgUser; + if ( $this->isEditable() && $wgUser->getOption( 'editsectiononrightclick' ) ) { + $js = 'setupRightClickEdit()'; + } else { + $js = ''; + } + return cbt_value( $js, 'loggedin dynamic' ); + } + + function nsclass() { + return cbt_value( 'ns-' . $this->mTitle->getNamespace(), 'title' ); + } + + function sitenotice() { + // Perhaps this could be given special dependencies using our knowledge of what + // wfGetSiteNotice() depends on. + return cbt_value( wfGetSiteNotice(), 'dynamic' ); + } + + function title() { + return cbt_value( $this->mOut->getPageTitle(), array( 'title', 'lang' ) ); + } + + function title_urlform() { + return cbt_value( $this->getThisTitleUrlForm(), 'title' ); + } + + function title_userurl() { + return cbt_value( urlencode( $this->mTitle->getDBkey() ), 'title' ); + } + + function subtitle() { + $subpagestr = $this->subPageSubtitle(); + if ( !empty( $subpagestr ) ) { + $s = '<span class="subpages">'.$subpagestr.'</span>'.$this->mOut->getSubtitle(); + } else { + $s = $this->mOut->getSubtitle(); + } + return cbt_value( $s, array( 'title', 'nonview dynamic' ) ); + } + + function undelete() { + return cbt_value( $this->getUndeleteLink(), array( 'title', 'lang' ) ); + } + + function newtalk() { + global $wgUser, $wgDBname; + $newtalks = $wgUser->getNewMessageLinks(); + + if (count($newtalks) == 1 && $newtalks[0]["wiki"] === $wgDBname) { + $usertitle = $this->getUserPageTitle(); + $usertalktitle = $usertitle->getTalkPage(); + if( !$usertalktitle->equals( $this->mTitle ) ) { + $ntl = wfMsg( 'youhavenewmessages', + $this->makeKnownLinkObj( + $usertalktitle, + wfMsgHtml( 'newmessageslink' ), + 'redirect=no' + ), + $this->makeKnownLinkObj( + $usertalktitle, + wfMsgHtml( 'newmessagesdifflink' ), + 'diff=cur' + ) + ); + # Disable Cache + $this->mOut->setSquidMaxage(0); + } + } else if (count($newtalks)) { + $sep = str_replace("_", " ", wfMsgHtml("newtalkseperator")); + $msgs = array(); + foreach ($newtalks as $newtalk) { + $msgs[] = wfElement("a", + array('href' => $newtalk["link"]), $newtalk["wiki"]); + } + $parts = implode($sep, $msgs); + $ntl = wfMsgHtml('youhavenewmessagesmulti', $parts); + $this->mOut->setSquidMaxage(0); + } else { + $ntl = ''; + } + return cbt_value( $ntl, 'dynamic' ); + } + + function showjumplinks() { + global $wgUser; + return cbt_value( $wgUser->getOption( 'showjumplinks' ) ? 'true' : '', 'user' ); + } + + function bodytext() { + return cbt_value( $this->mOut->getHTML(), 'dynamic' ); + } + + function catlinks() { + if ( !isset( $this->mCatlinks ) ) { + $this->mCatlinks = $this->getCategories(); + } + return cbt_value( $this->mCatlinks, 'dynamic' ); + } + + function extratabs( $itemTemplate ) { + global $wgContLang, $wgDisableLangConversion; + + $etpl = cbt_escape( $itemTemplate ); + + /* show links to different language variants */ + $variants = $wgContLang->getVariants(); + $s = ''; + if ( !$wgDisableLangConversion && count( $wgContLang->getVariants() ) > 1 ) { + $vcount=0; + foreach ( $variants as $code ) { + $name = $wgContLang->getVariantname( $code ); + if ( $name == 'disable' ) { + continue; + } + $code = cbt_escape( $code ); + $name = cbt_escape( $name ); + $s .= "{ca_variant {{$code}} {{$name}} {{$vcount}} {{$etpl}}}\n"; + $vcount ++; + } + } + return cbt_value( $s, array(), true ); + } + + function is_special() { return cbt_value( $this->mTitle->getNamespace() == NS_SPECIAL, 'title' ); } + function can_edit() { return cbt_value( (string)($this->mTitle->userCanEdit()), 'dynamic' ); } + function can_move() { return cbt_value( (string)($this->mTitle->userCanMove()), 'dynamic' ); } + function is_talk() { return cbt_value( (string)($this->mTitle->isTalkPage()), 'title' ); } + function is_protected() { return cbt_value( (string)$this->mTitle->isProtected(), 'dynamic' ); } + function nskey() { return cbt_value( $this->mTitle->getNamespaceKey(), 'title' ); } + + function request_url() { + global $wgRequest; + return cbt_value( $wgRequest->getRequestURL(), 'dynamic' ); + } + + function subject_url() { + $title = $this->getSubjectPage(); + if ( $title->exists() ) { + $url = $title->getLocalUrl(); + } else { + $url = $title->getLocalUrl( 'action=edit' ); + } + return cbt_value( $url, 'title' ); + } + + function talk_url() { + $title = $this->getTalkPage(); + if ( $title->exists() ) { + $url = $title->getLocalUrl(); + } else { + $url = $title->getLocalUrl( 'action=edit' ); + } + return cbt_value( $url, 'title' ); + } + + function edit_url() { + return cbt_value( $this->getEditUrl(), array( 'title', 'nonview dynamic' ) ); + } + + function move_url() { + return cbt_value( $this->makeSpecialParamUrl( 'Movepage' ), array(), true ); + } + + function localurl( $query ) { + return cbt_value( $this->mTitle->getLocalURL( $query ), 'title' ); + } + + function selecttab( $tab, $extraclass = '' ) { + if ( !isset( $this->mSelectedTab ) ) { + $prevent_active_tabs = false ; + wfRunHooks( 'SkinTemplatePreventOtherActiveTabs', array( &$this , &$preventActiveTabs ) ); + + $actionTabs = array( + 'edit' => 'edit', + 'submit' => 'edit', + 'history' => 'history', + 'protect' => 'protect', + 'unprotect' => 'protect', + 'delete' => 'delete', + 'watch' => 'watch', + 'unwatch' => 'watch', + ); + if ( $preventActiveTabs ) { + $this->mSelectedTab = false; + } else { + $action = $this->getAction(); + $section = $this->getSection(); + + if ( isset( $actionTabs[$action] ) ) { + $this->mSelectedTab = $actionTabs[$action]; + + if ( $this->mSelectedTab == 'edit' && $section == 'new' ) { + $this->mSelectedTab = 'addsection'; + } + } elseif ( $this->mTitle->isTalkPage() ) { + $this->mSelectedTab = 'talk'; + } else { + $this->mSelectedTab = 'subject'; + } + } + } + if ( $extraclass ) { + if ( $this->mSelectedTab == $tab ) { + $s = 'class="selected ' . htmlspecialchars( $extraclass ) . '"'; + } else { + $s = 'class="' . htmlspecialchars( $extraclass ) . '"'; + } + } else { + if ( $this->mSelectedTab == $tab ) { + $s = 'class="selected"'; + } else { + $s = ''; + } + } + return cbt_value( $s, array( 'nonview dynamic', 'title' ) ); + } + + function subject_newclass() { + $title = $this->getSubjectPage(); + $class = $title->exists() ? '' : 'new'; + return cbt_value( $class, 'dynamic' ); + } + + function talk_newclass() { + $title = $this->getTalkPage(); + $class = $title->exists() ? '' : 'new'; + return cbt_value( $class, 'dynamic' ); + } + + function ca_variant( $code, $name, $index, $template ) { + global $wgContLang; + $selected = ($code == $wgContLang->getPreferredVariant()); + $action = $this->getAction(); + $actstr = ''; + if( $action ) + $actstr = 'action=' . $action . '&'; + $s = strtr( $template, array( + '$id' => htmlspecialchars( 'varlang-' . $index ), + '$class' => $selected ? 'class="selected"' : '', + '$text' => $name, + '$href' => htmlspecialchars( $this->mTitle->getLocalUrl( $actstr . 'variant=' . $code ) ) + )); + return cbt_value( $s, 'dynamic' ); + } + + function is_watching() { + return cbt_value( (string)$this->mTitle->userIsWatching(), array( 'dynamic' ) ); + } + + + function personal_urls( $itemTemplate ) { + global $wgShowIPinHeader, $wgContLang; + + # Split this function up into many small functions, to obtain the + # best specificity in the dependencies of each one. The template below + # has no dependencies, so its generation, and any static subfunctions, + # can be optimised away. + $etpl = cbt_escape( $itemTemplate ); + $s = " + {userpage {{$etpl}}} + {mytalk {{$etpl}}} + {preferences {{$etpl}}} + {watchlist {{$etpl}}} + {mycontris {{$etpl}}} + {logout {{$etpl}}} + "; + + if ( $wgShowIPinHeader ) { + $s .= " + {anonuserpage {{$etpl}}} + {anontalk {{$etpl}}} + {anonlogin {{$etpl}}} + "; + } else { + $s .= "{login {{$etpl}}}\n"; + } + // No dependencies + return cbt_value( $s, array(), true /*this is a template*/ ); + } + + function userpage( $itemTemplate ) { + global $wgUser; + if ( $this->isLoggedIn() ) { + $userPage = $this->getUserPageTitle(); + $s = $this->makeTemplateLink( $itemTemplate, 'userpage', $userPage, $wgUser->getName() ); + } else { + $s = ''; + } + return cbt_value( $s, 'user' ); + } + + function mytalk( $itemTemplate ) { + global $wgUser; + if ( $this->isLoggedIn() ) { + $userPage = $this->getUserPageTitle(); + $talkPage = $userPage->getTalkPage(); + $s = $this->makeTemplateLink( $itemTemplate, 'mytalk', $talkPage, wfMsg('mytalk') ); + } else { + $s = ''; + } + return cbt_value( $s, 'user' ); + } + + function preferences( $itemTemplate ) { + if ( $this->isLoggedIn() ) { + $s = $this->makeSpecialTemplateLink( $itemTemplate, 'preferences', + 'Preferences', wfMsg( 'preferences' ) ); + } else { + $s = ''; + } + return cbt_value( $s, array( 'loggedin', 'lang' ) ); + } + + function watchlist( $itemTemplate ) { + if ( $this->isLoggedIn() ) { + $s = $this->makeSpecialTemplateLink( $itemTemplate, 'watchlist', + 'Watchlist', wfMsg( 'watchlist' ) ); + } else { + $s = ''; + } + return cbt_value( $s, array( 'loggedin', 'lang' ) ); + } + + function mycontris( $itemTemplate ) { + if ( $this->isLoggedIn() ) { + global $wgUser; + $s = $this->makeSpecialTemplateLink( $itemTemplate, 'mycontris', + "Contributions/" . $wgUser->getTitleKey(), wfMsg('mycontris') ); + } else { + $s = ''; + } + return cbt_value( $s, 'user' ); + } + + function logout( $itemTemplate ) { + if ( $this->isLoggedIn() ) { + $s = $this->makeSpecialTemplateLink( $itemTemplate, 'logout', + 'Userlogout', wfMsg( 'userlogout' ), + $this->mTitle->getNamespace() === NS_SPECIAL && $this->mTitle->getText() === 'Preferences' + ? '' : "returnto=" . $this->mTitle->getPrefixedURL() ); + } else { + $s = ''; + } + return cbt_value( $s, 'loggedin dynamic' ); + } + + function anonuserpage( $itemTemplate ) { + if ( $this->isLoggedIn() ) { + $s = ''; + } else { + global $wgUser; + $userPage = $this->getUserPageTitle(); + $s = $this->makeTemplateLink( $itemTemplate, 'userpage', $userPage, $wgUser->getName() ); + } + return cbt_value( $s, '!loggedin dynamic' ); + } + + function anontalk( $itemTemplate ) { + if ( $this->isLoggedIn() ) { + $s = ''; + } else { + $userPage = $this->getUserPageTitle(); + $talkPage = $userPage->getTalkPage(); + $s = $this->makeTemplateLink( $itemTemplate, 'mytalk', $talkPage, wfMsg('anontalk') ); + } + return cbt_value( $s, '!loggedin dynamic' ); + } + + function anonlogin( $itemTemplate ) { + if ( $this->isLoggedIn() ) { + $s = ''; + } else { + $s = $this->makeSpecialTemplateLink( $itemTemplate, 'anonlogin', 'Userlogin', + wfMsg( 'userlogin' ), 'returnto=' . urlencode( $this->getThisPDBK() ) ); + } + return cbt_value( $s, '!loggedin dynamic' ); + } + + function login( $itemTemplate ) { + if ( $this->isLoggedIn() ) { + $s = ''; + } else { + $s = $this->makeSpecialTemplateLink( $itemTemplate, 'login', 'Userlogin', + wfMsg( 'userlogin' ), 'returnto=' . urlencode( $this->getThisPDBK() ) ); + } + return cbt_value( $s, '!loggedin dynamic' ); + } + + function logopath() { return $GLOBALS['wgLogo']; } + function mainpage() { return $this->makeI18nUrl( 'mainpage' ); } + + function sidebar( $startSection, $endSection, $innerTpl ) { + $s = ''; + $lines = explode( "\n", wfMsgForContent( 'sidebar' ) ); + $firstSection = true; + foreach ($lines as $line) { + if (strpos($line, '*') !== 0) + continue; + if (strpos($line, '**') !== 0) { + $bar = trim($line, '* '); + $name = wfMsg( $bar ); + if (wfEmptyMsg($bar, $name)) { + $name = $bar; + } + if ( $firstSection ) { + $firstSection = false; + } else { + $s .= $endSection; + } + $s .= strtr( $startSection, + array( + '$bar' => htmlspecialchars( $bar ), + '$barname' => $name + ) ); + } else { + if (strpos($line, '|') !== false) { // sanity check + $line = explode( '|' , trim($line, '* '), 2 ); + $link = wfMsgForContent( $line[0] ); + if ($link == '-') + continue; + if (wfEmptyMsg($line[1], $text = wfMsg($line[1]))) + $text = $line[1]; + if (wfEmptyMsg($line[0], $link)) + $link = $line[0]; + $href = $this->makeInternalOrExternalUrl( $link ); + + $s .= strtr( $innerTpl, + array( + '$text' => htmlspecialchars( $text ), + '$href' => htmlspecialchars( $href ), + '$id' => htmlspecialchars( 'n-' . strtr($line[1], ' ', '-') ), + '$classactive' => '' + ) ); + } else { continue; } + } + } + if ( !$firstSection ) { + $s .= $endSection; + } + + // Depends on user language only + return cbt_value( $s, 'lang' ); + } + + function searchaction() { + // Static link + return $this->getSearchLink(); + } + + function search() { + global $wgRequest; + return cbt_value( trim( $this->getSearch() ), 'special dynamic' ); + } + + function notspecialpage() { + return cbt_value( $this->mTitle->getNamespace() != NS_SPECIAL, 'special' ); + } + + function nav_whatlinkshere() { + return cbt_value( $this->makeSpecialParamUrl('Whatlinkshere' ), array(), true ); + } + + function article_exists() { + return cbt_value( (string)($this->mTitle->getArticleId() !== 0), 'title' ); + } + + function nav_recentchangeslinked() { + return cbt_value( $this->makeSpecialParamUrl('Recentchangeslinked' ), array(), true ); + } + + function feeds( $itemTemplate = '' ) { + if ( !$this->mOut->isSyndicated() ) { + $feeds = ''; + } elseif ( $itemTemplate == '' ) { + // boolean only required + $feeds = 'true'; + } else { + $feeds = ''; + global $wgFeedClasses, $wgRequest; + foreach( $wgFeedClasses as $format => $class ) { + $feeds .= strtr( $itemTemplate, + array( + '$key' => htmlspecialchars( $format ), + '$text' => $format, + '$href' => $wgRequest->appendQuery( "feed=$format" ) + ) ); + } + } + return cbt_value( $feeds, 'special dynamic' ); + } + + function is_userpage() { + list( $id, $ip ) = $this->getUserPageIdIp(); + return cbt_value( (string)($id || $ip), 'title' ); + } + + function is_ns_mediawiki() { + return cbt_value( (string)$this->mTitle->getNamespace() == NS_MEDIAWIKI, 'title' ); + } + + function is_loggedin() { + global $wgUser; + return cbt_value( (string)($wgUser->isLoggedIn()), 'loggedin' ); + } + + function nav_contributions() { + $url = $this->makeSpecialParamUrl( 'Contributions', '', '{title_userurl}' ); + return cbt_value( $url, array(), true ); + } + + function is_allowed( $right ) { + global $wgUser; + return cbt_value( (string)$wgUser->isAllowed( $right ), 'user' ); + } + + function nav_blockip() { + $url = $this->makeSpecialParamUrl( 'Blockip', '', '{title_userurl}' ); + return cbt_value( $url, array(), true ); + } + + function nav_emailuser() { + global $wgEnableEmail, $wgEnableUserEmail, $wgUser; + if ( !$wgEnableEmail || !$wgEnableUserEmail ) return ''; + + $url = $this->makeSpecialParamUrl( 'Emailuser', '', '{title_userurl}' ); + return cbt_value( $url, array(), true ); + } + + function nav_upload() { + global $wgEnableUploads, $wgUploadNavigationUrl; + if ( !$wgEnableUploads ) { + return ''; + } elseif ( $wgUploadNavigationUrl ) { + return $wgUploadNavigationUrl; + } else { + return $this->makeSpecialUrl('Upload'); + } + } + + function nav_specialpages() { + return $this->makeSpecialUrl('Specialpages'); + } + + function nav_print() { + global $wgRequest, $wgArticle; + $action = $this->getAction(); + $url = ''; + if( $this->mTitle->getNamespace() !== NS_SPECIAL + && ($action == '' || $action == 'view' || $action == 'purge' ) ) + { + $revid = $wgArticle->getLatest(); + if ( $revid != 0 ) { + $url = $wgRequest->appendQuery( 'printable=yes' ); + } + } + return cbt_value( $url, array( 'nonview dynamic', 'title' ) ); + } + + function nav_permalink() { + $url = (string)$this->getPermalink(); + return cbt_value( $url, 'dynamic' ); + } + + function nav_trackbacklink() { + global $wgUseTrackbacks; + if ( !$wgUseTrackbacks ) return ''; + + return cbt_value( $this->mTitle->trackbackURL(), 'title' ); + } + + function is_permalink() { + return cbt_value( (string)($this->getPermalink() === false), 'nonview dynamic' ); + } + + function toolboxend() { + // This is where the MonoBookTemplateToolboxEnd hook went in the old skin + return ''; + } + + function language_urls( $outer, $inner ) { + global $wgHideInterlanguageLinks, $wgOut, $wgContLang; + if ( $wgHideInterlanguageLinks ) return ''; + + $links = $wgOut->getLanguageLinks(); + $s = ''; + if ( count( $links ) ) { + foreach( $links as $l ) { + $tmp = explode( ':', $l, 2 ); + $nt = Title::newFromText( $l ); + $s .= strtr( $inner, + array( + '$class' => htmlspecialchars( 'interwiki-' . $tmp[0] ), + '$href' => htmlspecialchars( $nt->getFullURL() ), + '$text' => ($wgContLang->getLanguageName( $nt->getInterwiki() ) != ''? + $wgContLang->getLanguageName( $nt->getInterwiki() ) : $l ), + ) + ); + } + $s = str_replace( '$body', $s, $outer ); + } + return cbt_value( $s, 'dynamic' ); + } + + function poweredbyico() { return $this->getPoweredBy(); } + function copyrightico() { return $this->getCopyrightIcon(); } + + function lastmod() { + global $wgMaxCredits; + if ( $wgMaxCredits ) return ''; + + if ( !isset( $this->mLastmod ) ) { + if ( $this->isCurrentArticleView() ) { + $this->mLastmod = $this->lastModified(); + } else { + $this->mLastmod = ''; + } + } + return cbt_value( $this->mLastmod, 'dynamic' ); + } + + function viewcount() { + global $wgDisableCounters; + if ( $wgDisableCounters ) return ''; + + global $wgLang, $wgArticle; + if ( is_object( $wgArticle ) ) { + $viewcount = $wgLang->formatNum( $wgArticle->getCount() ); + if ( $viewcount ) { + $viewcount = wfMsg( "viewcount", $viewcount ); + } else { + $viewcount = ''; + } + } else { + $viewcount = ''; + } + return cbt_value( $viewcount, 'dynamic' ); + } + + function numberofwatchingusers() { + global $wgPageShowWatchingUsers; + if ( !$wgPageShowWatchingUsers ) return ''; + + $dbr =& wfGetDB( DB_SLAVE ); + extract( $dbr->tableNames( 'watchlist' ) ); + $sql = "SELECT COUNT(*) AS n FROM $watchlist + WHERE wl_title='" . $dbr->strencode($this->mTitle->getDBKey()) . + "' AND wl_namespace=" . $this->mTitle->getNamespace() ; + $res = $dbr->query( $sql, 'SkinTemplate::outputPage'); + $row = $dbr->fetchObject( $res ); + $num = $row->n; + if ($num > 0) { + $s = wfMsg('number_of_watching_users_pageview', $num); + } else { + $s = ''; + } + return cbt_value( $s, 'dynamic' ); + } + + function credits() { + global $wgMaxCredits; + if ( !$wgMaxCredits ) return ''; + + if ( $this->isCurrentArticleView() ) { + require_once("Credits.php"); + global $wgArticle, $wgShowCreditsIfMax; + $credits = getCredits($wgArticle, $wgMaxCredits, $wgShowCreditsIfMax); + } else { + $credits = ''; + } + return cbt_value( $credits, 'view dynamic' ); + } + + function normalcopyright() { + return $this->getCopyright( 'normal' ); + } + + function historycopyright() { + return $this->getCopyright( 'history' ); + } + + function is_currentview() { + global $wgRequest; + return cbt_value( (string)$this->isCurrentArticleView(), 'view' ); + } + + function usehistorycopyright() { + global $wgRequest; + if ( wfMsgForContent( 'history_copyright' ) == '-' ) return ''; + + $oldid = $this->getOldId(); + $diff = $this->getDiff(); + $use = (string)(!is_null( $oldid ) && is_null( $diff )); + return cbt_value( $use, 'nonview dynamic' ); + } + + function privacy() { + return cbt_value( $this->privacyLink(), 'lang' ); + } + function about() { + return cbt_value( $this->aboutLink(), 'lang' ); + } + function disclaimer() { + return cbt_value( $this->disclaimerLink(), 'lang' ); + } + function tagline() { + # A reference to this tag existed in the old MonoBook.php, but the + # template data wasn't set anywhere + return ''; + } + function reporttime() { + return cbt_value( $this->mOut->reportTime(), 'dynamic' ); + } + + function msg( $name ) { + return cbt_value( wfMsg( $name ), 'lang' ); + } + + function fallbackmsg( $name, $fallback ) { + $text = wfMsg( $name ); + if ( wfEmptyMsg( $name, $text ) ) { + $text = $fallback; + } + return cbt_value( $text, 'lang' ); + } + + /****************************************************** + * Utility functions * + ******************************************************/ + + /** Return true if this request is a valid, secure CSS preview */ + function isCssPreview() { + if ( !isset( $this->mCssPreview ) ) { + global $wgRequest, $wgAllowUserCss, $wgUser; + $this->mCssPreview = + $wgAllowUserCss && + $wgUser->isLoggedIn() && + $this->mTitle->isCssSubpage() && + $this->userCanPreview( $this->getAction() ); + } + return $this->mCssPreview; + } + + /** Return true if this request is a valid, secure JS preview */ + function isJsPreview() { + if ( !isset( $this->mJsPreview ) ) { + global $wgRequest, $wgAllowUserJs, $wgUser; + $this->mJsPreview = + $wgAllowUserJs && + $wgUser->isLoggedIn() && + $this->mTitle->isJsSubpage() && + $this->userCanPreview( $this->getAction() ); + } + return $this->mJsPreview; + } + + /** Get the title of the $wgUser's user page */ + function getUserPageTitle() { + if ( !isset( $this->mUserPageTitle ) ) { + global $wgUser; + $this->mUserPageTitle = $wgUser->getUserPage(); + } + return $this->mUserPageTitle; + } + + /** Get the text of the user page title */ + function getUserPageText() { + if ( !isset( $this->mUserPageText ) ) { + $userPage = $this->getUserPageTitle(); + $this->mUserPageText = $userPage->getPrefixedText(); + } + return $this->mUserPageText; + } + + /** Make an HTML element for a stylesheet link */ + function makeStylesheetLink( $url ) { + return '<link rel="stylesheet" type="text/css" href="' . htmlspecialchars( $url ) . "\"/>"; + } + + /** Make an XHTML element for inline CSS */ + function makeStylesheetCdata( $style ) { + return "<style type=\"text/css\"> /*<![CDATA[*/ {$style} /*]]>*/ </style>"; + } + + /** Get the edit URL for this page */ + function getEditUrl() { + if ( !isset( $this->mEditUrl ) ) { + $this->mEditUrl = $this->mTitle->getLocalUrl( $this->editUrlOptions() ); + } + return $this->mEditUrl; + } + + /** Get the prefixed DB key for this page */ + function getThisPDBK() { + if ( !isset( $this->mThisPDBK ) ) { + $this->mThisPDBK = $this->mTitle->getPrefixedDbKey(); + } + return $this->mThisPDBK; + } + + function getThisTitleUrlForm() { + if ( !isset( $this->mThisTitleUrlForm ) ) { + $this->mThisTitleUrlForm = $this->mTitle->getPrefixedURL(); + } + return $this->mThisTitleUrlForm; + } + + /** + * If the current page is a user page, get the user's ID and IP. Otherwise return array(0,false) + */ + function getUserPageIdIp() { + if ( !isset( $this->mUserPageId ) ) { + if( $this->mTitle->getNamespace() == NS_USER || $this->mTitle->getNamespace() == NS_USER_TALK ) { + $this->mUserPageId = User::idFromName($this->mTitle->getText()); + $this->mUserPageIp = User::isIP($this->mTitle->getText()); + } else { + $this->mUserPageId = 0; + $this->mUserPageIp = false; + } + } + return array( $this->mUserPageId, $this->mUserPageIp ); + } + + /** + * Returns a permalink URL, or false if the current page is already a + * permalink, or blank if a permalink shouldn't be displayed + */ + function getPermalink() { + if ( !isset( $this->mPermalink ) ) { + global $wgRequest, $wgArticle; + $action = $this->getAction(); + $oldid = $this->getOldId(); + $url = ''; + if( $this->mTitle->getNamespace() !== NS_SPECIAL + && $this->mTitle->getArticleId() != 0 + && ($action == '' || $action == 'view' || $action == 'purge' ) ) + { + if ( !$oldid ) { + $revid = $wgArticle->getLatest(); + $url = $this->mTitle->getLocalURL( "oldid=$revid" ); + } else { + $url = false; + } + } else { + $url = ''; + } + } + return $url; + } + + /** + * Returns true if the current page is an article, not a special page, + * and we are viewing a revision, not a diff + */ + function isArticleView() { + global $wgOut, $wgArticle, $wgRequest; + if ( !isset( $this->mIsArticleView ) ) { + $oldid = $this->getOldId(); + $diff = $this->getDiff(); + $this->mIsArticleView = $wgOut->isArticle() and + (!is_null( $oldid ) or is_null( $diff )) and 0 != $wgArticle->getID(); + } + return $this->mIsArticleView; + } + + function isCurrentArticleView() { + if ( !isset( $this->mIsCurrentArticleView ) ) { + global $wgOut, $wgArticle, $wgRequest; + $oldid = $this->getOldId(); + $this->mIsCurrentArticleView = $wgOut->isArticle() && is_null( $oldid ) && 0 != $wgArticle->getID(); + } + return $this->mIsCurrentArticleView; + } + + + /** + * Return true if the current page is editable; if edit section on right + * click should be enabled. + */ + function isEditable() { + global $wgRequest; + $action = $this->getAction(); + return ($this->mTitle->getNamespace() != NS_SPECIAL and !($action == 'edit' or $action == 'submit')); + } + + /** Return true if the user is logged in */ + function isLoggedIn() { + global $wgUser; + return $wgUser->isLoggedIn(); + } + + /** Get the local URL of the current page */ + function getPageUrl() { + if ( !isset( $this->mPageUrl ) ) { + $this->mPageUrl = $this->mTitle->getLocalURL(); + } + return $this->mPageUrl; + } + + /** Make a link to a title using a template */ + function makeTemplateLink( $template, $key, $title, $text ) { + $url = $title->getLocalUrl(); + return strtr( $template, + array( + '$key' => $key, + '$classactive' => ($url == $this->getPageUrl()) ? 'class="active"' : '', + '$class' => $title->getArticleID() == 0 ? 'class="new"' : '', + '$href' => htmlspecialchars( $url ), + '$text' => $text + ) ); + } + + /** Make a link to a URL using a template */ + function makeTemplateLinkUrl( $template, $key, $url, $text ) { + return strtr( $template, + array( + '$key' => $key, + '$classactive' => ($url == $this->getPageUrl()) ? 'class="active"' : '', + '$class' => '', + '$href' => htmlspecialchars( $url ), + '$text' => $text + ) ); + } + + /** Make a link to a special page using a template */ + function makeSpecialTemplateLink( $template, $key, $specialName, $text, $query = '' ) { + $url = $this->makeSpecialUrl( $specialName, $query ); + // Ignore the query when comparing + $active = ($this->mTitle->getNamespace() == NS_SPECIAL && $this->mTitle->getDBkey() == $specialName); + return strtr( $template, + array( + '$key' => $key, + '$classactive' => $active ? 'class="active"' : '', + '$class' => '', + '$href' => htmlspecialchars( $url ), + '$text' => $text + ) ); + } + + function loadRequestValues() { + global $wgRequest; + $this->mAction = $wgRequest->getText( 'action' ); + $this->mOldId = $wgRequest->getVal( 'oldid' ); + $this->mDiff = $wgRequest->getVal( 'diff' ); + $this->mSection = $wgRequest->getVal( 'section' ); + $this->mSearch = $wgRequest->getVal( 'search' ); + $this->mRequestValuesLoaded = true; + } + + + + /** Get the action parameter of the request */ + function getAction() { + if ( !isset( $this->mRequestValuesLoaded ) ) { + $this->loadRequestValues(); + } + return $this->mAction; + } + + /** Get the oldid parameter */ + function getOldId() { + if ( !isset( $this->mRequestValuesLoaded ) ) { + $this->loadRequestValues(); + } + return $this->mOldId; + } + + /** Get the diff parameter */ + function getDiff() { + if ( !isset( $this->mRequestValuesLoaded ) ) { + $this->loadRequestValues(); + } + return $this->mDiff; + } + + function getSection() { + if ( !isset( $this->mRequestValuesLoaded ) ) { + $this->loadRequestValues(); + } + return $this->mSection; + } + + function getSearch() { + if ( !isset( $this->mRequestValuesLoaded ) ) { + $this->loadRequestValues(); + } + return $this->mSearch; + } + + /** Make a special page URL of the form [[Special:Somepage/{title_urlform}]] */ + function makeSpecialParamUrl( $name, $query = '', $param = '{title_urlform}' ) { + // Abuse makeTitle's lax validity checking to slip a control character into the URL + $title = Title::makeTitle( NS_SPECIAL, "$name/\x1a" ); + $url = cbt_escape( $title->getLocalURL( $query ) ); + // Now replace it with the parameter + return str_replace( '%1A', $param, $url ); + } + + function getSubjectPage() { + if ( !isset( $this->mSubjectPage ) ) { + $this->mSubjectPage = $this->mTitle->getSubjectPage(); + } + return $this->mSubjectPage; + } + + function getTalkPage() { + if ( !isset( $this->mTalkPage ) ) { + $this->mTalkPage = $this->mTitle->getTalkPage(); + } + return $this->mTalkPage; + } +} +?> |