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) ) {