*/
// must be run within Dokuwiki
if (!defined('DOKU_INC')) {
die();
}
class syntax_plugin_htmldetailstag_summary extends DokuWiki_Syntax_Plugin
{
/**
* @return string Syntax mode type
*/
public function getType()
{
return 'container';
}
/**
* @return string|array(string) Allowed syntax mode types
*/
public function getAllowedTypes()
{
return array('container', 'baseonly', 'formatting', 'substition', 'protected', 'disabled', 'paragraphs');
}
/**
* @return string Paragraph type
*/
public function getPType()
{
return 'block';
}
/**
* @return int Sort order - Low numbers go before high numbers
*/
public function getSort()
{
return 195; // cf. Doku_Parser_Mode_html 190
}
/**
* Connect lookup pattern to lexer.
*
* @param string $mode Parser mode
*/
public function connectTo($mode)
{
$this->Lexer->addEntryPattern('(?=.*?)', $mode, 'plugin_htmldetailstag_summary');
}
public function postConnect()
{
$this->Lexer->addExitPattern('', 'plugin_htmldetailstag_summary');
}
/**
* Handle matches of the htmldetailstag syntax
*
* @param string $match The match of the syntax
* @param int $state The state of the handler
* @param int $pos The position in the document
* @param Doku_Handler $handler The handler
*
* @return array Data for the renderer
*/
public function handle($match, $state, $pos, Doku_Handler $handler)
{
$data = array($match, $state);
return $data;
}
/**
* Render xhtml output or metadata
*
* @param string $mode Renderer mode (supported modes: xhtml)
* @param Doku_Renderer $renderer The renderer
* @param array $data The data from the handler() function
*
* @return bool If rendering was successful.
*/
public function render($mode, Doku_Renderer $renderer, $data)
{
if ($mode !== 'xhtml') {
return false;
}
list($match, $state) = $data;
switch ($state) {
case DOKU_LEXER_ENTER:
$renderer->doc .= "";
break;
case DOKU_LEXER_UNMATCHED:
$renderer->doc .= $renderer->_xmlEntities($match);
break;
case DOKU_LEXER_EXIT:
$renderer->doc .= "";
break;
}
return true;
}
}