first commit
This commit is contained in:
		
							
								
								
									
										282
									
								
								vendor/symfony/console/Formatter/OutputFormatter.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										282
									
								
								vendor/symfony/console/Formatter/OutputFormatter.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,282 @@ | ||||
| <?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; | ||||
|  | ||||
| /** | ||||
|  * Formatter class for console output. | ||||
|  * | ||||
|  * @author Konstantin Kudryashov <ever.zet@gmail.com> | ||||
|  * @author Roland Franssen <franssen.roland@gmail.com> | ||||
|  */ | ||||
| class OutputFormatter implements WrappableOutputFormatterInterface | ||||
| { | ||||
|     private $decorated; | ||||
|     private $styles = []; | ||||
|     private $styleStack; | ||||
|  | ||||
|     /** | ||||
|      * Escapes "<" special char in given text. | ||||
|      * | ||||
|      * @param string $text Text to escape | ||||
|      * | ||||
|      * @return string Escaped text | ||||
|      */ | ||||
|     public static function escape($text) | ||||
|     { | ||||
|         $text = preg_replace('/([^\\\\]?)</', '$1\\<', $text); | ||||
|  | ||||
|         return self::escapeTrailingBackslash($text); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Escapes trailing "\" in given text. | ||||
|      * | ||||
|      * @param string $text Text to escape | ||||
|      * | ||||
|      * @return string Escaped text | ||||
|      * | ||||
|      * @internal | ||||
|      */ | ||||
|     public static function escapeTrailingBackslash($text) | ||||
|     { | ||||
|         if ('\\' === substr($text, -1)) { | ||||
|             $len = \strlen($text); | ||||
|             $text = rtrim($text, '\\'); | ||||
|             $text = str_replace("\0", '', $text); | ||||
|             $text .= str_repeat("\0", $len - \strlen($text)); | ||||
|         } | ||||
|  | ||||
|         return $text; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Initializes console output formatter. | ||||
|      * | ||||
|      * @param bool                            $decorated Whether this formatter should actually decorate strings | ||||
|      * @param OutputFormatterStyleInterface[] $styles    Array of "name => FormatterStyle" instances | ||||
|      */ | ||||
|     public function __construct(bool $decorated = false, array $styles = []) | ||||
|     { | ||||
|         $this->decorated = $decorated; | ||||
|  | ||||
|         $this->setStyle('error', new OutputFormatterStyle('white', 'red')); | ||||
|         $this->setStyle('info', new OutputFormatterStyle('green')); | ||||
|         $this->setStyle('comment', new OutputFormatterStyle('yellow')); | ||||
|         $this->setStyle('question', new OutputFormatterStyle('black', 'cyan')); | ||||
|  | ||||
|         foreach ($styles as $name => $style) { | ||||
|             $this->setStyle($name, $style); | ||||
|         } | ||||
|  | ||||
|         $this->styleStack = new OutputFormatterStyleStack(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function setDecorated($decorated) | ||||
|     { | ||||
|         $this->decorated = (bool) $decorated; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function isDecorated() | ||||
|     { | ||||
|         return $this->decorated; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function setStyle($name, OutputFormatterStyleInterface $style) | ||||
|     { | ||||
|         $this->styles[strtolower($name)] = $style; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function hasStyle($name) | ||||
|     { | ||||
|         return isset($this->styles[strtolower($name)]); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function getStyle($name) | ||||
|     { | ||||
|         if (!$this->hasStyle($name)) { | ||||
|             throw new InvalidArgumentException(sprintf('Undefined style: %s', $name)); | ||||
|         } | ||||
|  | ||||
|         return $this->styles[strtolower($name)]; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function format($message) | ||||
|     { | ||||
|         return $this->formatAndWrap((string) $message, 0); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function formatAndWrap(string $message, int $width) | ||||
|     { | ||||
|         $offset = 0; | ||||
|         $output = ''; | ||||
|         $tagRegex = '[a-z][a-z0-9,_=;-]*+'; | ||||
|         $currentLineLength = 0; | ||||
|         preg_match_all("#<(($tagRegex) | /($tagRegex)?)>#ix", $message, $matches, PREG_OFFSET_CAPTURE); | ||||
|         foreach ($matches[0] as $i => $match) { | ||||
|             $pos = $match[1]; | ||||
|             $text = $match[0]; | ||||
|  | ||||
|             if (0 != $pos && '\\' == $message[$pos - 1]) { | ||||
|                 continue; | ||||
|             } | ||||
|  | ||||
|             // add the text up to the next tag | ||||
|             $output .= $this->applyCurrentStyle(substr($message, $offset, $pos - $offset), $output, $width, $currentLineLength); | ||||
|             $offset = $pos + \strlen($text); | ||||
|  | ||||
|             // opening tag? | ||||
|             if ($open = '/' != $text[1]) { | ||||
|                 $tag = $matches[1][$i][0]; | ||||
|             } else { | ||||
|                 $tag = isset($matches[3][$i][0]) ? $matches[3][$i][0] : ''; | ||||
|             } | ||||
|  | ||||
|             if (!$open && !$tag) { | ||||
|                 // </> | ||||
|                 $this->styleStack->pop(); | ||||
|             } elseif (false === $style = $this->createStyleFromString($tag)) { | ||||
|                 $output .= $this->applyCurrentStyle($text, $output, $width, $currentLineLength); | ||||
|             } elseif ($open) { | ||||
|                 $this->styleStack->push($style); | ||||
|             } else { | ||||
|                 $this->styleStack->pop($style); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         $output .= $this->applyCurrentStyle(substr($message, $offset), $output, $width, $currentLineLength); | ||||
|  | ||||
|         if (false !== strpos($output, "\0")) { | ||||
|             return strtr($output, ["\0" => '\\', '\\<' => '<']); | ||||
|         } | ||||
|  | ||||
|         return str_replace('\\<', '<', $output); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * @return OutputFormatterStyleStack | ||||
|      */ | ||||
|     public function getStyleStack() | ||||
|     { | ||||
|         return $this->styleStack; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Tries to create new style instance from string. | ||||
|      * | ||||
|      * @return OutputFormatterStyle|false False if string is not format string | ||||
|      */ | ||||
|     private function createStyleFromString(string $string) | ||||
|     { | ||||
|         if (isset($this->styles[$string])) { | ||||
|             return $this->styles[$string]; | ||||
|         } | ||||
|  | ||||
|         if (!preg_match_all('/([^=]+)=([^;]+)(;|$)/', $string, $matches, PREG_SET_ORDER)) { | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         $style = new OutputFormatterStyle(); | ||||
|         foreach ($matches as $match) { | ||||
|             array_shift($match); | ||||
|             $match[0] = strtolower($match[0]); | ||||
|  | ||||
|             if ('fg' == $match[0]) { | ||||
|                 $style->setForeground(strtolower($match[1])); | ||||
|             } elseif ('bg' == $match[0]) { | ||||
|                 $style->setBackground(strtolower($match[1])); | ||||
|             } elseif ('options' === $match[0]) { | ||||
|                 preg_match_all('([^,;]+)', strtolower($match[1]), $options); | ||||
|                 $options = array_shift($options); | ||||
|                 foreach ($options as $option) { | ||||
|                     $style->setOption($option); | ||||
|                 } | ||||
|             } else { | ||||
|                 return false; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $style; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Applies current style from stack to text, if must be applied. | ||||
|      */ | ||||
|     private function applyCurrentStyle(string $text, string $current, int $width, int &$currentLineLength): string | ||||
|     { | ||||
|         if ('' === $text) { | ||||
|             return ''; | ||||
|         } | ||||
|  | ||||
|         if (!$width) { | ||||
|             return $this->isDecorated() ? $this->styleStack->getCurrent()->apply($text) : $text; | ||||
|         } | ||||
|  | ||||
|         if (!$currentLineLength && '' !== $current) { | ||||
|             $text = ltrim($text); | ||||
|         } | ||||
|  | ||||
|         if ($currentLineLength) { | ||||
|             $prefix = substr($text, 0, $i = $width - $currentLineLength)."\n"; | ||||
|             $text = substr($text, $i); | ||||
|         } else { | ||||
|             $prefix = ''; | ||||
|         } | ||||
|  | ||||
|         preg_match('~(\\n)$~', $text, $matches); | ||||
|         $text = $prefix.preg_replace('~([^\\n]{'.$width.'})\\ *~', "\$1\n", $text); | ||||
|         $text = rtrim($text, "\n").($matches[1] ?? ''); | ||||
|  | ||||
|         if (!$currentLineLength && '' !== $current && "\n" !== substr($current, -1)) { | ||||
|             $text = "\n".$text; | ||||
|         } | ||||
|  | ||||
|         $lines = explode("\n", $text); | ||||
|  | ||||
|         foreach ($lines as $line) { | ||||
|             $currentLineLength += \strlen($line); | ||||
|             if ($width <= $currentLineLength) { | ||||
|                 $currentLineLength = 0; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if ($this->isDecorated()) { | ||||
|             foreach ($lines as $i => $line) { | ||||
|                 $lines[$i] = $this->styleStack->getCurrent()->apply($line); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return implode("\n", $lines); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										71
									
								
								vendor/symfony/console/Formatter/OutputFormatterInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										71
									
								
								vendor/symfony/console/Formatter/OutputFormatterInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,71 @@ | ||||
| <?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; | ||||
|  | ||||
| /** | ||||
|  * Formatter interface for console output. | ||||
|  * | ||||
|  * @author Konstantin Kudryashov <ever.zet@gmail.com> | ||||
|  */ | ||||
| interface OutputFormatterInterface | ||||
| { | ||||
|     /** | ||||
|      * Sets the decorated flag. | ||||
|      * | ||||
|      * @param bool $decorated Whether to decorate the messages or not | ||||
|      */ | ||||
|     public function setDecorated($decorated); | ||||
|  | ||||
|     /** | ||||
|      * Gets the decorated flag. | ||||
|      * | ||||
|      * @return bool true if the output will decorate messages, false otherwise | ||||
|      */ | ||||
|     public function isDecorated(); | ||||
|  | ||||
|     /** | ||||
|      * Sets a new style. | ||||
|      * | ||||
|      * @param string                        $name  The style name | ||||
|      * @param OutputFormatterStyleInterface $style The style instance | ||||
|      */ | ||||
|     public function setStyle($name, OutputFormatterStyleInterface $style); | ||||
|  | ||||
|     /** | ||||
|      * Checks if output formatter has style with specified name. | ||||
|      * | ||||
|      * @param string $name | ||||
|      * | ||||
|      * @return bool | ||||
|      */ | ||||
|     public function hasStyle($name); | ||||
|  | ||||
|     /** | ||||
|      * Gets style options from style with specified name. | ||||
|      * | ||||
|      * @param string $name | ||||
|      * | ||||
|      * @return OutputFormatterStyleInterface | ||||
|      * | ||||
|      * @throws \InvalidArgumentException When style isn't defined | ||||
|      */ | ||||
|     public function getStyle($name); | ||||
|  | ||||
|     /** | ||||
|      * Formats a message according to the given styles. | ||||
|      * | ||||
|      * @param string $message The message to style | ||||
|      * | ||||
|      * @return string The styled message | ||||
|      */ | ||||
|     public function format($message); | ||||
| } | ||||
							
								
								
									
										183
									
								
								vendor/symfony/console/Formatter/OutputFormatterStyle.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										183
									
								
								vendor/symfony/console/Formatter/OutputFormatterStyle.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,183 @@ | ||||
| <?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; | ||||
|  | ||||
| /** | ||||
|  * Formatter style class for defining styles. | ||||
|  * | ||||
|  * @author Konstantin Kudryashov <ever.zet@gmail.com> | ||||
|  */ | ||||
| class OutputFormatterStyle implements OutputFormatterStyleInterface | ||||
| { | ||||
|     private static $availableForegroundColors = [ | ||||
|         'black' => ['set' => 30, 'unset' => 39], | ||||
|         'red' => ['set' => 31, 'unset' => 39], | ||||
|         'green' => ['set' => 32, 'unset' => 39], | ||||
|         'yellow' => ['set' => 33, 'unset' => 39], | ||||
|         'blue' => ['set' => 34, 'unset' => 39], | ||||
|         'magenta' => ['set' => 35, 'unset' => 39], | ||||
|         'cyan' => ['set' => 36, 'unset' => 39], | ||||
|         'white' => ['set' => 37, 'unset' => 39], | ||||
|         'default' => ['set' => 39, 'unset' => 39], | ||||
|     ]; | ||||
|     private static $availableBackgroundColors = [ | ||||
|         'black' => ['set' => 40, 'unset' => 49], | ||||
|         'red' => ['set' => 41, 'unset' => 49], | ||||
|         'green' => ['set' => 42, 'unset' => 49], | ||||
|         'yellow' => ['set' => 43, 'unset' => 49], | ||||
|         'blue' => ['set' => 44, 'unset' => 49], | ||||
|         'magenta' => ['set' => 45, 'unset' => 49], | ||||
|         'cyan' => ['set' => 46, 'unset' => 49], | ||||
|         'white' => ['set' => 47, 'unset' => 49], | ||||
|         'default' => ['set' => 49, 'unset' => 49], | ||||
|     ]; | ||||
|     private static $availableOptions = [ | ||||
|         'bold' => ['set' => 1, 'unset' => 22], | ||||
|         'underscore' => ['set' => 4, 'unset' => 24], | ||||
|         'blink' => ['set' => 5, 'unset' => 25], | ||||
|         'reverse' => ['set' => 7, 'unset' => 27], | ||||
|         'conceal' => ['set' => 8, 'unset' => 28], | ||||
|     ]; | ||||
|  | ||||
|     private $foreground; | ||||
|     private $background; | ||||
|     private $options = []; | ||||
|  | ||||
|     /** | ||||
|      * Initializes output formatter style. | ||||
|      * | ||||
|      * @param string|null $foreground The style foreground color name | ||||
|      * @param string|null $background The style background color name | ||||
|      * @param array       $options    The style options | ||||
|      */ | ||||
|     public function __construct(string $foreground = null, string $background = null, array $options = []) | ||||
|     { | ||||
|         if (null !== $foreground) { | ||||
|             $this->setForeground($foreground); | ||||
|         } | ||||
|         if (null !== $background) { | ||||
|             $this->setBackground($background); | ||||
|         } | ||||
|         if (\count($options)) { | ||||
|             $this->setOptions($options); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function setForeground($color = null) | ||||
|     { | ||||
|         if (null === $color) { | ||||
|             $this->foreground = null; | ||||
|  | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         if (!isset(static::$availableForegroundColors[$color])) { | ||||
|             throw new InvalidArgumentException(sprintf('Invalid foreground color specified: "%s". Expected one of (%s)', $color, implode(', ', array_keys(static::$availableForegroundColors)))); | ||||
|         } | ||||
|  | ||||
|         $this->foreground = static::$availableForegroundColors[$color]; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function setBackground($color = null) | ||||
|     { | ||||
|         if (null === $color) { | ||||
|             $this->background = null; | ||||
|  | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         if (!isset(static::$availableBackgroundColors[$color])) { | ||||
|             throw new InvalidArgumentException(sprintf('Invalid background color specified: "%s". Expected one of (%s)', $color, implode(', ', array_keys(static::$availableBackgroundColors)))); | ||||
|         } | ||||
|  | ||||
|         $this->background = static::$availableBackgroundColors[$color]; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function setOption($option) | ||||
|     { | ||||
|         if (!isset(static::$availableOptions[$option])) { | ||||
|             throw new InvalidArgumentException(sprintf('Invalid option specified: "%s". Expected one of (%s)', $option, implode(', ', array_keys(static::$availableOptions)))); | ||||
|         } | ||||
|  | ||||
|         if (!\in_array(static::$availableOptions[$option], $this->options)) { | ||||
|             $this->options[] = static::$availableOptions[$option]; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function unsetOption($option) | ||||
|     { | ||||
|         if (!isset(static::$availableOptions[$option])) { | ||||
|             throw new InvalidArgumentException(sprintf('Invalid option specified: "%s". Expected one of (%s)', $option, implode(', ', array_keys(static::$availableOptions)))); | ||||
|         } | ||||
|  | ||||
|         $pos = array_search(static::$availableOptions[$option], $this->options); | ||||
|         if (false !== $pos) { | ||||
|             unset($this->options[$pos]); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function setOptions(array $options) | ||||
|     { | ||||
|         $this->options = []; | ||||
|  | ||||
|         foreach ($options as $option) { | ||||
|             $this->setOption($option); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * {@inheritdoc} | ||||
|      */ | ||||
|     public function apply($text) | ||||
|     { | ||||
|         $setCodes = []; | ||||
|         $unsetCodes = []; | ||||
|  | ||||
|         if (null !== $this->foreground) { | ||||
|             $setCodes[] = $this->foreground['set']; | ||||
|             $unsetCodes[] = $this->foreground['unset']; | ||||
|         } | ||||
|         if (null !== $this->background) { | ||||
|             $setCodes[] = $this->background['set']; | ||||
|             $unsetCodes[] = $this->background['unset']; | ||||
|         } | ||||
|         if (\count($this->options)) { | ||||
|             foreach ($this->options as $option) { | ||||
|                 $setCodes[] = $option['set']; | ||||
|                 $unsetCodes[] = $option['unset']; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if (0 === \count($setCodes)) { | ||||
|             return $text; | ||||
|         } | ||||
|  | ||||
|         return sprintf("\033[%sm%s\033[%sm", implode(';', $setCodes), $text, implode(';', $unsetCodes)); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										62
									
								
								vendor/symfony/console/Formatter/OutputFormatterStyleInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								vendor/symfony/console/Formatter/OutputFormatterStyleInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,62 @@ | ||||
| <?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; | ||||
|  | ||||
| /** | ||||
|  * Formatter style interface for defining styles. | ||||
|  * | ||||
|  * @author Konstantin Kudryashov <ever.zet@gmail.com> | ||||
|  */ | ||||
| interface OutputFormatterStyleInterface | ||||
| { | ||||
|     /** | ||||
|      * Sets style foreground color. | ||||
|      * | ||||
|      * @param string|null $color The color name | ||||
|      */ | ||||
|     public function setForeground($color = null); | ||||
|  | ||||
|     /** | ||||
|      * Sets style background color. | ||||
|      * | ||||
|      * @param string $color The color name | ||||
|      */ | ||||
|     public function setBackground($color = null); | ||||
|  | ||||
|     /** | ||||
|      * Sets some specific style option. | ||||
|      * | ||||
|      * @param string $option The option name | ||||
|      */ | ||||
|     public function setOption($option); | ||||
|  | ||||
|     /** | ||||
|      * Unsets some specific style option. | ||||
|      * | ||||
|      * @param string $option The option name | ||||
|      */ | ||||
|     public function unsetOption($option); | ||||
|  | ||||
|     /** | ||||
|      * Sets multiple style options at once. | ||||
|      */ | ||||
|     public function setOptions(array $options); | ||||
|  | ||||
|     /** | ||||
|      * Applies the style to a given text. | ||||
|      * | ||||
|      * @param string $text The text to style | ||||
|      * | ||||
|      * @return string | ||||
|      */ | ||||
|     public function apply($text); | ||||
| } | ||||
							
								
								
									
										110
									
								
								vendor/symfony/console/Formatter/OutputFormatterStyleStack.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										110
									
								
								vendor/symfony/console/Formatter/OutputFormatterStyleStack.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,110 @@ | ||||
| <?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; | ||||
|     } | ||||
| } | ||||
							
								
								
									
										25
									
								
								vendor/symfony/console/Formatter/WrappableOutputFormatterInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								vendor/symfony/console/Formatter/WrappableOutputFormatterInterface.php
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,25 @@ | ||||
| <?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; | ||||
|  | ||||
| /** | ||||
|  * Formatter interface for console output that supports word wrapping. | ||||
|  * | ||||
|  * @author Roland Franssen <franssen.roland@gmail.com> | ||||
|  */ | ||||
| interface WrappableOutputFormatterInterface extends OutputFormatterInterface | ||||
| { | ||||
|     /** | ||||
|      * Formats a message according to the given styles, wrapping at `$width` (0 means no wrapping). | ||||
|      */ | ||||
|     public function formatAndWrap(string $message, int $width); | ||||
| } | ||||
		Reference in New Issue
	
	Block a user