hoathis / symfony-console-bridge
The Hoa\Console to Symfony\Console bridge.
Installs: 2 351
Dependents: 1
Suggesters: 0
Security: 0
Stars: 21
Watchers: 13
Forks: 4
Open Issues: 0
pkg:composer/hoathis/symfony-console-bridge
Requires
- php: >=5.3.3
- hoa/console: >=1.0,<3.0
- symfony/console: ~2.3,>=2.3.6|~3.0.0
Requires (Dev)
- atoum/atoum: ~1.0
This package is auto-updated.
Last update: 2021-10-04 11:06:50 UTC
README
Hoa is a modular, extensible and structured set of PHP libraries. Moreover, Hoa aims at being a bridge between industrial and research worlds.
Hoathis\SymfonyConsoleBridge 
All the examples in this readme are available and working in the test application.
Installation
With Composer, to include this library into your dependencies, you need to require
hoathis/symfony-console-bridge:
{
    "require": {
        "hoathis/symfony-console-bridge": "~1.0"
    }
}
Please, read the website to get more informations about how to install.
Finally, install dependencies:
$ composer update hoathis/symfony-console-bridge
How to use
Symfony
To use this library with the Symfony framework, please use
the dedicated bundle:
hoathis/symfony-console-bundle.
Output
Hoathis\SymfonyConsoleBridge\Output\ConsoleOutput is an alternative to the
native ConsoleOutput which is able to detect output type and automatically
configure verbosity and text decoration.
Let's have the following command:
<?php $app = new Application(); $app ->register('output:verbosity') ->setCode(function(InputInterface $input, OutputInterface $output) { $output->writeln('<info>I\'m a decorated text only in the console</info>'); if ($output->getVerbosity() === OutputInterface::VERBOSITY_NORMAL) { $output->writeln('I\'ll be displayed with the <comment>normal</comment> verbosity level'); } if ($output->getVerbosity() === OutputInterface::VERBOSITY_VERBOSE) { $output->writeln('I\'ll be displayed with the <comment>verbose</comment> verbosity level'); } if ($output->getVerbosity() === OutputInterface::VERBOSITY_VERY_VERBOSE) { $output->writeln('I\'ll be displayed with the <comment>very verbose</comment> verbosity level'); } if ($output->getVerbosity() === OutputInterface::VERBOSITY_DEBUG) { $output->writeln('I\'ll be displayed with the <comment>debug</comment> verbosity level'); } }) ;
Running:
$ bin/console output:verbosity # I'm a decorated text only in the console # I'll be displayed with the verbose verbosity level
As you will see in your terminal, output will be decorated and verbose by default. However if you run:
$ bin/console output:verbosity > output $ cat -vet output # I'm a decorated text only in the console$ # I'll be displayed with the very verbose verbosity level$
The verbosity level will automatically be switched to very verbose because the output has detected that you were redirecting it to a file.
Here are the rules used to determine verbosity level and text decoration support:
| Verbosity | Decoration | |
|---|---|---|
| Pipe | normal | disabled | 
| Redirect | very verbose | disabled | 
| Terminal | verbose | enabled | 
Those rules will only be used if you do not provide any verbosity level using command line arguments. If you want to redirect outputs to a file using the debug verbosity level, simply run:
$ bin/console output:verbosity -vvv > output $ cat -vet output # I'm a decorated text only in the console$ # I'll be displayed with the debug verbosity level$
You can still force ANSI output using the --ansi option:
$ bin/console output:verbosity -vvv --ansi | xargs -0 echo -n | cat -vet # ^[[38;5;189mI'm a decorated text only in the console^[[39;49;0m$ # I'll be displayed with the ^[[38;5;96mdebug^[[39;49;0m verbosity level$
Want to try it? Run
bin/console output:verbosityto get a live demo and code snippet.
Formatter
Hoathis\SymfonyConsoleBridge\Formatter\OutputFormatterStyle will let you do
everything you were able to do with the native symfony/console formatter with
some more cool things:
- supports xterm-8colorcolor names,
- supports xterm-256colorcolor codes,
- automatically translates hexadecimal color codes,
- supports text styling (normal, bold, underlined, blink and inverse).
To use those new OutputFormatterStyle, use the usual API:
<?php class Application extends BaseApplication { protected function configureIO(InputInterface $input, OutputInterface $output) { parent::configureIO($input, $output); $formatter = $output->getFormatter(); $formatter->setStyle('info', new OutputFormatterStyle('#e4cbf4')); $formatter->setStyle('comment', new OutputFormatterStyle('#795290')); $formatter->setStyle('question', new OutputFormatterStyle('#de8300')); $formatter->setStyle('error', new OutputFormatterStyle('white', '#ff3333', array(OutputFormatterStyle::STYLE_BOLD))); } //... }
As you can see in the previous example, you can replace built-in styles by simply redifining them with the new formatter.
Want to try it? Run
bin/console output:formatter:customorbin/console output:formatter:nativeto get a live demo and code snippet.
Helpers
The real power of the library comes from its helpers: they let you manage every terminal components. You will first have to manually load them:
<?php class Application extends BaseApplication { protected function getDefaultHelperSet() { $set = parent::getDefaultHelperSet(); $set->set(new Helper\WindowHelper()); $set->set(new Helper\CursorHelper()); $set->set(new Helper\ReadlineHelper()); $set->set(new Helper\PagerHelper()); return $set; } //... }
Every helper has a dedicated test command. Just run
bin/console listto get a list.
Window
The window helper will let you manipulate the current terminal window. It provides several utility methods, each one being bound to an action:
<?php $app = new Application(); $app ->register('helper:window:animate') ->setCode(function(InputInterface $input, OutputInterface $output) use ($app) { $window = $app->getHelperSet()->get('window'); $output->writeln('<info>I\'m going to bring your window to the foreground and back to the foreground after one second</info>'); sleep(1); $window->lower($output); sleep(1); $window->raise($output); $output->writeln('<info>I\'m going to minimize your window and restore it after one second</info>'); sleep(1); $window->minimize($output); sleep(1); $window->restore($output); }) ;
Many other utility methods are available:
- setTitle,- getTitle,- getLabelto manipulate terminal title,
- setSize,- getSize,- move,- setPosition,- getPositionto manipulate window position,
- minimize,- restore,- lower,- raiseto manipulate window placement,
- scroll,- refresh,- copyto manipulate window content.
Want to try it? Run
bin/console helper:window:animateto get a live demo and code snippet.
Cursor
The cursor helper will let you manipulate the cursor. It provides several utility methods, each one being bound to an action:
<?php $app = new Application(); $app ->register('helper:cursor:draw') ->setCode(function(InputInterface $input, OutputInterface $output) use ($app) { $window = $app->getHelperSet()->get('cursor'); $colors = ['red', '#FFCC33', 'yellow', 'green', 'blue', '#003DF5', '#6633FF']; $helper = new Helper\CursorHelper(); $helper->hide($output)->move($output, 'up', 1); foreach ($colors as $index => $color) { $helper->move($output, 'left', 20 - ($index * 4)); $output->write(sprintf('<bg=%1$s>%2$s</bg=%1$s>', $color, str_repeat(' ', 20))); $helper->move($output, 'down')->move($output, 'left', 20); $output->write(sprintf('<bg=%1$s>%2$s</bg=%1$s>', $color, str_repeat(' ', 20))); $helper->move($output, 'up')->bip($output); usleep(250000); } $helper ->move($output, 'down', 2) ->move($output, 'left', 100) ->reset($output) ->show($output); }) ;
Many other utility method are available:
- move,- moveToto change cursor position,- getPositionto retrieve the current cursor position,
- saveand- restoreto save and restore the cursor position,
- clearto clear whole or part of the screen,
- hide,- showand- styleto change cursor display options,
- colorizeand- resetto manage text styling,
- bipto emit a bell.
Want to try it? Run
bin/console helper:cursor:drawto get a live demo and code snippet.
Readline
The readline helper will help you gather inputs from the user. It provides some methods to ask and validates user's inputs:
- readwill prompt the user for an input,
- autocompletewill display a prompt and let the user input text and use autocompletion,
- selectwill display a list of choices to the user and let him select one or more values,
- validatewill keep asking for an input until it validates against a validator you provide.
<?php $app = new Application(); $app ->register('helper:readline:select') ->addOption('multi', null, InputOption::VALUE_NONE) ->setCode(function(InputInterface $input, OutputInterface $output) use($app) { $readline = $app->getHelperSet()->get('readline'); $selection = (array) $readline->select( $output, $input->getOption('multi') ? 'Select some values:' : 'Select a value:', [ '<info>php</info>' => ReadlineHelper::SEPARATOR, 'hoa', 'symfony', 'laravel', '<info>js</info>' => ReadlineHelper::SEPARATOR, 'express', 'connect', 'restify', ], null, false, $input->getOption('multi') ); $output->writeln(sprintf('<info>You selected</info>: %s', implode(', ', $selection))); });
Note that for select you can provide a special choice that will display as a
separator using 'label' => ReadlineHelper::SEPARATOR items in you choices
list.
Want to try it? Run
bin/console helper:readline:selectorbin/console helper:readline:autocompleteto get a live demo and code snippet.
Pager
The pager helper will let you display outputs through a pager so the user can
easily read and scroll. The helper provides two pagers: less and more. You
will have to feed them using a closure wrapping code producing output:
<?php $app = new Application(); $app ->register('helper:pager:less') ->setCode(function(InputInterface $input, OutputInterface $output) use($app) { $pager = $app->getHelperSet()->get('pager'); $pager->less( $output, function() { passthru('cat ' . __DIR__ . '/*.php'); } ); });
Want to try it? Run
bin/console helper:pager:lessorbin/console helper:pager:moreto get a live demo and code snippet.
Tput
The tput helper will help you get informed about user's terminal capabilities. The helper provides
a single entry point to all capabilities: the get method. Here is how you would do to get the clear_screen
capability:
<?php $app = new Application(); $app ->register('helper:tput:get') ->setCode(function(InputInterface $input, OutputInterface $output) use($app) { $tput = new TputHelper(); $capability = 'clear_screen'; $value = $tput->get($capability); $output->writeln(sprintf('<info>%s</info>: %s', $capability, $value)); });
Want to try it? Run
bin/console helper:tput:capabilitiesorbin/console helper:tput:echoorbin/console helper:tput:getto get a live demo and code snippet.