Merge branch 'global'
commit
472037fb90
|
@ -148,6 +148,24 @@ to the command.
|
||||||
* **--no-progress:** Removes the progress display that can mess with some
|
* **--no-progress:** Removes the progress display that can mess with some
|
||||||
terminals or scripts which don't handle backspace characters.
|
terminals or scripts which don't handle backspace characters.
|
||||||
|
|
||||||
|
## global
|
||||||
|
|
||||||
|
The global command allows you to run other commands like `install`, `require`
|
||||||
|
or `update` as if you were running them from the [COMPOSER_HOME](#COMPOSER_HOME)
|
||||||
|
directory.
|
||||||
|
|
||||||
|
This can be used to install CLI utilities globally and if you add
|
||||||
|
`$COMPOSER_HOME/vendor/bin` to your `$PATH` environment variable. Here is an
|
||||||
|
example:
|
||||||
|
|
||||||
|
$ php composer.phar global require fabpot/php-cs-fixer:dev-master
|
||||||
|
|
||||||
|
Now the `php-cs-fixer` binary is available globally (assuming you adjusted
|
||||||
|
your PATH). If you wish to update the binary later on you can just run a
|
||||||
|
global update:
|
||||||
|
|
||||||
|
$ php composer.phar global update
|
||||||
|
|
||||||
## search
|
## search
|
||||||
|
|
||||||
The search command allows you to search through the current project's package
|
The search command allows you to search through the current project's package
|
||||||
|
@ -356,6 +374,11 @@ performance.
|
||||||
autoloader. This is recommended especially for production, but can take
|
autoloader. This is recommended especially for production, but can take
|
||||||
a bit of time to run so it is currently not done by default.
|
a bit of time to run so it is currently not done by default.
|
||||||
|
|
||||||
|
## licenses
|
||||||
|
|
||||||
|
Lists the name, version and license of every package installed. Use
|
||||||
|
`--format=json` to get machine readable output.
|
||||||
|
|
||||||
## run-script
|
## run-script
|
||||||
|
|
||||||
To run [scripts](articles/scripts.md) manually you can use this command,
|
To run [scripts](articles/scripts.md) manually you can use this command,
|
||||||
|
|
|
@ -0,0 +1,79 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
/*
|
||||||
|
* This file is part of Composer.
|
||||||
|
*
|
||||||
|
* (c) Nils Adermann <naderman@naderman.de>
|
||||||
|
* Jordi Boggiano <j.boggiano@seld.be>
|
||||||
|
*
|
||||||
|
* For the full copyright and license information, please view the LICENSE
|
||||||
|
* file that was distributed with this source code.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Composer\Command;
|
||||||
|
|
||||||
|
use Composer\Installer;
|
||||||
|
use Composer\Factory;
|
||||||
|
use Symfony\Component\Console\Input\InputInterface;
|
||||||
|
use Symfony\Component\Console\Input\InputArgument;
|
||||||
|
use Symfony\Component\Console\Input\StringInput;
|
||||||
|
use Symfony\Component\Console\Output\OutputInterface;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Jordi Boggiano <j.boggiano@seld.be>
|
||||||
|
*/
|
||||||
|
class GlobalCommand extends Command
|
||||||
|
{
|
||||||
|
protected function configure()
|
||||||
|
{
|
||||||
|
$this
|
||||||
|
->setName('global')
|
||||||
|
->setDescription('Allows running commands in the global composer dir ($COMPOSER_HOME).')
|
||||||
|
->setDefinition(array(
|
||||||
|
new InputArgument('command-name', InputArgument::REQUIRED, ''),
|
||||||
|
new InputArgument('args', InputArgument::IS_ARRAY | InputArgument::OPTIONAL, ''),
|
||||||
|
))
|
||||||
|
->setHelp(<<<EOT
|
||||||
|
Use this command as a wrapper to run other Composer commands
|
||||||
|
within the global context of COMPOSER_HOME.
|
||||||
|
|
||||||
|
You can use this to install CLI utilities globally, all you need
|
||||||
|
is to add the COMPOSER_HOME/vendor/bin dir to your PATH env var.
|
||||||
|
|
||||||
|
COMPOSER_HOME is c:\Users\<user>\AppData\Roaming\Composer on Windows
|
||||||
|
and /home/<user>/.composer on unix systems.
|
||||||
|
|
||||||
|
EOT
|
||||||
|
)
|
||||||
|
;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function run(InputInterface $input, OutputInterface $output)
|
||||||
|
{
|
||||||
|
// extract real command name
|
||||||
|
$tokens = preg_split('{\s+}', $input->__toString());
|
||||||
|
$args = array();
|
||||||
|
foreach ($tokens as $token) {
|
||||||
|
if ($token && $token[0] !== '-') {
|
||||||
|
$args[] = $token;
|
||||||
|
if (count($args) >= 2) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// show help for this command if no command was found
|
||||||
|
if (count($args) < 2) {
|
||||||
|
return parent::run($input, $output);
|
||||||
|
}
|
||||||
|
|
||||||
|
// change to global dir
|
||||||
|
$config = Factory::createConfig();
|
||||||
|
chdir($config->get('home'));
|
||||||
|
|
||||||
|
// create new input without "global" command prefix
|
||||||
|
$input = new StringInput(preg_replace('{\bg(?:l(?:o(?:b(?:a(?:l)?)?)?)?)?\b}', '', $input->__toString(), 1));
|
||||||
|
|
||||||
|
return $this->getApplication()->get($args[1])->run($input, $output);
|
||||||
|
}
|
||||||
|
}
|
|
@ -225,6 +225,7 @@ class Application extends BaseApplication
|
||||||
$commands[] = new Command\DiagnoseCommand();
|
$commands[] = new Command\DiagnoseCommand();
|
||||||
$commands[] = new Command\RunScriptCommand();
|
$commands[] = new Command\RunScriptCommand();
|
||||||
$commands[] = new Command\LicensesCommand();
|
$commands[] = new Command\LicensesCommand();
|
||||||
|
$commands[] = new Command\GlobalCommand();
|
||||||
|
|
||||||
if ('phar:' === substr(__FILE__, 0, 5)) {
|
if ('phar:' === substr(__FILE__, 0, 5)) {
|
||||||
$commands[] = new Command\SelfUpdateCommand();
|
$commands[] = new Command\SelfUpdateCommand();
|
||||||
|
|
Loading…
Reference in New Issue