This repository has been archived on 2023-08-20. You can view files and clone it, but cannot push or open issues or pull requests.
symfony/src/Symfony/Component/Console
2013-04-17 07:37:48 +02:00
..
Command [Console] Fix merging of application definition, fixes #7068, replaces #7158 2013-04-12 15:15:07 +02:00
Event refactored the implementation of how a console application can handle events 2013-03-25 09:14:22 +01:00
Formatter Enforce sprintf for exceptions 2013-04-11 08:50:46 +02:00
Helper Merge branch '2.2' 2013-04-17 07:31:37 +02:00
Input Merge branch '2.2' 2013-04-17 07:31:37 +02:00
Output Merge branch '2.1' into 2.2 2013-03-01 07:43:14 +01:00
Resources/bin Move hiddeninput.exe to Resources/bin 2012-10-16 11:08:11 +02:00
Tester [Console] added a way to normalize a command display when using the tester 2013-03-24 10:36:53 +01:00
Tests fixed previous merge 2013-04-17 07:37:48 +02:00
.gitignore made usage of Composer autoloader for subtree-split unit tests 2012-11-09 14:10:06 +01:00
Application.php Merge branch '2.2' 2013-04-07 22:25:23 +02:00
CHANGELOG.md [2.3] [Console] TableHelper 2013-04-07 16:24:41 +02:00
composer.json refactored the implementation of how a console application can handle events 2013-03-25 09:14:22 +01:00
ConsoleEvents.php refactored the implementation of how a console application can handle events 2013-03-25 09:14:22 +01:00
LICENSE updated license year 2013-01-04 17:58:00 +01:00
phpunit.xml.dist made usage of Composer autoloader for subtree-split unit tests 2012-11-09 14:10:06 +01:00
README.md made usage of Composer autoloader for subtree-split unit tests 2012-11-09 14:10:06 +01:00
Shell.php [Console] Fix #5897 - Console component require Shell component 2012-11-06 02:56:20 +01:00

Console Component

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, ...

Tests

You can run the unit tests with the following command:

$ cd path/to/Symfony/Component/Console/
$ composer.phar install --dev
$ phpunit

Third Party

Resources/bin/hiddeninput.exe is a third party binary provided within this component. Find sources and license at https://github.com/Seldaek/hidden-input.

Resources

The Console Component

How to create a Console Command