|  | 10 years ago | |
|---|---|---|
| .. | ||
| Command | 10 years ago | |
| Descriptor | 10 years ago | |
| Event | 10 years ago | |
| Formatter | 10 years ago | |
| Helper | 10 years ago | |
| Input | 10 years ago | |
| Logger | 10 years ago | |
| Output | 10 years ago | |
| Question | 10 years ago | |
| Style | 10 years ago | |
| Tester | 10 years ago | |
| Tests | 10 years ago | |
| Application.php | 10 years ago | |
| CHANGELOG.md | 10 years ago | |
| ConsoleEvents.php | 10 years ago | |
| LICENSE | 10 years ago | |
| README.md | 10 years ago | |
| Shell.php | 10 years ago | |
| composer.json | 10 years ago | |
| phpunit.xml.dist | 10 years ago | |
Console eases the creation of beautiful and testable command line interfaces.
The Application object manages the CLI application:
use Symfony\Component\Console\Application;
$console = new Application();
$console->run();
The run() method parses the arguments and options passed on the command
line and executes the right command.
Registering a new command can easily be done via the register() method,
which returns a Command instance:
use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Input\InputArgument;
use Symfony\Component\Console\Input\InputOption;
use Symfony\Component\Console\Output\OutputInterface;
$console
    ->register('ls')
    ->setDefinition(array(
        new InputArgument('dir', InputArgument::REQUIRED, 'Directory name'),
    ))
    ->setDescription('Displays the files in the given directory')
    ->setCode(function (InputInterface $input, OutputInterface $output) {
        $dir = $input->getArgument('dir');
        $output->writeln(sprintf('Dir listing for <info>%s</info>', $dir));
    })
;
You can also register new commands via classes.
The component provides a lot of features like output coloring, input and output abstractions (so that you can easily unit-test your commands), validation, automatic help messages, ...
You can run the unit tests with the following command:
$ cd path/to/Symfony/Component/Console/
$ composer install
$ phpunit
Resources/bin/hiddeninput.exe is a third party binary provided within this
component. Find sources and license at https://github.com/Seldaek/hidden-input.