<?php namespace PHPGit\Command; use PHPGit\Command; use PHPGit\Exception\GitException; use Symfony\Component\OptionsResolver\OptionsResolverInterface; /** * Clone a repository into a new directory - `git clone` * * @author Kazuyuki Hayashi <hayashi@valnur.net> */ class CloneCommand extends Command { /** * Clone a repository into a new directory * * ``` php * $git = new PHPGit\Git(); * $git->clone('https://github.com/kzykhys/PHPGit.git', '/path/to/repo'); * ``` * * ##### Options * * - **shared** (_boolean_) Starts out without any object of its own * - **bare** (_boolean_) Make a bare GIT repository * * @param string $repository The repository to clone from * @param string $path [optional] The name of a new directory to clone into * @param array $options [optional] An array of options {@see CloneCommand::setDefaultOptions} * * @throws GitException * @return bool */ public function __invoke($repository, $path = null, array $options = array()) { $options = $this->resolve($options); $builder = $this->git->getProcessBuilder() ->add('clone') ->add('--quiet'); $this->addFlags($builder, $options); $builder->add($repository); if ($path) { $builder->add($path); } $this->git->run($builder->getProcess()); return true; } /** * {@inheritdoc} * * - **shared** (_boolean_) Starts out without any object of its own * - **bare** (_boolean_) Make a bare GIT repository */ public function setDefaultOptions(OptionsResolverInterface $resolver) { $resolver->setDefaults(array( 'shared' => false, 'bare' => false )); } }