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
Fabien Potencier 2570042937 Merge branch '2.6' into 2.7
* 2.6:
  [2.3] [HttpFoundation] [MimeTypeGuesser]
  Removed dead code and various cleaning
  Removed dead code and various cleaning
  [FrameworkBundle][xsd] added missing logging attribute.
  [Console] Make it clear that the second argument is not about command options.
  Added the '-' character for spaceless on tag start and end to be consistent for block, if, set and for nodes
  [Yaml] fixed parse shortcut Key after unindented collection.
  [Console] fixed #10531
  Make the container considered non-fresh if the environment parameters are changed
2015-01-25 05:39:35 +01:00
..
Command Normalized @deprecated annotations. 2015-01-05 16:02:26 +01:00
Descriptor Removed dead code and various cleaning 2015-01-21 21:57:55 +01:00
Event Merge branch '2.5' into 2.6 2014-12-02 21:19:20 +01:00
Formatter Merge branch '2.3' into 2.5 2014-12-22 17:29:52 +01:00
Helper Merge branch '2.6' into 2.7 2015-01-15 13:16:13 +01:00
Input Merge branch '2.6' into 2.7 2015-01-20 02:40:35 +01:00
Logger CS fixes 2014-12-04 20:26:11 +00:00
Output Merge branch '2.3' into 2.5 2014-12-02 21:15:53 +01:00
Question Added i18n support to ConfirmationQuestion 2015-01-25 05:09:28 +01:00
Resources/bin Move hiddeninput.exe to Resources/bin 2012-10-16 11:08:11 +02:00
Tester Merge branch '2.3' into 2.5 2015-01-25 05:37:39 +01:00
Tests Merge branch '2.6' into 2.7 2015-01-25 05:39:35 +01:00
.gitignore Added missing files .gitignore 2013-07-21 14:12:18 +02:00
Application.php Merge branch '2.6' into 2.7 2015-01-25 05:39:35 +01:00
CHANGELOG.md Merge branch '2.5' 2014-08-05 11:07:51 +02:00
composer.json bumped min PHP version to 5.3.9 2015-01-09 07:51:41 +01:00
ConsoleEvents.php Add machine readable events 2014-11-16 18:21:02 +01:00
LICENSE Updated copyright to 2015 2015-01-01 13:56:52 +01:00
phpunit.xml.dist [Tests] Silenced all deprecations in tests for 2.3 2014-12-18 20:00:19 +01:00
README.md [Doc] Use Markdown syntax highlighting 2014-10-01 07:38:33 +02:00
Shell.php Merge branch '2.3' into 2.5 2014-12-02 21:15:53 +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
$ 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