bin/generate-document generates function-list-by-*

This commit is contained in:
池下克彦 2020-02-21 14:56:43 +09:00
parent b98c19ca28
commit e11202168f
2 changed files with 116 additions and 0 deletions

14
bin/generate-document Executable file
View File

@ -0,0 +1,14 @@
#!/usr/bin/env php
<?php
use PhpOffice\PhpSpreadsheet\DocumentGenerator;
require_once __DIR__ . '/../src/Bootstrap.php';
try {
DocumentGenerator::generateFunctionListByCategory();
DocumentGenerator::generateFunctionListByName();
} catch (ReflectionException $e) {
fwrite(STDERR, (string)$e);
exit(1);
}

View File

@ -0,0 +1,102 @@
<?php
namespace PhpOffice\PhpSpreadsheet;
use PhpOffice\PhpSpreadsheet\Calculation\Calculation;
use PhpOffice\PhpSpreadsheet\Calculation\Category;
use PhpOffice\PhpSpreadsheet\Calculation\Functions;
use ReflectionClass;
use ReflectionException;
use UnexpectedValueException;
class DocumentGenerator {
/**
* @throws ReflectionException
*/
public static function generateFunctionListByCategory(): void {
ob_start();
try {
echo "# Function list by category\n";
$phpSpreadsheetFunctions = self::getPhpSpreadsheetFunctions();
foreach (self::getCategories() as $categoryConstant => $category) {
echo "\n";
echo "## {$categoryConstant}\n";
echo "\n";
echo "Excel Function | PhpSpreadsheet Function\n";
echo "--------------------|-------------------------------------------\n";
foreach ($phpSpreadsheetFunctions as $function => $functionInfo) {
if ($category === $functionInfo['category']) {
echo str_pad($function, 20)
. '| ' . self::getPhpSpreadsheetFunctionText($functionInfo['functionCall']) . "\n";
}
}
}
} finally {
file_put_contents(__DIR__ . '/../../docs/references/function-list-by-category.md', ob_get_clean());
}
}
/**
* @return mixed
* @throws ReflectionException
*/
private static function getPhpSpreadsheetFunctions() {
$phpSpreadsheetFunctionsProperty = (new ReflectionClass(Calculation::class))->getProperty('phpSpreadsheetFunctions');
$phpSpreadsheetFunctionsProperty->setAccessible(true);
$phpSpreadsheetFunctions = $phpSpreadsheetFunctionsProperty->getValue();
ksort($phpSpreadsheetFunctions);
return $phpSpreadsheetFunctions;
}
/**
* @return array
* @throws ReflectionException
*/
private static function getCategories(): array {
return (new ReflectionClass(Category::class))->getConstants();
}
private static function getPhpSpreadsheetFunctionText($functionCall): string {
if (is_string($functionCall)) {
return $functionCall;
}
if ($functionCall === [Functions::class, 'DUMMY']) {
return '**Not yet Implemented**';
}
if (is_array($functionCall)) {
return "\\{$functionCall[0]}::{$functionCall[1]}";
}
throw new UnexpectedValueException('$functionCall is of type ' . gettype($functionCall) . '. string or array expected');
}
/**
* @throws ReflectionException
*/
public static function generateFunctionListByName(): void {
$categoryConstants = array_flip(self::getCategories());
ob_start();
try {
echo "# Function list by name\n";
$phpSpreadsheetFunctions = self::getPhpSpreadsheetFunctions();
$lastAlphabet = null;
foreach ($phpSpreadsheetFunctions as $function => $functionInfo) {
if ($lastAlphabet !== $function[0]) {
$lastAlphabet = $function[0];
echo "\n";
echo "## {$lastAlphabet}\n";
echo "\n";
echo "Excel Function | Category | PhpSpreadsheet Function\n";
echo "--------------------|--------------------------------|-------------------------------------------\n";
}
echo str_pad($function, 20)
. '| ' . str_pad($categoryConstants[$functionInfo['category']], 31)
. '| ' . self::getPhpSpreadsheetFunctionText($functionInfo['functionCall'])
. "\n";
}
} finally {
file_put_contents(__DIR__ . '/../../docs/references/function-list-by-name.md', ob_get_clean());
}
}
}