Commit 59825446 by Carsten Brandt

finished render command, added cli script

parent 81aea730
#!/usr/bin/env php
<?php
/**
* Yii Framework 2.0 API documentation generator
*
* @link http://www.yiiframework.com/
* @copyright Copyright (c) 2008 Yii Software LLC
* @license http://www.yiiframework.com/license/
*/
defined('YII_DEBUG') or define('YII_DEBUG', false);
$composerAutoload = [
__DIR__ . '/vendor/autoload.php', // standalone with "composer install" run
__DIR__ . '/../../../../autoload.php', // script is installed as a composer binary
];
foreach($composerAutoload as $autoload) {
if (file_exists($autoload)) {
require($autoload);
break;
}
}
$yiiDirs = [
__DIR__ . '/../../../framework', // in yii2-dev repo
__DIR__ . '/vendor/yiisoft/yii2', // standalone with "composer install" run
__DIR__ . '/../../../../yiisoft/yii2', // script is installed as a composer binary
];
foreach($yiiDirs as $dir) {
if (file_exists($dir . '/yii/Yii.php')) {
require($dir . '/yii/Yii.php');
break;
}
}
if (!class_exists('Yii')) {
echo "\nThe Yii Framework 2.0 does not seem to be installed. Try running composer install.\n\n";
exit(1);
}
Yii::setAlias('@yii/apidoc', __DIR__);
$application = new yii\console\Application([
'id' => 'yii2-apidoc',
'basePath' => __DIR__,
'enableCoreCommands' => false,
'controllerNamespace' => 'yii\\apidoc\\commands',
'controllerPath' => '@yii/apidoc/commands',
]);
$exitCode = $application->run();
exit($exitCode);
@echo off
rem -------------------------------------------------------------
rem Yii command line bootstrap script for Windows.
rem
rem @author Qiang Xue <qiang.xue@gmail.com>
rem @link http://www.yiiframework.com/
rem @copyright Copyright &copy; 2012 Yii Software LLC
rem @license http://www.yiiframework.com/license/
rem -------------------------------------------------------------
@setlocal
set YII_PATH=%~dp0
if "%PHP_COMMAND%" == "" set PHP_COMMAND=php.exe
"%PHP_COMMAND%" "%YII_PATH%apidoc" %*
@endlocal
...@@ -16,30 +16,59 @@ use yii\apidoc\models\Context; ...@@ -16,30 +16,59 @@ use yii\apidoc\models\Context;
use Yii; use Yii;
/** /**
* Command to render API Documentation files
* *
* @author Carsten Brandt <mail@cebe.cc> * @author Carsten Brandt <mail@cebe.cc>
* @since 2.0 * @since 2.0
*/ */
class PhpdocController extends Controller class RenderController extends Controller
{ {
public function actionIndex($targetDir) /**
* Renders API documentation files
* @param array $sourceDirs
* @param string $targetDir
* @return int
*/
public function actionIndex(array $sourceDirs, $targetDir)
{ {
echo "hi\n";
$targetDir = Yii::getAlias($targetDir); $targetDir = Yii::getAlias($targetDir);
if (is_dir($targetDir) && !$this->confirm('TargetDirectory already exists. Overwrite?')) { if (is_dir($targetDir) && !$this->confirm('TargetDirectory already exists. Overwrite?')) {
return 2; return 2;
} }
if (!is_dir($targetDir)) {
mkdir($targetDir);
}
// TODO determine files to analyze
$this->stdout('Searching files to process... '); $this->stdout('Searching files to process... ');
$files = $this->findFiles(YII_PATH); $files = [];
// $files = array_slice($files, 0, 42); // TODO remove this line foreach($sourceDirs as $source) {
foreach($this->findFiles($source) as $fileName) {
$files[$fileName] = $fileName;
}
}
$this->stdout('done.' . PHP_EOL, Console::FG_GREEN); $this->stdout('done.' . PHP_EOL, Console::FG_GREEN);
$context = new Context();
$cacheFile = $targetDir . '/cache/' . md5(serialize($files)) . '.tmp';
if (file_exists($cacheFile)) {
$this->stdout('Loading processed data from cache... ');
$context = unserialize(file_get_contents($cacheFile));
$this->stdout('done.' . PHP_EOL, Console::FG_GREEN);
$this->stdout('Checking for updated files... ');
foreach($context->files as $file => $sha) {
if (sha1_file($file) === $sha) {
unset($files[$file]);
}
}
$this->stdout('done.' . PHP_EOL, Console::FG_GREEN);
}
$fileCount = count($files); $fileCount = count($files);
$this->stdout($fileCount . ' file' . ($fileCount == 1 ? '' : 's') . ' to update.' . PHP_EOL);
Console::startProgress(0, $fileCount, 'Processing files... ', false); Console::startProgress(0, $fileCount, 'Processing files... ', false);
$context = new Context();
$done = 0; $done = 0;
foreach($files as $file) { foreach($files as $file) {
$context->addFile($file); $context->addFile($file);
...@@ -48,20 +77,22 @@ class PhpdocController extends Controller ...@@ -48,20 +77,22 @@ class PhpdocController extends Controller
Console::endProgress(true); Console::endProgress(true);
$this->stdout('done.' . PHP_EOL, Console::FG_GREEN); $this->stdout('done.' . PHP_EOL, Console::FG_GREEN);
// save processed data to cache
if (!is_dir(dirname($cacheFile))) {
mkdir(dirname($cacheFile));
}
file_put_contents($cacheFile, serialize($context));
$this->stdout('Updating cross references and backlinks... '); $this->stdout('Updating cross references and backlinks... ');
$context->updateReferences(); $context->updateReferences();
$this->stdout('done.' . PHP_EOL, Console::FG_GREEN); $this->stdout('done.' . PHP_EOL, Console::FG_GREEN);
// render models
// TODO LATER analyze for dead links and similar stuff
// TODO render models
$renderer = new OfflineRenderer(); $renderer = new OfflineRenderer();
$renderer->targetDir = $targetDir; $renderer->targetDir = $targetDir;
$renderer->render($context, $this); $renderer->render($context, $this);
} }
protected function findFiles($path, $except = []) protected function findFiles($path, $except = [])
{ {
$path = FileHelper::normalizePath($path); $path = FileHelper::normalizePath($path);
...@@ -84,5 +115,4 @@ class PhpdocController extends Controller ...@@ -84,5 +115,4 @@ class PhpdocController extends Controller
]; ];
return FileHelper::findFiles($path, $options); return FileHelper::findFiles($path, $options);
} }
} }
\ No newline at end of file
...@@ -25,5 +25,6 @@ ...@@ -25,5 +25,6 @@
"autoload": { "autoload": {
"psr-0": { "yii\\apidoc\\": "" } "psr-0": { "yii\\apidoc\\": "" }
}, },
"target-dir": "yii/apidoc" "target-dir": "yii/apidoc",
"bin": ["apidoc"]
} }
...@@ -47,10 +47,7 @@ class Context extends Component ...@@ -47,10 +47,7 @@ class Context extends Component
public function addFile($fileName) public function addFile($fileName)
{ {
if (isset($this->files[$fileName])) { $this->files[$fileName] = sha1_file($fileName);
return;
}
$this->files[$fileName] = $fileName;
$reflection = new FileReflector($fileName, true); $reflection = new FileReflector($fileName, true);
$reflection->process(); $reflection->process();
...@@ -58,54 +55,18 @@ class Context extends Component ...@@ -58,54 +55,18 @@ class Context extends Component
foreach($reflection->getClasses() as $class) { foreach($reflection->getClasses() as $class) {
$class = new ClassDoc($class); $class = new ClassDoc($class);
$class->sourceFile = $fileName; $class->sourceFile = $fileName;
$this->addClass($class); $this->classes[$class->name] = $class;
} }
foreach($reflection->getInterfaces() as $interface) { foreach($reflection->getInterfaces() as $interface) {
$interface = new InterfaceDoc($interface); $interface = new InterfaceDoc($interface);
$interface->sourceFile = $fileName; $interface->sourceFile = $fileName;
$this->addInterface($interface); $this->interfaces[$interface->name] = $interface;
} }
foreach($reflection->getTraits() as $trait) { foreach($reflection->getTraits() as $trait) {
$trait = new TraitDoc($trait); $trait = new TraitDoc($trait);
$trait->sourceFile = $fileName; $trait->sourceFile = $fileName;
$this->addTrait($trait); $this->traits[$trait->name] = $trait;
}
}
/**
* @param ClassDoc $class
* @throws \yii\base\Exception when class is already part of this context
*/
public function addClass($class)
{
if (isset($this->classes[$class->name])) {
throw new Exception('Duplicate class definition: ' . $class->name . ' in file ' . $class->sourceFile . '.');
}
$this->classes[$class->name] = $class;
}
/**
* @param InterfaceDoc $interface
* @throws \yii\base\Exception when interface is already part of this context
*/
public function addInterface($interface)
{
if (isset($this->interfaces[$interface->name])) {
throw new Exception('Duplicate interface definition: ' . $interface->name . ' in file ' . $interface->sourceFile);
}
$this->interfaces[$interface->name] = $interface;
}
/**
* @param TraitDoc $trait
* @throws \yii\base\Exception when trait is already part of this context
*/
public function addTrait($trait)
{
if (isset($this->traits[$trait->name])) {
throw new Exception('Duplicate trait definition: ' . $trait->name . ' in file ' . $trait->sourceFile);
} }
$this->traits[$trait->name] = $trait;
} }
public function updateReferences() public function updateReferences()
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment