浏览代码

Merge pull request #4419 from sroze/real-system-path

Uses `realpath` to fix relative path issues
Jordi Boggiano 9 年之前
父节点
当前提交
fbf61ae671
共有 1 个文件被更改,包括 5 次插入4 次删除
  1. 5 4
      src/Composer/Downloader/PathDownloader.php

+ 5 - 4
src/Composer/Downloader/PathDownloader.php

@@ -39,18 +39,19 @@ class PathDownloader extends FileDownloader
         ));
 
         $url = $package->getDistUrl();
-        if (!file_exists($url) || !is_dir($url)) {
+        $realUrl = realpath($url);
+        if (false === $realUrl || !file_exists($realUrl) || !is_dir($realUrl)) {
             throw new \RuntimeException(sprintf(
                 'Path "%s" is not found',
-                $path
+                $url
             ));
         }
 
         try {
-            $fileSystem->symlink($url, $path);
+            $fileSystem->symlink($realUrl, $path);
             $this->io->writeError(sprintf('    Symlinked from %s', $url));
         } catch (IOException $e) {
-            $fileSystem->mirror($url, $path);
+            $fileSystem->mirror($realUrl, $path);
             $this->io->writeError(sprintf('    Mirrored from %s', $url));
         }