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
Nicolas Grekas 2abbb8a451 Merge branch '2.8'
* 2.8:
  Fix undefined array $server
  Fix call to undefined function json_last_error_message
  Fix bug in windows detection
  [ProxyManager] Tmp fix composer reqs issue in ZF
  Fix PropertyInfo extractor namespace in framework bundle
  Add missing exclusions from phpunit.xml.dist
  [Serializer] ObjectNormalizer: don't serialize static methods and props
  [Form] Enhance some FormRegistry deprecation messages
  [Validator] [sl] BIC (SWIFT-BIC) validation constraint
  [WebProfilerBundle] correct typo in show stack trace link
  bumped Symfony version to 2.8.0
  updated VERSION for 2.8.0-BETA1
  updated CHANGELOG for 2.8.0-BETA1
  Fix the server variables in the router_*.php files
  [Validator] Allow an empty path with a non empty fragment or a query
  The following change adds support for Armenian pluralization.
  [2.3][Process] fix Proccess run with pts enabled

Conflicts:
	src/Symfony/Bridge/ProxyManager/composer.json
	src/Symfony/Bundle/FrameworkBundle/DependencyInjection/Compiler/FormPass.php
	src/Symfony/Component/Form/FormRegistry.php
2015-11-18 14:48:51 +01:00
..
Command Replace is_callable checks with type hints 2015-10-05 16:57:27 +02:00
Descriptor Merge branch '2.8' 2015-10-07 09:44:07 +02:00
Event fixes CS 2015-08-24 09:13:45 +02:00
Exception remove api tags that are new in 2.8 2015-09-29 14:35:00 +02:00
Formatter Merge branch '2.7' into 2.8 2015-09-29 14:32:55 +02:00
Helper [Console] Add progress indicator helper 2015-11-01 12:44:27 +01:00
Input [Console] End of options (--) signal support 2015-11-05 15:03:04 +01:00
Logger fixes CS 2015-08-24 09:13:45 +02:00
Output Merge branch '2.8' 2015-10-10 12:22:50 +02:00
Question Merge branch '2.7' into 2.8 2015-10-06 19:12:59 +02:00
Resources/bin Move hiddeninput.exe to Resources/bin 2012-10-16 11:08:11 +02:00
Style Merge branch '2.8' 2015-11-18 14:48:51 +01:00
Tester Fix currently broken tests 2015-04-04 14:23:36 +02:00
Tests feature #11431 [Console] End of options (--) signal support (Seldaek) 2015-11-05 15:03:06 +01:00
.gitignore Added missing files .gitignore 2013-07-21 14:12:18 +02:00
Application.php [Console] End of options (--) signal support 2015-11-05 15:03:04 +01:00
CHANGELOG.md [Console] Use readline for user input when available 2015-08-01 11:46:56 +02:00
composer.json Merge branch '2.8' 2015-10-30 16:35:59 -07: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 Merge branch '2.3' into 2.7 2015-10-11 11:39:48 +02:00
README.md link to https://symfony.com where possible 2015-05-01 16:06:45 +02: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 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