[Console] moved the IO configuration to its own method
The IO configuration was also moved earlier in the process so that options are taken into account as early as possible. That's useful for instance in Symfony FrameworkBundle, where commands are registered in the doRun() method. If an exception occurs during registration, the -q, -v, ... options would not have any effect.
This commit is contained in:
parent
fdb4b1fd75
commit
bd0c48cc00
@ -115,6 +115,8 @@ class Application
|
|||||||
$output = new ConsoleOutput();
|
$output = new ConsoleOutput();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$this->configureIO($input, $output);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
$exitCode = $this->doRun($input, $output);
|
$exitCode = $this->doRun($input, $output);
|
||||||
} catch (\Exception $e) {
|
} catch (\Exception $e) {
|
||||||
@ -154,35 +156,6 @@ class Application
|
|||||||
*/
|
*/
|
||||||
public function doRun(InputInterface $input, OutputInterface $output)
|
public function doRun(InputInterface $input, OutputInterface $output)
|
||||||
{
|
{
|
||||||
if (true === $input->hasParameterOption(array('--ansi'))) {
|
|
||||||
$output->setDecorated(true);
|
|
||||||
} elseif (true === $input->hasParameterOption(array('--no-ansi'))) {
|
|
||||||
$output->setDecorated(false);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (true === $input->hasParameterOption(array('--no-interaction', '-n'))) {
|
|
||||||
$input->setInteractive(false);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (function_exists('posix_isatty') && $this->getHelperSet()->has('dialog')) {
|
|
||||||
$inputStream = $this->getHelperSet()->get('dialog')->getInputStream();
|
|
||||||
if (!posix_isatty($inputStream)) {
|
|
||||||
$input->setInteractive(false);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (true === $input->hasParameterOption(array('--quiet', '-q'))) {
|
|
||||||
$output->setVerbosity(OutputInterface::VERBOSITY_QUIET);
|
|
||||||
} else {
|
|
||||||
if ($input->hasParameterOption('-vvv') || $input->hasParameterOption('--verbose=3') || $input->getParameterOption('--verbose') === 3) {
|
|
||||||
$output->setVerbosity(OutputInterface::VERBOSITY_DEBUG);
|
|
||||||
} elseif ($input->hasParameterOption('-vv') || $input->hasParameterOption('--verbose=2') || $input->getParameterOption('--verbose') === 2) {
|
|
||||||
$output->setVerbosity(OutputInterface::VERBOSITY_VERY_VERBOSE);
|
|
||||||
} elseif ($input->hasParameterOption('-v') || $input->hasParameterOption('--verbose=1') || $input->hasParameterOption('--verbose') || $input->getParameterOption('--verbose')) {
|
|
||||||
$output->setVerbosity(OutputInterface::VERBOSITY_VERBOSE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (true === $input->hasParameterOption(array('--version', '-V'))) {
|
if (true === $input->hasParameterOption(array('--version', '-V'))) {
|
||||||
$output->writeln($this->getLongVersion());
|
$output->writeln($this->getLongVersion());
|
||||||
|
|
||||||
@ -863,6 +836,44 @@ class Application
|
|||||||
return array(null, null);
|
return array(null, null);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Configures the input and output instances based on the user arguments and options.
|
||||||
|
*
|
||||||
|
* @param InputInterface $input An InputInterface instance
|
||||||
|
* @param OutputInterface $output An OutputInterface instance
|
||||||
|
*/
|
||||||
|
protected function configureIO(InputInterface $input, OutputInterface $output)
|
||||||
|
{
|
||||||
|
if (true === $input->hasParameterOption(array('--ansi'))) {
|
||||||
|
$output->setDecorated(true);
|
||||||
|
} elseif (true === $input->hasParameterOption(array('--no-ansi'))) {
|
||||||
|
$output->setDecorated(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (true === $input->hasParameterOption(array('--no-interaction', '-n'))) {
|
||||||
|
$input->setInteractive(false);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (function_exists('posix_isatty') && $this->getHelperSet()->has('dialog')) {
|
||||||
|
$inputStream = $this->getHelperSet()->get('dialog')->getInputStream();
|
||||||
|
if (!posix_isatty($inputStream)) {
|
||||||
|
$input->setInteractive(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (true === $input->hasParameterOption(array('--quiet', '-q'))) {
|
||||||
|
$output->setVerbosity(OutputInterface::VERBOSITY_QUIET);
|
||||||
|
} else {
|
||||||
|
if ($input->hasParameterOption('-vvv') || $input->hasParameterOption('--verbose=3') || $input->getParameterOption('--verbose') === 3) {
|
||||||
|
$output->setVerbosity(OutputInterface::VERBOSITY_DEBUG);
|
||||||
|
} elseif ($input->hasParameterOption('-vv') || $input->hasParameterOption('--verbose=2') || $input->getParameterOption('--verbose') === 2) {
|
||||||
|
$output->setVerbosity(OutputInterface::VERBOSITY_VERY_VERBOSE);
|
||||||
|
} elseif ($input->hasParameterOption('-v') || $input->hasParameterOption('--verbose=1') || $input->hasParameterOption('--verbose') || $input->getParameterOption('--verbose')) {
|
||||||
|
$output->setVerbosity(OutputInterface::VERBOSITY_VERBOSE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Runs the current command.
|
* Runs the current command.
|
||||||
*
|
*
|
||||||
|
Reference in New Issue
Block a user