123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110 |
- <?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\Formatter;
- use Symfony\Component\Console\Exception\InvalidArgumentException;
- use Symfony\Contracts\Service\ResetInterface;
- /**
- * @author Jean-François Simon <contact@jfsimon.fr>
- */
- class OutputFormatterStyleStack implements ResetInterface
- {
- /**
- * @var OutputFormatterStyleInterface[]
- */
- private $styles;
- private $emptyStyle;
- public function __construct(OutputFormatterStyleInterface $emptyStyle = null)
- {
- $this->emptyStyle = $emptyStyle ?? new OutputFormatterStyle();
- $this->reset();
- }
- /**
- * Resets stack (ie. empty internal arrays).
- */
- public function reset()
- {
- $this->styles = [];
- }
- /**
- * Pushes a style in the stack.
- */
- public function push(OutputFormatterStyleInterface $style)
- {
- $this->styles[] = $style;
- }
- /**
- * Pops a style from the stack.
- *
- * @return OutputFormatterStyleInterface
- *
- * @throws InvalidArgumentException When style tags incorrectly nested
- */
- public function pop(OutputFormatterStyleInterface $style = null)
- {
- if (empty($this->styles)) {
- return $this->emptyStyle;
- }
- if (null === $style) {
- return array_pop($this->styles);
- }
- foreach (array_reverse($this->styles, true) as $index => $stackedStyle) {
- if ($style->apply('') === $stackedStyle->apply('')) {
- $this->styles = \array_slice($this->styles, 0, $index);
- return $stackedStyle;
- }
- }
- throw new InvalidArgumentException('Incorrectly nested style tag found.');
- }
- /**
- * Computes current style with stacks top codes.
- *
- * @return OutputFormatterStyle
- */
- public function getCurrent()
- {
- if (empty($this->styles)) {
- return $this->emptyStyle;
- }
- return $this->styles[\count($this->styles) - 1];
- }
- /**
- * @return $this
- */
- public function setEmptyStyle(OutputFormatterStyleInterface $emptyStyle)
- {
- $this->emptyStyle = $emptyStyle;
- return $this;
- }
- /**
- * @return OutputFormatterStyleInterface
- */
- public function getEmptyStyle()
- {
- return $this->emptyStyle;
- }
- }
|