1
0
Fork 0

Revert "Add test and some fixes to allow absolute paths, refs #869"

This reverts commit a2a2f4af59.
pull/931/head
Jordi Boggiano 2012-07-18 18:40:17 +02:00
parent 5777aa8087
commit 6fb5d26474
3 changed files with 9 additions and 22 deletions

View File

@ -53,7 +53,7 @@ return array(
EOF; EOF;
$packageMap = $this->buildPackageMap($installationManager, $mainPackage, $localRepo->getPackages()); $packageMap = $this->buildPackageMap($installationManager, $mainPackage, $localRepo->getPackages());
$autoloads = $this->parseAutoloads($packageMap, $filesystem); $autoloads = $this->parseAutoloads($packageMap);
foreach ($autoloads['psr-0'] as $namespace => $paths) { foreach ($autoloads['psr-0'] as $namespace => $paths) {
$exportedPaths = array(); $exportedPaths = array();
@ -118,9 +118,10 @@ EOF;
$autoloads['classmap'] = new \RecursiveIteratorIterator(new \RecursiveArrayIterator($autoloads['classmap'])); $autoloads['classmap'] = new \RecursiveIteratorIterator(new \RecursiveArrayIterator($autoloads['classmap']));
foreach ($autoloads['classmap'] as $dir) { foreach ($autoloads['classmap'] as $dir) {
foreach (ClassMapGenerator::createMap($dir) as $class => $path) { foreach (ClassMapGenerator::createMap($dir) as $class => $path) {
$classmapFile .= ' '.var_export($class, true) . ' => '; $classmapFile .= ' '.var_export($class, true) . ' => ';
if (0 === strpos($path, getcwd())) { if (0 === strpos($path, dirname($vendorPath), 0)) {
// this path seems to be located within this application/package // this path seems to be located within this application/package
$path = '/' . $filesystem->findShortestPath(getcwd(), $path, true); $path = '/' . $filesystem->findShortestPath(getcwd(), $path, true);
$classmapFile .= '$baseDir . '; $classmapFile .= '$baseDir . ';
@ -169,16 +170,11 @@ EOF;
/** /**
* Compiles an ordered list of namespace => path mappings * Compiles an ordered list of namespace => path mappings
* *
* @param array $packageMap array of array(package, installDir-relative-to-composer.json) * @param array $packageMap array of array(package, installDir-relative-to-composer.json)
* @param Filesystem $filesystem optional filesystem instance to use * @return array array('psr-0' => array('Ns\\Foo' => array('installDir')))
* @return array array('psr-0' => array('Ns\\Foo' => array('installDir')))
*/ */
public function parseAutoloads(array $packageMap, Filesystem $filesystem = null) public function parseAutoloads(array $packageMap)
{ {
if (!$filesystem) {
$filesystem = new Filesystem;
}
$autoloads = array('classmap' => array(), 'psr-0' => array(), 'files' => array()); $autoloads = array('classmap' => array(), 'psr-0' => array(), 'files' => array());
foreach ($packageMap as $item) { foreach ($packageMap as $item) {
list($package, $installPath) = $item; list($package, $installPath) = $item;
@ -194,13 +190,7 @@ EOF;
} }
foreach ($mapping as $namespace => $paths) { foreach ($mapping as $namespace => $paths) {
foreach ((array) $paths as $path) { foreach ((array) $paths as $path) {
if ($filesystem->isAbsolutePath($path)) { $autoloads[$type][$namespace][] = empty($installPath) ? $path : $installPath.'/'.$path;
// handle absolute paths in raw form
$autoloads[$type][$namespace][] = $path;
} else {
// prepend install path (including target dir) to the relative paths
$autoloads[$type][$namespace][] = empty($installPath) ? $path : $installPath.'/'.$path;
}
} }
} }
} }

View File

@ -190,7 +190,7 @@ class AutoloadGeneratorTest extends TestCase
$packages[] = $a = new MemoryPackage('a/a', '1.0', '1.0'); $packages[] = $a = new MemoryPackage('a/a', '1.0', '1.0');
$packages[] = $b = new MemoryPackage('b/b', '1.0', '1.0'); $packages[] = $b = new MemoryPackage('b/b', '1.0', '1.0');
$a->setAutoload(array('classmap' => array('src/'))); $a->setAutoload(array('classmap' => array('src/')));
$b->setAutoload(array('classmap' => array('src/', 'lib/', __FILE__))); $b->setAutoload(array('classmap' => array('src/', 'lib/')));
$this->repository->expects($this->once()) $this->repository->expects($this->once())
->method('getPackages') ->method('getPackages')
@ -211,12 +211,10 @@ class AutoloadGeneratorTest extends TestCase
'ClassMapFoo' => $this->workingDir.'/composer-test-autoload/a/a/src/a.php', 'ClassMapFoo' => $this->workingDir.'/composer-test-autoload/a/a/src/a.php',
'ClassMapBar' => $this->workingDir.'/composer-test-autoload/b/b/src/b.php', 'ClassMapBar' => $this->workingDir.'/composer-test-autoload/b/b/src/b.php',
'ClassMapBaz' => $this->workingDir.'/composer-test-autoload/b/b/lib/c.php', 'ClassMapBaz' => $this->workingDir.'/composer-test-autoload/b/b/lib/c.php',
'Composer\Test\Autoload\AutoloadGeneratorTest' => __FILE__,
), ),
include ($this->vendorDir.'/composer/autoload_classmap.php') include ($this->vendorDir.'/composer/autoload_classmap.php')
); );
$expected = str_replace('%path%', var_export(__FILE__, true), file_get_contents(__DIR__.'/Fixtures/autoload_classmap4.php')); $this->assertAutoloadFiles('classmap4', $this->vendorDir.'/composer', 'classmap');
$this->assertEquals($expected, file_get_contents($this->vendorDir.'/composer/autoload_classmap.php'));
} }
public function testClassMapAutoloadingEmptyDirAndExactFile() public function testClassMapAutoloadingEmptyDirAndExactFile()

View File

@ -6,7 +6,6 @@ $vendorDir = dirname(__DIR__);
$baseDir = dirname($vendorDir); $baseDir = dirname($vendorDir);
return array( return array(
'Composer\\Test\\Autoload\\AutoloadGeneratorTest' => %path%,
'ClassMapBaz' => $baseDir . '/composer-test-autoload/b/b/lib/c.php', 'ClassMapBaz' => $baseDir . '/composer-test-autoload/b/b/lib/c.php',
'ClassMapFoo' => $baseDir . '/composer-test-autoload/a/a/src/a.php', 'ClassMapFoo' => $baseDir . '/composer-test-autoload/a/a/src/a.php',
'ClassMapBar' => $baseDir . '/composer-test-autoload/b/b/src/b.php', 'ClassMapBar' => $baseDir . '/composer-test-autoload/b/b/src/b.php',