9b61957154
- [doc getting-started:installation], or - [doc getting-started:installation Custom link text] - Updated Text_Wiki to 1.2.0 - Documentation should now pass XHTML validator - Formatted DSN section so that it's easier on eyes - The single quotes in <code type='php'> won't work anymore due to the Text_Wiki update. Use double quotes instead: <code type="php">. The single quotes have been converted to double quotes in documentation files. - Modified the links in h1-h6 headings to use the same style as the headings. - Some refactoring
231 lines
6.2 KiB
PHP
231 lines
6.2 KiB
PHP
<?php
|
|
|
|
require_once("highlight.php");
|
|
require_once('Text/Wiki.php');
|
|
|
|
class DocTool
|
|
{
|
|
private $_wiki;
|
|
private $_toc;
|
|
private $_options = array('max-level' => 1,
|
|
'one-page' => false,
|
|
'section' => null,
|
|
'clean-url' => false,
|
|
'base-url' => '');
|
|
private $_lang = array();
|
|
|
|
public function __construct($filename)
|
|
{
|
|
$this->_toc = new Sensei_Doc_Toc($filename);
|
|
|
|
$this->_wiki = Text_Wiki::singleton('Doc');
|
|
$this->_wiki->setParseConf('Doclink', 'toc', $this->_toc);
|
|
$this->_wiki->setRenderConf('xhtml', 'Doclink', 'url_callback', array(&$this, 'makeUrl'));
|
|
}
|
|
|
|
public function getOption($option)
|
|
{
|
|
return $this->_options[$option];
|
|
}
|
|
|
|
public function setOption($option, $value)
|
|
{
|
|
switch ($option) {
|
|
case 'max-level':
|
|
$value = (int) $value;
|
|
break;
|
|
|
|
case 'one-page':
|
|
case 'clean-url':
|
|
$value = (bool) $value;
|
|
break;
|
|
|
|
case 'base-url':
|
|
$value = (string) $value;
|
|
break;
|
|
|
|
case 'section':
|
|
if (! $value instanceof Sensei_Doc_Section) {
|
|
throw new Exception('Value must be an instance of Sensei_Doc_Section.');
|
|
}
|
|
break;
|
|
|
|
default:
|
|
throw new Exception('Unknown option.');
|
|
}
|
|
|
|
$this->_wiki->setRenderConf('xhtml', 'Doclink', 'view_url', $this->getUrlPrefix());
|
|
|
|
$this->_options[$option] = $value;
|
|
}
|
|
|
|
public function renderToc($toc = null)
|
|
{
|
|
if (!$toc) {
|
|
$toc = $this->_toc;
|
|
}
|
|
|
|
$classes = array();
|
|
|
|
if ($toc instanceof Sensei_Doc_Toc) {
|
|
|
|
$class = '';
|
|
if ($this->getOption('one-page')) {
|
|
$class = ' class="one-page"';
|
|
}
|
|
|
|
$classes[] = 'tree';
|
|
|
|
} else {
|
|
|
|
$isParent = false;
|
|
$section = $this->getOption('section');
|
|
|
|
if ($section !== null) {
|
|
$current = $section;
|
|
do {
|
|
if ($current === $toc) {
|
|
$isParent = true;
|
|
break;
|
|
}
|
|
} while (($current = $current->getParent()) !== null);
|
|
}
|
|
|
|
if (! $isParent) {
|
|
$classes[] = 'closed';
|
|
}
|
|
}
|
|
|
|
$classes = implode(' ', $classes);
|
|
|
|
if ($classes === '') {
|
|
echo "<ul>\n";
|
|
} else {
|
|
echo "<ul class=\"$classes\">\n";
|
|
}
|
|
|
|
for ($i = 0; $i < $toc->count(); $i++) {
|
|
$child = $toc->getChild($i);
|
|
|
|
if ($child === $this->getOption('section')) {
|
|
echo '<li class="current">';
|
|
} else {
|
|
echo '<li>';
|
|
}
|
|
|
|
echo '<a href="' . $this->makeUrl($child->getPath()) . '">';
|
|
echo $child->getIndex() . ' ' . $child->getName() . '</a>';
|
|
|
|
if ($child->count() > 0) {
|
|
echo "\n";
|
|
$this->renderToc($child);
|
|
}
|
|
|
|
echo '</li>' . "\n";
|
|
}
|
|
|
|
echo '</ul>' . "\n";
|
|
|
|
}
|
|
|
|
public function getUrlPrefix()
|
|
{
|
|
$prefix = $this->getOption('base-url');
|
|
|
|
if (!$this->getOption('one-page')) {
|
|
if ($this->getOption('clean-url')) {
|
|
$prefix .= 'chapter/';
|
|
} else {
|
|
$prefix .= '?chapter=';
|
|
}
|
|
}
|
|
|
|
return $prefix;
|
|
}
|
|
|
|
public function makeUrl($path)
|
|
{
|
|
$parts = explode(':', $path);
|
|
$firstPath = array_slice($parts, 0, $this->getOption('max-level'));
|
|
|
|
$href = $this->getUrlPrefix() . implode(':', $firstPath);
|
|
|
|
$anchorName = $this->makeAnchor($path);
|
|
if (!empty($anchorName)) {
|
|
$href .= '#' . $anchorName;
|
|
}
|
|
|
|
return $href;
|
|
}
|
|
|
|
public function makeAnchor($path)
|
|
{
|
|
$pathParts = explode(':', $path);
|
|
$anchorParts = array_slice($pathParts, $this->getOption('max-level'));
|
|
$anchorName = implode(':', $anchorParts);
|
|
return $anchorName;
|
|
}
|
|
|
|
public function render()
|
|
{
|
|
if ($this->getOption('one-page')) {
|
|
|
|
for ($i = 0; $i < count($this->_toc); $i++) {
|
|
$this->renderSection($this->_toc->getChild($i));
|
|
}
|
|
|
|
} else {
|
|
$section = $this->getOption('section');
|
|
|
|
if (!$section) {
|
|
throw new Exception('Section has not been set.');
|
|
} else {
|
|
$this->renderSection($section);
|
|
}
|
|
}
|
|
}
|
|
|
|
protected function renderSection($section)
|
|
{
|
|
$level = $section->getLevel();
|
|
$name = $section->getName();
|
|
$index = $section->getIndex();
|
|
|
|
if ($section->getLevel() == 1) {
|
|
echo '<div class="chapter">' . "\n";
|
|
echo "<h$level>Chapter $index ";
|
|
} else {
|
|
echo '<div class="section">' . "\n";
|
|
echo "<h$level>$index ";
|
|
}
|
|
|
|
if ($section->getLevel() > $this->getOption('max-level')) {
|
|
echo '<a href="#'. $this->makeAnchor($section->getPath());
|
|
echo '" id="' . $this->makeAnchor($section->getPath()) . '">';
|
|
echo $name;
|
|
echo '</a>';
|
|
} else {
|
|
echo $name;
|
|
}
|
|
|
|
echo "</h$level>\n";
|
|
|
|
echo $this->_wiki->transform($section->getText());
|
|
|
|
for ($i = 0; $i < count($section); $i++) {
|
|
$this->renderSection($section->getChild($i));
|
|
}
|
|
|
|
echo '</div>' . "\n";
|
|
}
|
|
|
|
public function findByPath($path)
|
|
{
|
|
return $this->_toc->findByPath($path);
|
|
}
|
|
|
|
public function findByIndex($index)
|
|
{
|
|
return $this->_toc->findByIndex($index);
|
|
}
|
|
} |