diff --git a/inc/parser/action.php b/inc/parser/action.php index 82bebf0aebf97f231a6006c62e648e50beb9f0ba..ed85f5cf96198ddae7a842c7b838981d9676fcd2 100644 --- a/inc/parser/action.php +++ b/inc/parser/action.php @@ -73,6 +73,8 @@ function parse_to_instructions($text){ function render_as_xhtml($instructions){ +#dbg($instructions); + // Create the renderer require_once DOKU_INC . 'inc/parser/xhtml.php'; $Renderer = & new Doku_Renderer_XHTML(); diff --git a/inc/parser/handler.php b/inc/parser/handler.php index 752ba49f7fc4e4a276f03e5bf886637017d7753b..72880736d244bd12aa63c7785f615c5565ff97cc 100644 --- a/inc/parser/handler.php +++ b/inc/parser/handler.php @@ -88,7 +88,7 @@ class Doku_Handler { $markerLen = strlen($iLevels[$level]); $title = substr($match, $markerLen, strlen($match)-($markerLen*2)); - $this->__addCall('header',array($title,$level), $pos); + $this->__addCall('header',array($title,$level,$pos), $pos); $this->meta['section'] = TRUE; return TRUE; } @@ -1353,9 +1353,11 @@ class Doku_Handler_Toc { var $numHeaders = 0; function process($calls) { + #FIXME can this be done better? + global $conf; foreach ( $calls as $call ) { - if ( $call[0] == 'header' && $call[1][1] < 4 ) { + if ( $call[0] == 'header' && $call[1][1] <= $conf['maxtoclevel'] ) { $this->numHeaders++; $this->addToToc($call); } diff --git a/inc/parser/renderer.php b/inc/parser/renderer.php index d6072e0a49c4234a829318d705e866fe71a81bfb..60462a2b49385e49b7816bc09dba3344fa7888b7 100644 --- a/inc/parser/renderer.php +++ b/inc/parser/renderer.php @@ -19,7 +19,7 @@ class Doku_Renderer { function toc_close() {} - function header($text, $level) {} + function header($text, $level, $pos) {} function section_open($level) {} diff --git a/inc/parser/xhtml.php b/inc/parser/xhtml.php index 63bd9a974c8e44f84cd53e837acfcbf8f8bbb202..b66a92ec4b0164ddb18f33b15e4f5a6d3a23c11b 100644 --- a/inc/parser/xhtml.php +++ b/inc/parser/xhtml.php @@ -32,11 +32,15 @@ class Doku_Renderer_XHTML extends Doku_Renderer { var $entities = array(); var $interwiki = array(); + var $lastsec = 0; + function document_start() { ob_start(); } function document_end() { + // add button for last section if any + if($this->lastsec) $this->__secedit($this->lastsec,''); if ( count ($this->footnotes) > 0 ) { echo '<div class="footnotes">'.DOKU_LF; @@ -87,7 +91,16 @@ class Doku_Renderer_XHTML extends Doku_Renderer { echo '</div>'.DOKU_LF.'</div>'.DOKU_LF; } - function header($text, $level) { + function header($text, $level, $pos) { + global $conf; + //handle section editing + if($level <= $conf['maxseclevel']){ + // add button for last section if any + if($this->lastsec) $this->__secedit($this->lastsec,$pos-1); + // remember current position + $this->lastsec = $pos; + } + echo DOKU_LF.'<a name="'.$this->__headerToLink($text).'"></a><h'.$level.'>'; echo $this->__xmlEntities($text); echo "</h$level>".DOKU_LF; @@ -283,8 +296,7 @@ class Doku_Renderer_XHTML extends Doku_Renderer { if ( is_null($language) ) { $this->preformatted($text); } else { - - // Handle with Geshi here (needs tuning) + // Handle with Geshi here FIXME: strip first beginning newline require_once(DOKU_INC . 'inc/geshi.php'); $geshi = new GeSHi($text, strtolower($language), DOKU_INC . 'inc/geshi'); $geshi->enable_classes(); @@ -742,6 +754,13 @@ class Doku_Renderer_XHTML extends Doku_Renderer { function __headerToLink($title) { return preg_replace('/\W/','_',trim($title)); } + + /** + * Adds code for section editing button + */ + function __secedit($f, $t){ + print '<!-- SECTION ['.$f.'-'.$t.'] -->'; + } function __getLinkTitle($title, $default, & $isImage) { $isImage = FALSE; @@ -838,7 +857,7 @@ function interwikiImgExists($name) { * @deprecated -> resolve_pagename should be used */ function wikiPageExists($name) { - +msg("deprecated wikiPageExists called",-1); static $pages = array(); if ( array_key_exists($name,$pages) ) {