* lang (optional) programming language name that will be passed to syntaxhighlighter. * If not provided, the plugin will use the default syntax highlighting. * Refer to http://code.google.com/p/syntaxhighlighter/wiki/Languages for list of supported languages. * For more languages, please add the .js files contributed by other users. * nogutter (optional) will display no gutter. * nocontrols (optional) will display no controls at the top * collapse (optional) will collapse the block by default * firstline[value] (optional) will begin line count at value. Default value is 1. * showcolumns (optional) will show row columns in the first line. * * The options are passed together with the alias and are separated by a colon : character. e.g *
* ... some code here ... ** * @license LGPL 2 (http://www.gnu.org/licenses/lgpl.html) * @author David Shin
 handler with SyntaxHighigter by Alex Gorbatchev.
                     Syntax: , all configurations are optional.',
        'url'    => 'http://wiki.splitbrain.org/plugin:syntaxhighlighter',
      );
    }
 
    function getType(){ return 'protected';}
    function getSort(){ return 195; }
    function getPType(){ return 'block'; }
 
    /**
     * Connect pattern to lexer
     */
    function connectTo($mode) {       
      $this->Lexer->addEntryPattern('.*?)',$mode,'plugin_syntaxhighlighter_code');
    }
 
    function postConnect() {
      $this->Lexer->addExitPattern('', 'plugin_syntaxhighlighter_code');
    }
 
    /**
     * Handle the match
     */
    function handle($match, $state, $pos, &$handler){
 
        switch ($state) {
            case DOKU_LEXER_ENTER:
                $this->syntax = substr($match, 1);
                return false;
 
            case DOKU_LEXER_UNMATCHED:
                // will include everything from 
                // e.g. ... [lang]:nogutter:nocontrols:collapse:firstline[value]:showcolumns> [content]
                list($attr, $content) = preg_split('/>/u',$match,2);
 
                if ($this->syntax == 'code') {
                    $attr = trim($attr);
                    if ($attr == NULL) {
                        $attr = 'html';
                    }
                } else {
                    $attr = NULL;
                }
 
                return array($this->syntax, $attr, $content);
        }       
        return false;
    }
    /**
     * Create output
     */
    function render($mode, &$renderer, $data) {
 
      if($mode == 'xhtml'){
        if (count($data) == 3) {
 
            list($syntax, $attr, $content) = $data;
            if ($syntax == 'code') 
                $renderer->doc .= "".$renderer->_xmlEntities($content)."
";
            else 
                $renderer->file($content);
        }
        return true;
      }
      return false;
    }
}