1
0
Fork 0

Store path from composer.json with the `path` repository to ensure lock file to be reused

pull/4417/head
Samuel ROZE 2015-09-14 09:58:07 +01:00
parent 66acee7feb
commit 0e8c5fa62e
2 changed files with 23 additions and 7 deletions

View File

@ -39,6 +39,13 @@ class PathDownloader extends FileDownloader
$package->getDistUrl()
));
if (!file_exists($path) || !is_dir($path)) {
throw new \RuntimeException(sprintf(
'Path "%s" is not found',
$path
));
}
try {
$fileSystem->symlink($package->getDistUrl(), $path);
} catch (IOException $e) {

View File

@ -60,7 +60,7 @@ class PathRepository extends ArrayRepository
/**
* @var string
*/
private $path;
private $url;
/**
* @var ProcessExecutor
@ -81,7 +81,7 @@ class PathRepository extends ArrayRepository
}
$this->loader = new ArrayLoader();
$this->path = realpath(rtrim($repoConfig['url'], '/')) . '/';
$this->url = $repoConfig['url'];
$this->process = new ProcessExecutor($io);
$this->versionGuesser = new VersionGuesser($config, $this->process, new VersionParser());
@ -97,27 +97,36 @@ class PathRepository extends ArrayRepository
{
parent::initialize();
$composerFilePath = $this->path.'composer.json';
$path = $this->getPath();
$composerFilePath = $path.'composer.json';
if (!file_exists($composerFilePath)) {
throw new \RuntimeException(sprintf('No `composer.json` file found in path repository "%s"', $this->path));
throw new \RuntimeException(sprintf('No `composer.json` file found in path repository "%s"', $path));
}
$json = file_get_contents($composerFilePath);
$package = JsonFile::parseJson($json, $composerFilePath);
$package['dist'] = array(
'type' => 'path',
'url' => $this->path,
'url' => $this->url,
'reference' => '',
);
if (!isset($package['version'])) {
$package['version'] = $this->versionGuesser->guessVersion($package, $this->path) ?: 'dev-master';
$package['version'] = $this->versionGuesser->guessVersion($package, $path) ?: 'dev-master';
}
if (is_dir($this->path.'/.git') && 0 === $this->process->execute('git log -n1 --pretty=%H', $output, $this->path)) {
if (is_dir($path.'/.git') && 0 === $this->process->execute('git log -n1 --pretty=%H', $output, $path)) {
$package['dist']['reference'] = trim($output);
}
$package = $this->loader->load($package);
$this->addPackage($package);
}
/**
* @return string
*/
private function getPath()
{
return realpath(rtrim($this->url, '/')) . '/';
}
}