1
0
Fork 0

[ZipDownloader] If `unzip` command failed, give cleaner error.

pull/561/head
Joseph Bielawski 2012-04-10 15:59:20 +03:00
parent 14c3222478
commit 9631d7c3fd
1 changed files with 7 additions and 3 deletions

View File

@ -33,15 +33,19 @@ class ZipDownloader extends ArchiveDownloader
protected function extract($file, $path) protected function extract($file, $path)
{ {
if (!class_exists('ZipArchive')) { if (!class_exists('ZipArchive')) {
$error = 'You need the zip extension enabled to use the ZipDownloader';
// try to use unzip on *nix // try to use unzip on *nix
if (!defined('PHP_WINDOWS_VERSION_BUILD')) { if (!defined('PHP_WINDOWS_VERSION_BUILD')) {
$result = $this->process->execute('unzip '.escapeshellarg($file).' -d '.escapeshellarg($path), $ignoredOutput); $command = 'unzip '.escapeshellarg($file).' -d '.escapeshellarg($path);
if (0 == $result) { if (0 === $this->process->execute($command, $ignoredOutput)) {
return; return;
} }
$error = 'Failed to execute ' . $command . "\n\n" . $this->process->getErrorOutput();
} }
throw new \RuntimeException('You need the zip extension enabled to use the ZipDownloader'); throw new \RuntimeException($error);
} }
$zipArchive = new ZipArchive(); $zipArchive = new ZipArchive();