2019-05-31 00:37:01 +02:00
|
|
|
<?php
|
|
|
|
namespace Psalm\Progress;
|
|
|
|
|
2019-06-26 22:52:29 +02:00
|
|
|
use const PHP_EOL;
|
|
|
|
use function strlen;
|
|
|
|
use function round;
|
|
|
|
use function sprintf;
|
|
|
|
use function str_repeat;
|
|
|
|
|
2019-05-31 00:37:01 +02:00
|
|
|
class LongProgress extends Progress
|
|
|
|
{
|
|
|
|
public const NUMBER_OF_COLUMNS = 60;
|
|
|
|
|
|
|
|
/** @var int|null */
|
|
|
|
protected $number_of_tasks;
|
|
|
|
|
|
|
|
/** @var int */
|
|
|
|
protected $progress = 0;
|
|
|
|
|
|
|
|
/** @var bool */
|
2019-06-03 17:20:42 +02:00
|
|
|
protected $print_errors = false;
|
2019-05-31 00:37:01 +02:00
|
|
|
|
2019-06-03 17:20:42 +02:00
|
|
|
/** @var bool */
|
|
|
|
protected $print_infos = false;
|
|
|
|
|
|
|
|
public function __construct(bool $print_errors = true, bool $print_infos = true)
|
2019-05-31 00:37:01 +02:00
|
|
|
{
|
2019-06-03 17:20:42 +02:00
|
|
|
$this->print_errors = $print_errors;
|
|
|
|
$this->print_infos = $print_infos;
|
2019-05-31 00:37:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public function startScanningFiles(): void
|
|
|
|
{
|
|
|
|
$this->write('Scanning files...' . "\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
public function startAnalyzingFiles(): void
|
|
|
|
{
|
|
|
|
$this->write('Analyzing files...' . "\n\n");
|
|
|
|
}
|
|
|
|
|
2019-06-02 15:59:45 +02:00
|
|
|
public function startAlteringFiles(): void
|
|
|
|
{
|
|
|
|
$this->write('Altering files...' . "\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
public function alterFileDone(string $file_path) : void
|
|
|
|
{
|
|
|
|
$this->write('Altered ' . $file_path . "\n");
|
|
|
|
}
|
|
|
|
|
2019-05-31 00:37:01 +02:00
|
|
|
public function start(int $number_of_tasks): void
|
|
|
|
{
|
|
|
|
$this->number_of_tasks = $number_of_tasks;
|
|
|
|
$this->progress = 0;
|
|
|
|
}
|
|
|
|
|
2019-06-03 17:20:42 +02:00
|
|
|
public function taskDone(int $level): void
|
2019-05-31 00:37:01 +02:00
|
|
|
{
|
2019-06-03 17:20:42 +02:00
|
|
|
if ($level === 0 || ($level === 1 && !$this->print_infos) || !$this->print_errors) {
|
2019-05-31 00:39:13 +02:00
|
|
|
$this->write(self::doesTerminalSupportUtf8() ? '░' : '_');
|
2019-06-03 17:20:42 +02:00
|
|
|
} elseif ($level === 1) {
|
|
|
|
$this->write('I');
|
2019-05-31 00:37:01 +02:00
|
|
|
} else {
|
2019-06-03 17:20:42 +02:00
|
|
|
$this->write('E');
|
2019-05-31 00:37:01 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
++$this->progress;
|
|
|
|
|
|
|
|
if (($this->progress % self::NUMBER_OF_COLUMNS) !== 0) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->printOverview();
|
|
|
|
$this->write(PHP_EOL);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function finish(): void
|
|
|
|
{
|
|
|
|
$this->write(PHP_EOL);
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function getOverview() : string
|
|
|
|
{
|
|
|
|
if ($this->number_of_tasks === null) {
|
|
|
|
throw new \LogicException('Progress::start() should be called before Progress::startDone()');
|
|
|
|
}
|
|
|
|
|
|
|
|
$leadingSpaces = 1 + strlen((string) $this->number_of_tasks) - strlen((string) $this->progress);
|
|
|
|
$percentage = round($this->progress / $this->number_of_tasks * 100);
|
|
|
|
return sprintf(
|
|
|
|
'%s%s / %s (%s%%)',
|
|
|
|
str_repeat(' ', $leadingSpaces),
|
|
|
|
$this->progress,
|
|
|
|
$this->number_of_tasks,
|
|
|
|
$percentage
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
private function printOverview(): void
|
|
|
|
{
|
|
|
|
$this->write($this->getOverview());
|
|
|
|
}
|
|
|
|
}
|