*/ if(!defined('DOKU_INC')) define('DOKU_INC',realpath(dirname(__FILE__).'/../../').'/'); if(!defined('DOKU_PLUGIN')) define('DOKU_PLUGIN',DOKU_INC.'lib/plugins/'); require_once(DOKU_PLUGIN.'syntax.php'); /** * All DokuWiki plugins to extend the parser/rendering mechanism * need to inherit from this class */ class syntax_plugin_info extends DokuWiki_Syntax_Plugin { /** * return some info */ function getInfo(){ return array( 'author' => 'Andreas Gohr', 'email' => 'andi@splitbrain.org', 'date' => '2005-06-26', 'name' => 'Info Plugin', 'desc' => 'Displays information about various DokuWiki internals', 'url' => 'http://wiki.splitbrain.org/plugin:info', ); } /** * What kind of syntax are we? */ function getType(){ return 'substition'; } /** * What about paragraphs? */ function getPType(){ return 'block'; } /** * Where to sort in? */ function getSort(){ return 155; } /** * Connect pattern to lexer */ function connectTo($mode) { $this->Lexer->addSpecialPattern('~~INFO:\w+~~',$mode,'plugin_info'); } /** * Handle the match */ function handle($match, $state, $pos, &$handler){ $match = substr($match,7,-2); //strip ~~INFO: from start and ~~ from end return array(strtolower($match)); } /** * Create output */ function render($mode, &$renderer, $data) { if($mode == 'xhtml'){ //handle various info stuff switch ($data[0]){ case 'version': $renderer->doc .= getVersion(); break; case 'syntaxmodes': $renderer->doc .= $this->_syntaxmodes_xhtml(); break; case 'syntaxtypes': $renderer->doc .= $this->_syntaxtypes_xhtml(); break; case 'syntaxplugins': $this->_syntaxplugins_xhtml($renderer); break; default: $renderer->doc .= "no info about ".htmlspecialchars($data[0]); } return true; } return false; } /** * list all installed syntax plugins * * uses some of the original renderer methods */ function _syntaxplugins_xhtml(& $renderer){ global $lang; $renderer->doc .= '
'; $doc .= $mode; $doc .= ' | '; $doc .= ''; $doc .= join(', ',$modes); $doc .= ' | '; $doc .= '