You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
155 lines
4.2 KiB
155 lines
4.2 KiB
<?php |
|
|
|
/* |
|
* This file is part of the Symfony package. |
|
* |
|
* (c) Fabien Potencier <fabien@symfony.com> |
|
* |
|
* For the full copyright and license information, please view the LICENSE |
|
* file that was distributed with this source code. |
|
*/ |
|
|
|
namespace Symfony\Component\Console\Output; |
|
|
|
use Symfony\Component\Console\Formatter\OutputFormatter; |
|
use Symfony\Component\Console\Formatter\OutputFormatterInterface; |
|
|
|
/** |
|
* Base class for output classes. |
|
* |
|
* There are five levels of verbosity: |
|
* |
|
* * normal: no option passed (normal output) |
|
* * verbose: -v (more output) |
|
* * very verbose: -vv (highly extended output) |
|
* * debug: -vvv (all debug output) |
|
* * quiet: -q (no output) |
|
* |
|
* @author Fabien Potencier <fabien@symfony.com> |
|
*/ |
|
abstract class Output implements OutputInterface |
|
{ |
|
private int $verbosity; |
|
private OutputFormatterInterface $formatter; |
|
|
|
/** |
|
* @param int|null $verbosity The verbosity level (one of the VERBOSITY constants in OutputInterface) |
|
* @param bool $decorated Whether to decorate messages |
|
* @param OutputFormatterInterface|null $formatter Output formatter instance (null to use default OutputFormatter) |
|
*/ |
|
public function __construct(?int $verbosity = self::VERBOSITY_NORMAL, bool $decorated = false, ?OutputFormatterInterface $formatter = null) |
|
{ |
|
$this->verbosity = $verbosity ?? self::VERBOSITY_NORMAL; |
|
$this->formatter = $formatter ?? new OutputFormatter(); |
|
$this->formatter->setDecorated($decorated); |
|
} |
|
|
|
/** |
|
* @return void |
|
*/ |
|
public function setFormatter(OutputFormatterInterface $formatter) |
|
{ |
|
$this->formatter = $formatter; |
|
} |
|
|
|
public function getFormatter(): OutputFormatterInterface |
|
{ |
|
return $this->formatter; |
|
} |
|
|
|
/** |
|
* @return void |
|
*/ |
|
public function setDecorated(bool $decorated) |
|
{ |
|
$this->formatter->setDecorated($decorated); |
|
} |
|
|
|
public function isDecorated(): bool |
|
{ |
|
return $this->formatter->isDecorated(); |
|
} |
|
|
|
/** |
|
* @return void |
|
*/ |
|
public function setVerbosity(int $level) |
|
{ |
|
$this->verbosity = $level; |
|
} |
|
|
|
public function getVerbosity(): int |
|
{ |
|
return $this->verbosity; |
|
} |
|
|
|
public function isQuiet(): bool |
|
{ |
|
return self::VERBOSITY_QUIET === $this->verbosity; |
|
} |
|
|
|
public function isVerbose(): bool |
|
{ |
|
return self::VERBOSITY_VERBOSE <= $this->verbosity; |
|
} |
|
|
|
public function isVeryVerbose(): bool |
|
{ |
|
return self::VERBOSITY_VERY_VERBOSE <= $this->verbosity; |
|
} |
|
|
|
public function isDebug(): bool |
|
{ |
|
return self::VERBOSITY_DEBUG <= $this->verbosity; |
|
} |
|
|
|
/** |
|
* @return void |
|
*/ |
|
public function writeln(string|iterable $messages, int $options = self::OUTPUT_NORMAL) |
|
{ |
|
$this->write($messages, true, $options); |
|
} |
|
|
|
/** |
|
* @return void |
|
*/ |
|
public function write(string|iterable $messages, bool $newline = false, int $options = self::OUTPUT_NORMAL) |
|
{ |
|
if (!is_iterable($messages)) { |
|
$messages = [$messages]; |
|
} |
|
|
|
$types = self::OUTPUT_NORMAL | self::OUTPUT_RAW | self::OUTPUT_PLAIN; |
|
$type = $types & $options ?: self::OUTPUT_NORMAL; |
|
|
|
$verbosities = self::VERBOSITY_QUIET | self::VERBOSITY_NORMAL | self::VERBOSITY_VERBOSE | self::VERBOSITY_VERY_VERBOSE | self::VERBOSITY_DEBUG; |
|
$verbosity = $verbosities & $options ?: self::VERBOSITY_NORMAL; |
|
|
|
if ($verbosity > $this->getVerbosity()) { |
|
return; |
|
} |
|
|
|
foreach ($messages as $message) { |
|
switch ($type) { |
|
case OutputInterface::OUTPUT_NORMAL: |
|
$message = $this->formatter->format($message); |
|
break; |
|
case OutputInterface::OUTPUT_RAW: |
|
break; |
|
case OutputInterface::OUTPUT_PLAIN: |
|
$message = strip_tags($this->formatter->format($message)); |
|
break; |
|
} |
|
|
|
$this->doWrite($message ?? '', $newline); |
|
} |
|
} |
|
|
|
/** |
|
* Writes a message to the output. |
|
* |
|
* @return void |
|
*/ |
|
abstract protected function doWrite(string $message, bool $newline); |
|
}
|
|
|