X-Git-Url: http://git.heureux-cyclage.org/?a=blobdiff_plain;f=includes%2FSkinPHPTal.php;h=3efb2e379003d3427bd654673f31ad870c09fdc7;hb=8f0f91659d5db006f61ff8c3332f83928e546f5d;hp=b7adc8756b07d6980d3c59bcbd76c57f328ab00b;hpb=ac19029d8aca84c169b2821d640a53bbe25ad5eb;p=lhc%2Fweb%2Fwiklou.git diff --git a/includes/SkinPHPTal.php b/includes/SkinPHPTal.php index b7adc8756b..3efb2e3790 100644 --- a/includes/SkinPHPTal.php +++ b/includes/SkinPHPTal.php @@ -1,569 +1,155 @@ _context[$varName] = $value; - } - - function translate($value) - { - $value = wfMsg( $value ); - - // interpolate variables - while (preg_match('/\$([0-9]*?)/sm', $value, $m)) { - list($src, $var) = $m; - $varValue = $this->_context[$var]; - $value = str_replace($src, $varValue, $value); - } - return $value; - } +/** + * Generic PHPTal (http://phptal.sourceforge.net/) skin + * Based on Brion's smarty skin + * Copyright (C) Gabriel Wicke -- http://www.aulinx.de/ + * + * The guts of this have moved to SkinTemplate.php + * + * Make sure the appropriate version of PHPTAL is installed (0.7.0 for PHP4, + * or 1.0.0 for PHP5) and available in the include_path. The system PEAR + * directory is good. + * + * If PEAR or PHPTAL can't be loaded, it will try to gracefully fall back. + * Turn on MediaWiki's debug log to see it complain. + * + * @package MediaWiki + * @subpackage Skins + */ + +/** + * This is not a valid entry point, perform no further processing unless + * MEDIAWIKI is defined + */ +if( defined( 'MEDIAWIKI' ) ) { + +require_once 'GlobalFunctions.php'; +require_once 'SkinTemplate.php'; + +if( version_compare( phpversion(), "5.0", "lt" ) ) { + define( 'OLD_PHPTAL', true ); + # PEAR and PHPTAL 0.7.x must be installed and in include_path +} else { + define( 'NEW_PHPTAL', true ); + # PEAR and PHPTAL 1.0.x must be installed and in include_path +} + +@include_once 'PEAR.php'; +if( !class_exists( 'PEAR' ) ) { + wfDebug( 'PHPTAL-based skin couldn\'t include PEAR.php' ); +} else { + +// PHPTAL may be in the libs dir direct, or under HTML/Template. +// Try them both to be safe. +@include_once 'HTML/Template/PHPTAL.php'; +if( !class_exists( 'PHPTAL' ) ) { + @include_once 'PHPTAL.php'; +} + +if( !class_exists( 'PHPTAL' ) ) { + wfDebug( 'PHPTAL-based skin couldn\'t include PHPTAL.php' ); +} else { + +/** + * + * @package MediaWiki + */ +class SkinPHPTal extends SkinTemplate { + /** */ + function initPage( &$out ) { + parent::initPage( $out ); + $this->skinname = 'monobook'; + $this->stylename = 'monobook'; + $this->template = 'MonoBook'; } - class SkinPHPTal extends Skin { - var $template; - - function initPage( &$out ) { - parent::initPage( $out ); - $this->skinname = "davinci"; - $this->template = "xhtml_slim"; - } - - function outputPage( &$out ) { - global $wgTitle, $wgArticle, $wgUser, $wgLang, $wgOut; - global $wgScript, $wgStyleSheetPath, $wgLanguageCode, $wgUseNewInterlanguage; - global $wgMimeType, $wgOutputEncoding, $wgUseDatabaseMessages, $wgRequest; - global $wgDisableCounters, $wgLogo, $action, $wgFeedClasses; - - extract( $wgRequest->getValues( 'oldid', 'diff' ) ); - - $this->thispage = $wgTitle->getPrefixedDbKey(); - $this->thisurl = $wgTitle->getPrefixedURL(); - $this->thisurle = urlencode($this->thisurl); - $this->loggedin = $wgUser->getID() != 0; - $this->username = $wgUser->getName(); - $this->userpage = $wgLang->getNsText( Namespace::getUser() ) . ":" . $wgUser->getName(); - $this->titletxt = $wgTitle->getPrefixedText(); - - $this->initPage( $out ); - $tpl = new PHPTAL($this->template . '.pt', 'templates'); - - #if ( $wgUseDatabaseMessages ) { // uncomment this to fall back to GetText - $tpl->setTranslator(new MediaWiki_I18N()); - #} - - $tpl->setRef( "title", &$this->titletxt ); // ? - if(!empty($action)) { - $taction = $this->getPageTitleActionText(); - $taction = !empty($taction)?' - '.$taction:''; - } else { $taction = ''; } - $tpl->set( "pagetitle", wfMsg( "pagetitle", $this->titletxt.$taction ) ); - $tpl->setRef( "thispage", &$this->thispage ); - $tpl->set( "subtitle", $out->getSubtitle() ); - $tpl->set( 'catlinks', getCategories()); - if( $wgOut->isSyndicated() ) { - $feeds = array(); - foreach( $wgFeedClasses as $format => $class ) { - $feeds[$format] = array( - 'text' => $format, - 'href' => $wgRequest->appendQuery( "feed=$format" ), - 'ttip' => wfMsg('tooltip-'.$format) - ); - } - $tpl->setRef( 'feeds', &$feeds ); - } - $tpl->setRef( 'mimetype', &$wgMimeType ); - $tpl->setRef( 'charset', &$wgOutputEncoding ); - $tpl->set( 'headlinks', $out->getHeadLinks() ); - $tpl->setRef( 'skinname', &$this->skinname ); - $tpl->setRef( "loggedin", &$this->loggedin ); - /* XXX currently unused, might get useful later - $tpl->set( "editable", ($wgTitle->getNamespace() != NS_SPECIAL ) ); - $tpl->set( "exists", $wgTitle->getArticleID() != 0 ); - $tpl->set( "watch", $wgTitle->userIsWatching() ? "unwatch" : "watch" ); - $tpl->set( "protect", count($wgTitle->getRestrictions()) ? "unprotect" : "protect" ); - $tpl->set( "helppage", wfMsg('helppage')); - $tpl->set( "sysop", $wgUser->isSysop() ); - */ - $tpl->setRef( "searchaction", &$wgScript ); - $tpl->setRef( "stylepath", &$wgStyleSheetPath ); - $tpl->setRef( "logopath", &$wgLogo ); - $tpl->setRef( "lang", &$wgLanguageCode ); - $tpl->set( "langname", $wgLang->getLanguageName( $wgLanguageCode ) ); - $tpl->setRef( "username", &$this->username ); - $tpl->setRef( "userpage", &$this->userpage); - if( $wgUser->getNewtalk() ) { - $usertitle = Title::newFromText( $this->userpage ); - $usertalktitle = $usertitle->getTalkPage(); - if($usertalktitle->getPrefixedDbKey() != $this->thispage){ - - $ntl = wfMsg( "newmessages", - $this->makeKnownLink( - $wgLang->getNsText( Namespace::getTalk( Namespace::getUser() ) ) - . ":" . $this->username, - wfMsg("newmessageslink") ) - ); - } - } else { - $ntl = ""; - } - - $tpl->setRef( "newtalk", &$ntl ); - $tpl->setRef( "skin", &$this); - $tpl->set( "logo", $this->logoText() ); - if ( $wgOut->isArticle() and (!isset( $oldid ) or isset( $diff )) and 0 != $wgArticle->getID() ) { - if ( !$wgDisableCounters ) { - $viewcount = $wgLang->formatNum( $wgArticle->getCount() ); - if ( $viewcount ) { - $tpl->set('viewcount', wfMsg( "viewcount", $viewcount )); - } - } - $tpl->set('lastmod', $this->lastModified()); - $tpl->set('copyright',$this->getCopyright()); - } - $tpl->set( "copyrightico", $this->getCopyrightIcon() ); - $tpl->set( "poweredbyico", $this->getPoweredBy() ); - $tpl->set( "disclaimer", $this->disclaimerLink() ); - $tpl->set( "about", $this->aboutLink() ); - - $tpl->setRef( "debug", &$out->mDebugtext ); - $tpl->set( "reporttime", $out->reportTime() ); - - $tpl->setRef( "bodytext", &$out->mBodytext ); - - $language_urls = array(); - foreach( $wgOut->getLanguageLinks() as $l ) { - $nt = Title::newFromText( $l ); - $language_urls[] = array('href' => $nt->getFullURL(), - 'text' => ($wgLang->getLanguageName( $nt->getInterwiki()) != ''?$wgLang->getLanguageName( $nt->getInterwiki()) : $l), - 'class' => $wgLang->isRTL() ? 'rtl' : 'ltr'); - } - if(count($language_urls)) { - $tpl->setRef( 'language_urls', &$language_urls); - } else { - $tpl->set('language_urls', false); - } - $tpl->set('personal_urls', $this->buildPersonalUrls()); - $content_actions = $this->buildContentActionUrls(); - $tpl->setRef('content_actions', &$content_actions); - // XXX: attach this from javascript, same with section editing - if(isset($content_actions['edit']['href']) && - !(isset($content_actions['edit']['class']) && $content_actions['edit']['class'] != '') && - $wgUser->getOption("editondblclick") ) - { - $tpl->set('body-ondblclick', 'document.location = "' .$content_actions['edit']['href'] .'";'); - } else { - $tpl->set('body-ondblclick', ''); - } - $tpl->set( "nav_urls", $this->buildNavUrls() ); - - // execute template - $res = $tpl->execute(); - // result may be an error - if (PEAR::isError($res)) { - echo $res->toString(), "\n"; - } else { - echo $res; - } - - } - - # build array of urls for personal toolbar - function buildPersonalUrls() { - /* set up the default links for the personal toolbar */ - global $wgShowIPinHeader; - $personal_urls = array(); - if ($this->loggedin) { - $personal_urls['userpage'] = array( - 'text' => $this->username, - 'href' => $this->makeUrl($this->userpage), - 'ttip' => wfMsg('tooltip-userpage'), - 'akey' => wfMsg('accesskey-userpage') - ); - $personal_urls['mytalk'] = array( - 'text' => wfMsg('mytalk'), - 'href' => $this->makeTalkUrl($this->userpage), - 'ttip' => wfMsg('tooltip-mytalk'), - 'akey' => wfMsg('accesskey-mytalk') - ); - $personal_urls['preferences'] = array( - 'text' => wfMsg('preferences'), - 'href' => $this->makeSpecialUrl('Preferences'), - 'ttip' => wfMsg('tooltip-preferences'), - 'akey' => wfMsg('accesskey-preferences') - ); - $personal_urls['watchlist'] = array( - 'text' => wfMsg('watchlist'), - 'href' => $this->makeSpecialUrl('Watchlist'), - 'ttip' => wfMsg('tooltip-watchlist'), - 'akey' => wfMsg('accesskey-watchlist') - ); - $personal_urls['mycontris'] = array( - 'text' => wfMsg('mycontris'), - 'href' => $this->makeSpecialUrl('Contributions','target=' . $this->username), - 'ttip' => wfMsg('tooltip-mycontris'), - 'akey' => wfMsg('accesskey-mycontris') - ); - $personal_urls['logout'] = array( - 'text' => wfMsg('userlogout'), - 'href' => $this->makeSpecialUrl('Userlogout','returnpage=' . $this->thisurle), - 'ttip' => wfMsg('tooltip-logout'), - 'akey' => wfMsg('accesskey-logout') - ); - } else { - if( $wgShowIPinHeader && isset( $_COOKIE[ini_get("session.name")] ) ) { - $personal_urls['anonuserpage'] = array( - 'text' => $this->username, - 'href' => $this->makeUrl($this->userpage), - 'ttip' => wfMsg('tooltip-anonuserpage'), - 'akey' => wfMsg('accesskey-anonuserpage') - ); - $personal_urls['anontalk'] = array( - 'text' => wfMsg('anontalk'), - 'href' => $this->makeTalkUrl($this->userpage), - 'ttip' => wfMsg('tooltip-anontalk'), - 'akey' => wfMsg('accesskey-anontalk') - ); - $personal_urls['anonlogin'] = array( - 'text' => wfMsg('userlogin'), - 'href' => $this->makeSpecialUrl('Userlogin', 'return='.$this->thisurle), - 'ttip' => wfMsg('tooltip-login'), - 'akey' => wfMsg('accesskey-login') - ); - } else { - - $personal_urls['login'] = array( - 'text' => wfMsg('userlogin'), - 'href' => $this->makeSpecialUrl('Userlogin', 'return='.$this->thisurle), - 'ttip' => wfMsg('tooltip-login'), - 'akey' => wfMsg('accesskey-login') - ); - } - } - - return $personal_urls; + /** + * If using PHPTAL 0.7 on PHP 4.x, return a PHPTAL template object. + * If using PHPTAL 1.0 on PHP 5.x, return a bridge object. + * @return object + * @access private + */ + function &setupTemplate( $file, $repository=false, $cache_dir=false ) { + if( defined( 'NEW_PHPTAL' ) ) { + return new PHPTAL_version_bridge( $file . '.pt', $repository, $cache_dir ); + } else { + return new PHPTAL( $file . '.pt', $repository, $cache_dir ); } - - # an array of edit links by default used for the tabs - function buildContentActionUrls () { - global $wgTitle, $wgUser, $wgRequest; - $action = $wgRequest->getText( 'action' ); - $oldid = $wgRequest->getVal( 'oldid' ); - $diff = $wgRequest->getVal( 'diff' ); - $content_actions = array(); - - $iscontent = ($wgTitle->getNamespace() != Namespace::getSpecial() ); - if( $iscontent) { - - $content_actions['article'] = array('class' => (!Namespace::isTalk( $wgTitle->getNamespace())) ? 'selected' : '', - 'text' => wfMsg('article'), - 'href' => $this->makeArticleUrl($this->thispage), - 'ttip' => wfMsg('tooltip-article'), - 'akey' => wfMsg('accesskey-article')); - - /* set up the classes for the talk link */ - $talk_class = (Namespace::isTalk( $wgTitle->getNamespace()) ? 'selected' : ''); - $talktitle = Title::newFromText( $this->titletxt ); - $talktitle = $talktitle->getTalkPage(); - $this->checkTitle(&$talktitle, &$this->titletxt); - if($talktitle->getArticleId() != 0) { - $content_actions['talk'] = array( - 'class' => $talk_class, - 'text' => wfMsg('talk'), - 'href' => $this->makeTalkUrl($this->titletxt), - 'ttip' => wfMsg('tooltip-talk'), - 'akey' => wfMsg('accesskey-talk') - ); - } else { - $content_actions['talk'] = array( - 'class' => $talk_class.' new', - 'text' => wfMsg('talk'), - 'href' => $this->makeTalkUrl($this->titletxt,'action=edit'), - 'ttip' => wfMsg('tooltip-talk'), - 'akey' => wfMsg('accesskey-talk') - ); - } - - if ( $wgTitle->userCanEdit() ) { - $oid = ( $oldid && ! isset( $diff ) ) ? "&oldid={$oldid}" : ''; - $content_actions['edit'] = array( - 'class' => ($action == 'edit' or $action == 'submit') ? 'selected' : '', - 'text' => wfMsg('edit'), - 'href' => $this->makeUrl($this->thispage, 'action=edit'.$oid), - 'ttip' => wfMsg('tooltip-edit'), - 'akey' => wfMsg('accesskey-edit') - ); - } else { - $oid = ( $oldid && ! isset( $diff ) ) ? "&oldid={$oldid}" : ''; - $content_actions['edit'] = array('class' => ($action == 'edit') ? 'selected' : '', - 'text' => wfMsg('viewsource'), - 'href' => $this->makeUrl($this->thispage, 'action=edit'.$oid), - 'ttip' => wfMsg('tooltip-viewsource'), - 'akey' => wfMsg('accesskey-viewsource')); - } - - if ( $wgTitle->getArticleId() ) { - - $content_actions['history'] = array('class' => ($action == 'history') ? 'selected' : '', - 'text' => wfMsg('history_short'), - 'href' => $this->makeUrl($this->thispage, 'action=history'), - 'ttip' => wfMsg('tooltip-history'), - 'akey' => wfMsg('accesskey-history')); - - # XXX: is there a rollback action anywhere or is it planned? - # Don't recall where i got this from... - /*if( $wgUser->getNewtalk() ) { - $content_actions['rollback'] = array('class' => ($action == 'rollback') ? 'selected' : '', - 'text' => wfMsg('rollback_short'), - 'href' => $this->makeUrl($this->thispage, 'action=rollback'), - 'ttip' => wfMsg('tooltip-rollback'), - 'akey' => wfMsg('accesskey-rollback')); - }*/ - - if($wgUser->isSysop()){ - if(!$wgTitle->isProtected()){ - $content_actions['protect'] = array( - 'class' => ($action == 'protect') ? 'selected' : '', - 'text' => wfMsg('protect'), - 'href' => $this->makeUrl($this->thispage, 'action=protect'), - 'ttip' => wfMsg('tooltip-protect'), - 'akey' => wfMsg('accesskey-protect') - ); - - } else { - $content_actions['unprotect'] = array( - 'class' => ($action == 'unprotect') ? 'selected' : '', - 'text' => wfMsg('unprotect'), - 'href' => $this->makeUrl($this->thispage, 'action=unprotect'), - 'ttip' => wfMsg('tooltip-protect'), - 'akey' => wfMsg('accesskey-protect') - ); - } - $content_actions['delete'] = array( - 'class' => ($action == 'delete') ? 'selected' : '', - 'text' => wfMsg('delete'), - 'href' => $this->makeUrl($this->thispage, 'action=delete'), - 'ttip' => wfMsg('tooltip-delete'), - 'akey' => wfMsg('accesskey-delete') - ); - } - if ( $wgUser->getID() != 0 ) { - if ( $wgTitle->userCanEdit()) { - $content_actions['move'] = array('class' => ($wgTitle->getDbKey() == 'Movepage' and $wgTitle->getNamespace == Namespace::getSpecial()) ? 'selected' : '', - 'text' => wfMsg('move'), - 'href' => $this->makeSpecialUrl('Movepage', 'target='.$this->thispage), - 'ttip' => wfMsg('tooltip-move'), - 'akey' => wfMsg('accesskey-move')); - } else { - $content_actions['move'] = array('class' => 'inactive', - 'text' => wfMsg('move'), - 'href' => false, - 'ttip' => wfMsg('tooltip-nomove'), - 'akey' => false); - - } - } - } else { - //article doesn't exist or is deleted - if($wgUser->isSysop()){ - if( $n = $wgTitle->isDeleted() ) { - $content_actions['delete'] = array( - 'class' => '', - 'text' => wfMsg( "undelete_short", $n ), - 'href' => $this->makeSpecialUrl('Undelete/'.$this->thispage), - 'ttip' => wfMsg('tooltip-undelete', $n), - 'akey' => wfMsg('accesskey-undelete') - ); - } - } - } - - if ( $wgUser->getID() != 0 and $action != 'edit' and $action != 'submit' ) { - if( !$wgTitle->userIsWatching()) { - $content_actions['watch'] = array('class' => ($action == 'watch' or $action == 'unwatch') ? 'selected' : '', - 'text' => wfMsg('watch'), - 'href' => $this->makeUrl($this->thispage, 'action=watch'), - 'ttip' => wfMsg('tooltip-watch'), - 'akey' => wfMsg('accesskey-watch')); - } else { - $content_actions['watch'] = array('class' => ($action == 'unwatch' or $action == 'watch') ? 'selected' : '', - 'text' => wfMsg('unwatch'), - 'href' => $this->makeUrl($this->thispage, 'action=unwatch'), - 'ttip' => wfMsg('tooltip-unwatch'), - 'akey' => wfMsg('accesskey-unwatch')); - - } - } - } else { - /* show special page tab */ - - $content_actions['article'] = array('class' => 'selected', - 'text' => wfMsg('specialpage'), - 'href' => false, - 'ttip' => wfMsg('tooltip-specialpage'), - 'akey' => false); - } - - return $content_actions; - } - - # build array of common navigation links - function buildNavUrls () { - global $wgTitle, $wgUser, $wgRequest; - global $wgSiteSupportPage; - - $action = $wgRequest->getText( 'action' ); - $oldid = $wgRequest->getVal( 'oldid' ); - $diff = $wgRequest->getVal( 'diff' ); - // XXX: remove htmlspecialchars when tal:attributes works with i18n:attributes - $nav_urls = array(); - $nav_urls['mainpage'] = array('href' => htmlspecialchars( $this->makeI18nUrl('mainpage'))); - $nav_urls['randompage'] = array('href' => htmlspecialchars( $this->makeSpecialUrl('Randompage'))); - $nav_urls['recentchanges'] = array('href' => htmlspecialchars( $this->makeSpecialUrl('Recentchanges'))); - $nav_urls['whatlinkshere'] = array('href' => htmlspecialchars( $this->makeSpecialUrl('Whatlinkshere', 'target='.$this->thispage))); - $nav_urls['currentevents'] = (wfMsg('currentevents') != '') ? array('href' => htmlspecialchars( $this->makeI18nUrl('currentevents'))) : ''; - $nav_urls['portal'] = (wfMsg('portal') != '') ? array('href' => htmlspecialchars( $this->makeI18nUrl('portal-url'))) : ''; - $nav_urls['recentchangeslinked'] = array('href' => htmlspecialchars( $this->makeSpecialUrl('Recentchangeslinked', 'target='.$this->thispage))); - $nav_urls['bugreports'] = array('href' => htmlspecialchars( $this->makeI18nUrl('bugreportspage'))); - // $nav_urls['sitesupport'] = array('href' => htmlspecialchars( $this->makeI18nUrl('sitesupportpage'))); - $nav_urls['sitesupport'] = array('href' => htmlspecialchars( $wgSiteSupportPage)); - $nav_urls['help'] = array('href' => htmlspecialchars( $this->makeI18nUrl('helppage'))); - $nav_urls['upload'] = array('href' => htmlspecialchars( $this->makeSpecialUrl('Upload'))); - $nav_urls['specialpages'] = array('href' => htmlspecialchars( $this->makeSpecialUrl('Specialpages'))); - - - $id=User::idFromName($wgTitle->getText()); - $ip=User::isIP($wgTitle->getText()); - - if($id || $ip) { # both anons and non-anons have contri list - $nav_urls['contributions'] = array( - 'href' => htmlspecialchars( $this->makeSpecialUrl('Contributions', "target=" . $wgTitle->getPartialURL() ) ) - ); - } - if ( 0 != $wgUser->getID() ) { # show only to signed in users - if($id) { # can only email non-anons - $nav_urls['emailuser'] = array( - 'href' => htmlspecialchars( $this->makeSpecialUrl('Emailuser', "target=" . $wgTitle->getPartialURL() ) ) - ); - } - } - - - return $nav_urls; - } - - function getPageTitleActionText () { - global $action; - switch($action) { - case 'edit': - return wfMsg('edit'); - case 'history': - return wfMsg('history_short'); - case 'protect': - return wfMsg('unprotect'); - case 'unprotect': - return wfMsg('unprotect'); - case 'delete': - return wfMsg('delete'); - case 'watch': - return wfMsg('watch'); - case 'unwatch': - return wfMsg('unwatch'); - default: - return ''; - } - } - /*static*/ function makeSpecialUrl( $name, $urlaction='' ) { - $title = Title::makeTitle( NS_SPECIAL, $name ); - $this->checkTitle(&$title, &$name); - return $title->getLocalURL( $urlaction ); - } - /*static*/ function makeTalkUrl ( $name, $urlaction='' ) { - $title = Title::newFromText( $name ); - $title = $title->getTalkPage(); - $this->checkTitle(&$title, &$name); - return $title->getLocalURL( $urlaction ); - } - /*static*/ function makeArticleUrl ( $name, $urlaction='' ) { - $title = Title::newFromText( $name ); - $title= $title->getSubjectPage(); - $this->checkTitle(&$title, &$name); - return $title->getLocalURL( $urlaction ); - } - /*static*/ function makeI18nUrl ( $name, $urlaction='' ) { - $title = Title::newFromText( wfMsg($name) ); - $this->checkTitle(&$title, &$name); - return $title->getLocalURL( $urlaction ); - } - /*static*/ function makeUrl ( $name, $urlaction='' ) { - $title = Title::newFromText( $name ); - $this->checkTitle(&$title, &$name); - return $title->getLocalURL( $urlaction ); - } - - # make sure we have some title to operate on, mind the '&' - /*static*/ function checkTitle ( &$title, &$name ) { - if(!is_object($title)) { - $title = Title::newFromText( $name ); - if(!is_object($title)) { - $title = Title::newFromText( '' ); - } - } + } + + /** + * Output the string, or print error message if it's + * an error object of the appropriate type. + * + * @param mixed $str + * @access private + */ + function printOrError( &$str ) { + if( PEAR::isError( $str ) ) { + echo $str->toString(), "\n"; + } else { + echo $str; } - - } - - class SkinDaVinci extends SkinPHPTal { - function initPage( &$out ) { - SkinPHPTal::initPage( $out ); - $this->skinname = "davinci"; +} + +/** + * @todo document + * @package MediaWiki + * @subpackage Skins + */ +class PHPTAL_version_bridge { + function PHPTAL_version_bridge( $file, $repository=false, $cache_dir=false ) { + $this->tpl =& new PHPTAL( $file ); + if( $repository ) { + $this->tpl->setTemplateRepository( $repository ); } } - class SkinMono extends SkinPHPTal { - function initPage( &$out ) { - SkinPHPTal::initPage( $out ); - $this->skinname = "mono"; - } + function set( $name, $value ) { + $this->tpl->$name = $value; } - class SkinMonoBook extends SkinPHPTal { - function initPage( &$out ) { - SkinPHPTal::initPage( $out ); - $this->skinname = "monobook"; - } + function setRef($name, &$value) { + $this->set( $name, $value ); } + function setTranslator( &$t ) { + $this->tpl->setTranslator( $t ); + } + + function execute() { + /* + try { + */ + return $this->tpl->execute(); + /* + } + catch (Exception $e) { + echo "
We caught an exception...\n "; + echo $e; + echo "
"; + } + */ + } +} + +} // end of if( class_exists( 'PHPTAL' ) ) +} // end of if( class_exists( 'PEAR' ) ) +} // end of if( defined( 'MEDIAWIKI' ) ) ?>