1
0
Fork 0

installer and downloaders update

pull/19/head
everzet 2011-09-18 13:14:58 +03:00
parent d7fe0dfda4
commit d2150a3c2e
5 changed files with 62 additions and 32 deletions

View File

@ -20,4 +20,5 @@ use Composer\Package\PackageInterface;
interface DownloaderInterface interface DownloaderInterface
{ {
function download(PackageInterface $package, $path, $url, $checksum = null); function download(PackageInterface $package, $path, $url, $checksum = null);
function isDownloaded(PackageInterface $package, $path);
} }

View File

@ -28,18 +28,17 @@ class GitDownloader implements DownloaderInterface
public function download(PackageInterface $package, $path, $url, $checksum = null) public function download(PackageInterface $package, $path, $url, $checksum = null)
{ {
if (!is_dir($path)) {
if (file_exists($path)) {
throw new \UnexpectedValueException($path.' exists and is not a directory.');
}
if (!mkdir($path, 0777, true)) {
throw new \UnexpectedValueException($path.' does not exist and could not be created.');
}
}
if ($this->clone) { if ($this->clone) {
system('git clone '.escapeshellarg($url).' -b master '.escapeshellarg($path.'/'.$package->getName())); system('git clone '.escapeshellarg($url).' -b master '.escapeshellarg($path.'/'.$package->getName()));
} else { } else {
system('git archive --format=tar --prefix='.escapeshellarg($package->getName()).' --remote='.escapeshellarg($url).' master | tar -xf -'); system('git archive --format=tar --prefix='.escapeshellarg($package->getName()).' --remote='.escapeshellarg($url).' master | tar -xf -');
} }
} }
public function isDownloaded(PackageInterface $package, $path)
{
$targetPath = $path . '/' . $package->getName();
return is_dir($targetPath);
}
} }

View File

@ -66,4 +66,11 @@ class PearDownloader implements DownloaderInterface
} }
chdir($cwd); chdir($cwd);
} }
public function isDownloaded(PackageInterface $package, $path)
{
$targetPath = $path . '/' . $package->getName();
return is_dir($targetPath);
}
} }

View File

@ -73,4 +73,11 @@ class ZipDownloader implements DownloaderInterface
throw new \UnexpectedValueException($zipName.' is not a valid zip archive, got error code '.$retval); throw new \UnexpectedValueException($zipName.' is not a valid zip archive, got error code '.$retval);
} }
} }
public function isDownloaded(PackageInterface $package, $path)
{
$targetPath = $path . '/' . $package->getName();
return is_dir($targetPath);
}
} }

View File

@ -18,15 +18,18 @@ use Composer\Composer;
/** /**
* @author Jordi Boggiano <j.boggiano@seld.be> * @author Jordi Boggiano <j.boggiano@seld.be>
* @author Konstantin Kudryashov <ever.zet@gmail.com>
*/ */
class LibraryInstaller implements InstallerInterface class LibraryInstaller implements InstallerInterface
{ {
private $dir; private $dir;
private $composer; private $composer;
private $preferSource;
public function __construct($dir = 'vendor') public function __construct($dir = 'vendor', $preferSource = false)
{ {
$this->dir = $dir; $this->dir = $dir;
$this->preferSource = $preferSource;
} }
public function setComposer(Composer $composer) public function setComposer(Composer $composer)
@ -36,39 +39,52 @@ class LibraryInstaller implements InstallerInterface
public function install(PackageInterface $package) public function install(PackageInterface $package)
{ {
if ($package->getDistType()) { if (!is_dir($this->dir)) {
if (file_exists($this->dir)) {
throw new \UnexpectedValueException($this->dir.' exists and is not a directory.');
}
if (!mkdir($this->dir, 0777, true)) {
throw new \UnexpectedValueException($this->path.' does not exist and could not be created.');
}
}
$this->composer->getDownloader($package->getDistType())->download( if (!($this->preferSource && $package->getSourceType()) && $package->getDistType()) {
$downloader = $this->composer->getDownloader($package->getDistType());
return $downloader->download(
$package, $this->dir, $package->getDistUrl(), $package->getDistSha1Checksum() $package, $this->dir, $package->getDistUrl(), $package->getDistSha1Checksum()
); );
} elseif ($package->getSourceType()) {
$this->composer->getDownloader($package->getSourceType())->download(
$package, $this->dir, $package->getSourceUrl()
);
} else {
throw new \InvalidArgumentException(
'Type must be one of (dist, source), '.$type.' given.'
);
} }
return true; if ($package->getSourceType()) {
$downloader = $this->composer->getDownloader($package->getSourceType());
return $downloader->download(
$package, $this->dir, $package->getSourceUrl()
);
}
throw new \InvalidArgumentException('Package should have dist or source specified');
} }
public function isInstalled(PackageInterface $package) public function isInstalled(PackageInterface $package)
{ {
// TODO: implement installation check if ($package->getSourceType()) {
} $downloader = $this->composer->getDownloader($package->getSourceType());
public function update(PackageInterface $package) if ($downloader->isDownloaded($package, $this->dir)) {
{ return true;
// TODO: implement package update }
} }
public function remove(PackageInterface $package) if ($package->getDistType()) {
{ $downloader = $this->composer->getDownloader($package->getDistType());
// TODO: implement package removal
if ($downloader->isDownloaded($package, $this->dir)) {
return true;
}
}
return false;
} }
} }