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 7351168841 feature #17761 [Console] Add non-auto column width functionality (akeeman)
This PR was squashed before being merged into the 3.1-dev branch (closes #17761).

Discussion
----------

[Console] Add non-auto column width functionality

| Q             | A
| ------------- | ---
| Bug fix?      | no
| New feature?  | yes
| BC breaks?    | no
| Deprecations? | no
| Tests pass?   | yes
| Fixed tickets |
| License       | MIT
| Doc PR        | [#6296](https://github.com/symfony/symfony-docs/pull/6296)

Be able to fix a columns width in a console table (i.e. set a columns width beforehand).
When a column's contents exceed the given column width, it will stretch.

Very useful, for instance, when one wants to display multiple tables that are separated from each other, but still want to align their columns.

Commits
-------

20c81b2 [Console] Add non-auto column width functionality
2016-03-01 18:31:11 +01:00
..
Command Merge branch '2.8' into 3.0 2016-02-16 07:11:42 +01:00
Descriptor Merge branch '2.8' into 3.0 2016-01-03 16:35:16 +01: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 2016-02-28 17:20:50 +01:00
Helper [Console] Add non-auto column width functionality 2016-03-01 18:31:09 +01:00
Input Merge branch '2.8' into 3.0 2016-02-16 07:11:42 +01:00
Logger fixes CS 2015-08-24 09:13:45 +02:00
Output Merge branch '2.8' into 3.0 2016-01-12 18:46:41 +01:00
Question Merge branch '2.8' into 3.0 2016-02-17 07:14:35 +01:00
Resources/bin Move hiddeninput.exe to Resources/bin 2012-10-16 11:08:11 +02:00
Style Merge branch '2.8' into 3.0 2016-01-21 10:38:31 +01:00
Tester Fix currently broken tests 2015-04-04 14:23:36 +02:00
Tests feature #17761 [Console] Add non-auto column width functionality (akeeman) 2016-03-01 18:31:11 +01:00
.gitignore Added missing files .gitignore 2013-07-21 14:12:18 +02:00
Application.php Merge branch '3.0' 2016-02-23 17:17:05 +01:00
CHANGELOG.md [Console] Add non-auto column width functionality 2016-03-01 18:31:09 +01:00
composer.json updated version to 3.1 2015-11-30 22:39:17 +01:00
ConsoleEvents.php Add machine readable events 2014-11-16 18:21:02 +01:00
LICENSE Update copyright year 2016-01-01 23:53:47 -03:00
phpunit.xml.dist Add missing exclusions from phpunit.xml.dist 2015-11-18 09:19:46 +01: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