1
0
mirror of https://github.com/danog/psalm.git synced 2025-01-05 20:48:45 +01:00
psalm/src/Psalm/Progress/LongProgress.php

106 lines
2.5 KiB
PHP
Raw Normal View History

<?php
namespace Psalm\Progress;
use const PHP_EOL;
use function round;
use function sprintf;
use function str_repeat;
2019-07-05 22:24:00 +02:00
use function strlen;
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-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-06-03 17:20:42 +02:00
$this->print_errors = $print_errors;
$this->print_infos = $print_infos;
}
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");
}
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-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');
} else {
2019-06-03 17:20:42 +02:00
$this->write('E');
}
++$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);
2019-07-05 22:24:00 +02:00
return sprintf(
'%s%s / %s (%s%%)',
str_repeat(' ', $leadingSpaces),
$this->progress,
$this->number_of_tasks,
$percentage
);
}
private function printOverview(): void
{
$this->write($this->getOverview());
}
}