check references to PHP files in READMEs

This commit is contained in:
Dominik Liebler
2019-09-12 21:03:12 +02:00
parent e3fd6631b5
commit e41d4321d1
2 changed files with 66 additions and 0 deletions

View File

@@ -25,3 +25,4 @@ script:
- vendor/bin/phpunit
- vendor/bin/phpcs .
- vendor/bin/psalm --show-info=false
- ./check-refs-readmes

65
check-refs-readmes Executable file
View File

@@ -0,0 +1,65 @@
#!/usr/bin/env php
<?php
// checks if all the PHP have been referenced in a README.rst
// and lists all PHP files that have not been referenced
function getFileIterator(string $regex): Generator {
$directory = new RecursiveDirectoryIterator(__DIR__);
$iterator = new RecursiveIteratorIterator($directory);
$iterator = new RegexIterator($iterator, $regex, RecursiveRegexIterator::GET_MATCH);
foreach ($iterator as $list) {
foreach ($list as $file) {
yield $file;
}
}
}
function getFiles($regex) {
$files = [];
foreach (getFileIterator($regex) as $file) {
$vendor = __DIR__ . '/vendor';
if (substr($file, 0, strlen($vendor)) != $vendor && $file != __FILE__) {
$files[] = $file;
}
}
return $files;
}
function getFilesFromReadmes() {
$allFiles = [];
$start = '.. literalinclude::';
foreach (getFiles('/^.+\.rst$/') as $rst) {
$dirName = dirname($rst);
$lines = file($rst);
$lines = array_filter($lines, function (string $line) use ($start): bool {
return substr($line, 0, strlen($start)) == $start;
});
$files = array_map(function (string $line) use ($dirName, $start): string {
return trim($dirName . '/' . substr($line, strlen($start) + 1));
}, $lines);
$allFiles = array_merge($allFiles, (array) $files);
}
return $allFiles;
}
$phpFiles = getFiles('/^.+\.php$/');
$filesFromReadme = getFilesFromReadmes();
$diff = array_diff($phpFiles, $filesFromReadme);
foreach ($diff as $file) {
echo $file . PHP_EOL;
}
if (count($diff) != 0) {
exit(1);
}