mirror of
				https://github.com/Icinga/icingaweb2.git
				synced 2025-10-26 17:04:15 +01:00 
			
		
		
		
	doc: Support setext-style only headers
Setext-style used to work before too but only if an atx-style header comes first.
This commit is contained in:
		
							parent
							
								
									b54a643c97
								
							
						
					
					
						commit
						b902913220
					
				| @ -3,6 +3,7 @@ | |||||||
| 
 | 
 | ||||||
| namespace Icinga\Module\Doc; | namespace Icinga\Module\Doc; | ||||||
| 
 | 
 | ||||||
|  | use CachingIterator; | ||||||
| use LogicException; | use LogicException; | ||||||
| use SplStack; | use SplStack; | ||||||
| use Icinga\Data\Tree\SimpleTree; | use Icinga\Data\Tree\SimpleTree; | ||||||
| @ -15,6 +16,20 @@ use Icinga\Module\Doc\Exception\DocException; | |||||||
|  */ |  */ | ||||||
| class DocParser | class DocParser | ||||||
| { | { | ||||||
|  |     /** | ||||||
|  |      * Internal identifier for Atx-style headers | ||||||
|  |      * | ||||||
|  |      * @var int | ||||||
|  |      */ | ||||||
|  |     const HEADER_ATX = 1; | ||||||
|  | 
 | ||||||
|  |     /** | ||||||
|  |      * Internal identifier for Setext-style headers | ||||||
|  |      * | ||||||
|  |      * @var int | ||||||
|  |      */ | ||||||
|  |     const HEADER_SETEXT = 2; | ||||||
|  | 
 | ||||||
|     /** |     /** | ||||||
|      * Path to the documentation |      * Path to the documentation | ||||||
|      * |      * | ||||||
| @ -70,11 +85,11 @@ class DocParser | |||||||
|      * Extract atx- or setext-style headers from the given lines |      * Extract atx- or setext-style headers from the given lines | ||||||
|      * |      * | ||||||
|      * @param   string $line |      * @param   string $line | ||||||
|      * @param   string $lastLine |      * @param   string $nextLine | ||||||
|      * |      * | ||||||
|      * @return  array|null An array containing the header and the header level or null if there's nothing to extract |      * @return  array|null An array containing the header and the header level or null if there's nothing to extract | ||||||
|      */ |      */ | ||||||
|     protected function extractHeader($line, $lastLine) |     protected function extractHeader($line, $nextLine) | ||||||
|     { |     { | ||||||
|         if (! $line) { |         if (! $line) { | ||||||
|             return null; |             return null; | ||||||
| @ -90,13 +105,14 @@ class DocParser | |||||||
|             if (! $header) { |             if (! $header) { | ||||||
|                 return null; |                 return null; | ||||||
|             } |             } | ||||||
|  |             $headerStyle = static::HEADER_ATX; | ||||||
|         } elseif ( |         } elseif ( | ||||||
|             $line |             $nextLine | ||||||
|             && ($line[0] === '=' || $line[0] === '-') |             && ($nextLine[0] === '=' || $nextLine[0] === '-') | ||||||
|             && preg_match('/^[=-]+\s*$/', $line, $match) === 1 |             && preg_match('/^[=-]+\s*$/', $nextLine, $match) === 1 | ||||||
|         ) { |         ) { | ||||||
|             // Setext
 |             // Setext
 | ||||||
|             $header = trim($lastLine); |             $header = trim($line); | ||||||
|             if (! $header) { |             if (! $header) { | ||||||
|                 return null; |                 return null; | ||||||
|             } |             } | ||||||
| @ -105,6 +121,7 @@ class DocParser | |||||||
|             } else { |             } else { | ||||||
|                 $level = 2; |                 $level = 2; | ||||||
|             } |             } | ||||||
|  |             $headerStyle = static::HEADER_SETEXT; | ||||||
|         } |         } | ||||||
|         if ($header === null) { |         if ($header === null) { | ||||||
|             return null; |             return null; | ||||||
| @ -117,7 +134,7 @@ class DocParser | |||||||
|         } else { |         } else { | ||||||
|             $id = null; |             $id = null; | ||||||
|         } |         } | ||||||
|         return array($header, $id, $level); |         return array($header, $id, $level, $headerStyle); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /** |     /** | ||||||
| @ -133,10 +150,13 @@ class DocParser | |||||||
|             /** @var $fileInfo \SplFileInfo */ |             /** @var $fileInfo \SplFileInfo */ | ||||||
|             $file = $fileInfo->openFile(); |             $file = $fileInfo->openFile(); | ||||||
|             $lastLine = null; |             $lastLine = null; | ||||||
|             foreach ($file as $line) { |             $cachingIterator = new CachingIterator($file, CachingIterator::TOSTRING_USE_CURRENT); | ||||||
|                 $header = $this->extractHeader($line, $lastLine); |             for ($cachingIterator->rewind(); $line = $cachingIterator->valid(); $cachingIterator->next()) { | ||||||
|  |                 $fileIterator = $cachingIterator->getInnerIterator(); | ||||||
|  |                 $line = $cachingIterator->current(); | ||||||
|  |                 $header = $this->extractHeader($line, $fileIterator->valid() ? $fileIterator->current() : null); | ||||||
|                 if ($header !== null) { |                 if ($header !== null) { | ||||||
|                     list($title, $id, $level) = $header; |                     list($title, $id, $level, $headerStyle) = $header; | ||||||
|                     while (! $stack->isEmpty() && $stack->top()->getLevel() >= $level) { |                     while (! $stack->isEmpty() && $stack->top()->getLevel() >= $level) { | ||||||
|                         $stack->pop(); |                         $stack->pop(); | ||||||
|                     } |                     } | ||||||
| @ -169,14 +189,16 @@ class DocParser | |||||||
|                         $tree->addChild($section, $stack->top()); |                         $tree->addChild($section, $stack->top()); | ||||||
|                     } |                     } | ||||||
|                     $stack->push($section); |                     $stack->push($section); | ||||||
|  |                     if ($headerStyle === static::HEADER_SETEXT) { | ||||||
|  |                         $cachingIterator->next(); | ||||||
|  |                         continue; | ||||||
|  |                     } | ||||||
|                 } else { |                 } else { | ||||||
|                     if ($stack->isEmpty()) { |                     if ($stack->isEmpty()) { | ||||||
|                         throw new LogicException('Heading required'); |                         throw new LogicException('Heading required'); | ||||||
|                     } |                     } | ||||||
|                     $stack->top()->appendContent($line); |                     $stack->top()->appendContent($line); | ||||||
|                 } |                 } | ||||||
|                 // Save last line for setext-style headers
 |  | ||||||
|                 $lastLine = $line; |  | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         return $tree; |         return $tree; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user