summaryrefslogtreecommitdiff
path: root/skins/disabled
diff options
context:
space:
mode:
authorPierre Schmitz <pierre@archlinux.de>2006-10-11 18:12:39 +0000
committerPierre Schmitz <pierre@archlinux.de>2006-10-11 18:12:39 +0000
commit183851b06bd6c52f3cae5375f433da720d410447 (patch)
treea477257decbf3360127f6739c2f9d0ec57a03d39 /skins/disabled
MediaWiki 1.7.1 wiederhergestellt
Diffstat (limited to 'skins/disabled')
-rw-r--r--skins/disabled/HTMLDump.php228
-rw-r--r--skins/disabled/MonoBook.tpl200
-rw-r--r--skins/disabled/MonoBookCBT.php1390
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&section=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}}" />&nbsp;
+ <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>&nbsp;</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;
+ }
+}
+?>