@ -17,6 +17,9 @@ use Composer\Factory;
use Composer\Installer;
use Composer\Installer;
use Composer\Installer\ProjectInstaller;
use Composer\Installer\ProjectInstaller;
use Composer\IO\IOInterface;
use Composer\IO\IOInterface;
use Composer\Package\BasePackage;
use Composer\Package\LinkConstraint\VersionConstraint;
use Composer\DependencyResolver\Pool;
use Composer\Repository\ComposerRepository;
use Composer\Repository\ComposerRepository;
use Composer\Repository\CompositeRepository;
use Composer\Repository\CompositeRepository;
use Composer\Repository\FilesystemRepository;
use Composer\Repository\FilesystemRepository;
@ -36,6 +39,7 @@ use Composer\Package\Version\VersionParser;
* Install a package as new project into new directory.
* Install a package as new project into new directory.
*
*
* @author Benjamin Eberlei < kontakt @ beberlei . de >
* @author Benjamin Eberlei < kontakt @ beberlei . de >
* @author Jordi Boggiano < j.boggiano @ seld . be >
*/
*/
class CreateProjectCommand extends Command
class CreateProjectCommand extends Command
{
{
@ -48,6 +52,7 @@ class CreateProjectCommand extends Command
new InputArgument('package', InputArgument::REQUIRED, 'Package name to be installed'),
new InputArgument('package', InputArgument::REQUIRED, 'Package name to be installed'),
new InputArgument('directory', InputArgument::OPTIONAL, 'Directory where the files should be created'),
new InputArgument('directory', InputArgument::OPTIONAL, 'Directory where the files should be created'),
new InputArgument('version', InputArgument::OPTIONAL, 'Version, will defaults to latest'),
new InputArgument('version', InputArgument::OPTIONAL, 'Version, will defaults to latest'),
new InputOption('stability', 's', InputOption::VALUE_REQUIRED, 'Minimum-stability allowed (unless a version is specified).', 'stable'),
new InputOption('prefer-source', null, InputOption::VALUE_NONE, 'Forces installation from package sources when possible, including VCS information.'),
new InputOption('prefer-source', null, InputOption::VALUE_NONE, 'Forces installation from package sources when possible, including VCS information.'),
new InputOption('prefer-dist', null, InputOption::VALUE_NONE, 'Forces installation from package dist even for dev versions.'),
new InputOption('prefer-dist', null, InputOption::VALUE_NONE, 'Forces installation from package dist even for dev versions.'),
new InputOption('repository-url', null, InputOption::VALUE_REQUIRED, 'Pick a different repository url to look for the package.'),
new InputOption('repository-url', null, InputOption::VALUE_REQUIRED, 'Pick a different repository url to look for the package.'),
@ -64,6 +69,11 @@ for developers of your project.
< info > php composer.phar create-project vendor/project target-directory [version]< / info >
< info > php composer.phar create-project vendor/project target-directory [version]< / info >
You can also specify the version with the package name using = or : as separator.
To install unstable packages, either specify the version you want, or use the
--stability=dev (where dev can be one of RC, beta, alpha or dev).
To setup a developer workable version you should create the project using the source
To setup a developer workable version you should create the project using the source
controlled code by appending the < info > '--prefer-source'< / info > flag. Also, it is
controlled code by appending the < info > '--prefer-source'< / info > flag. Also, it is
advisable to install all dependencies required for development by appending the
advisable to install all dependencies required for development by appending the
@ -84,6 +94,7 @@ EOT
$input->getArgument('package'),
$input->getArgument('package'),
$input->getArgument('directory'),
$input->getArgument('directory'),
$input->getArgument('version'),
$input->getArgument('version'),
$input->getOption('stability'),
$input->getOption('prefer-source'),
$input->getOption('prefer-source'),
$input->getOption('prefer-dist'),
$input->getOption('prefer-dist'),
$input->getOption('dev'),
$input->getOption('dev'),
@ -94,10 +105,18 @@ EOT
);
);
}
}
public function installProject(IOInterface $io, $packageName, $directory = null, $packageVersion = null, $preferSource = false, $preferDist = false, $installDevPackages = false, $repositoryUrl = null, $disableCustomInstallers = false, $noScripts = false, $keepVcs = false)
public function installProject(IOInterface $io, $packageName, $directory = null, $packageVersion = null, $stability = 'stable', $ preferSource = false, $preferDist = false, $installDevPackages = false, $repositoryUrl = null, $disableCustomInstallers = false, $noScripts = false, $keepVcs = false)
{
{
$config = Factory::createConfig();
$config = Factory::createConfig();
$stability = strtolower($stability);
if ($stability === 'rc') {
$stability = 'RC';
}
if (!isset(BasePackage::$stabilities[$stability])) {
throw new \InvalidArgumentException('Invalid stability provided ('.$stability.'), must be one of: '.implode(', ', array_keys(BasePackage::$stabilities)));
}
$dm = $this->createDownloadManager($io, $config);
$dm = $this->createDownloadManager($io, $config);
if ($preferSource) {
if ($preferSource) {
$dm->setPreferSource(true);
$dm->setPreferSource(true);
@ -113,33 +132,31 @@ EOT
throw new \InvalidArgumentException("Invalid repository url given. Has to be a .json file or an http url.");
throw new \InvalidArgumentException("Invalid repository url given. Has to be a .json file or an http url.");
}
}
$parser = new VersionParser();
$candidates = array();
$candidates = array();
$name = strtolower($packageName);
$requirements = $parser->parseNameVersionPairs(array($packageName));
$name = strtolower($requirements[0]['name']);
if (!$packageVersion & & isset($requirements[0]['version'])) {
$packageVersion = $requirements[0]['version'];
}
if ($packageVersion === null) {
$pool = new Pool($packageVersion ? 'dev' : $stability);
$sourceRepo->filterPackages(function ($package) use (& $candidates, $name) {
$pool->addRepository($sourceRepo);
if ($package->getName() === $name) {
$candidates[] = $package;
}
});
} else {
$parser = new VersionParser();
$version = $parser->normalize($packageVersion);
$sourceRepo->filterPackages(function ($package) use (& $candidates, $name, $version) {
if ($package->getName() === $name & & $version === $package->getVersion()) {
$candidates[] = $package;
return false;
$constraint = $packageVersion ? new VersionConstraint('=', $parser->normalize($packageVersion)) : null;
}
$candidates = $pool->whatProvides($name, $constraint);
});
foreach ($candidates as $key => $candidate) {
if ($candidate->getName() !== $name) {
unset($candidates[$key]);
}
}
}
if (!$candidates) {
if (!$candidates) {
throw new \InvalidArgumentException("Could not find package $packageName" . ($packageVersion ? " with version $packageVersion." : '' ));
throw new \InvalidArgumentException("Could not find package $name" . ($packageVersion ? " with version $packageVersion." : " with stability $stability." ));
}
}
if (null === $directory) {
if (null === $directory) {
$parts = explode("/", $packageN ame, 2);
$parts = explode("/", $n ame, 2);
$directory = getcwd() . DIRECTORY_SEPARATOR . array_pop($parts);
$directory = getcwd() . DIRECTORY_SEPARATOR . array_pop($parts);
}
}