class ClassMap
@author Jordi Boggiano <j.boggiano@seld.be>
Hierarchy
- class \Composer\ClassMapGenerator\ClassMap implements \Composer\ClassMapGenerator\Countable
Expanded class hierarchy of ClassMap
1 file declares its use of ClassMap
- AutoloadGenerator.php in vendor/
composer/ composer/ src/ Composer/ Autoload/ AutoloadGenerator.php
7 string references to 'ClassMap'
- AutoloadGenerator::parseAutoloads in vendor/
composer/ composer/ src/ Composer/ Autoload/ AutoloadGenerator.php - Compiles an ordered list of namespace => path mappings
- AutoloadGenerator::parseAutoloadsType in vendor/
composer/ composer/ src/ Composer/ Autoload/ AutoloadGenerator.php - ClassMapGenerator::createMap in vendor/
composer/ composer/ src/ Composer/ Autoload/ ClassMapGenerator.php - Iterate over all files in the given directory searching for classes
- ClassMapGenerator::scanPaths in vendor/
composer/ class-map-generator/ src/ ClassMapGenerator.php - Iterate over all files in the given directory searching for classes
- ShowCommand::appendAutoload in vendor/
composer/ composer/ src/ Composer/ Command/ ShowCommand.php
File
-
vendor/
composer/ class-map-generator/ src/ ClassMap.php, line 20
Namespace
Composer\ClassMapGeneratorView source
class ClassMap implements \Countable {
/**
* @var array<class-string, non-empty-string>
*/
public $map = [];
/**
* @var array<class-string, array<non-empty-string>>
*/
private $ambiguousClasses = [];
/**
* @var array<string, array<array{warning: string, className: string}>>
*/
private $psrViolations = [];
/**
* Returns the class map, which is a list of paths indexed by class name
*
* @return array<class-string, non-empty-string>
*/
public function getMap() : array {
return $this->map;
}
/**
* Returns warning strings containing details about PSR-0/4 violations that were detected
*
* Violations are for ex a class which is in the wrong file/directory and thus should not be
* found using psr-0/psr-4 autoloading but was found by the ClassMapGenerator as it scans all files.
*
* This is only happening when scanning paths using psr-0/psr-4 autoload type. Classmap type
* always accepts every class as it finds it.
*
* @return string[]
*/
public function getPsrViolations() : array {
if (\count($this->psrViolations) === 0) {
return [];
}
return array_map(static function (array $violation) : string {
return $violation['warning'];
}, array_merge(...array_values($this->psrViolations)));
}
/**
* A map of class names to their list of ambiguous paths
*
* This occurs when the same class can be found in several files
*
* To get the path the class is being mapped to, call getClassPath
*
* By default, paths that contain test(s), fixture(s), example(s) or stub(s) are ignored
* as those are typically not problematic when they're dummy classes in the tests folder.
* If you want to get these back as well you can pass false to $duplicatesFilter. Or
* you can pass your own pattern to exclude if you need to change the default.
*
* @param non-empty-string|false $duplicatesFilter
*
* @return array<class-string, array<non-empty-string>>
*/
public function getAmbiguousClasses($duplicatesFilter = '{/(test|fixture|example|stub)s?/}i') : array {
if (false === $duplicatesFilter) {
return $this->ambiguousClasses;
}
if (true === $duplicatesFilter) {
throw new \InvalidArgumentException('$duplicatesFilter should be false or a string with a valid regex, got true.');
}
$ambiguousClasses = [];
foreach ($this->ambiguousClasses as $class => $paths) {
$paths = array_filter($paths, function ($path) use ($duplicatesFilter) {
return !Preg::isMatch($duplicatesFilter, strtr($path, '\\', '/'));
});
if (\count($paths) > 0) {
$ambiguousClasses[$class] = array_values($paths);
}
}
return $ambiguousClasses;
}
/**
* Sorts the class map alphabetically by class names
*/
public function sort() : void {
ksort($this->map);
}
/**
* @param class-string $className
* @param non-empty-string $path
*/
public function addClass(string $className, string $path) : void {
unset($this->psrViolations[strtr($path, '\\', '/')]);
$this->map[$className] = $path;
}
/**
* @param class-string $className
* @return non-empty-string
*/
public function getClassPath(string $className) : string {
if (!isset($this->map[$className])) {
throw new \OutOfBoundsException('Class ' . $className . ' is not present in the map');
}
return $this->map[$className];
}
/**
* @param class-string $className
*/
public function hasClass(string $className) : bool {
return isset($this->map[$className]);
}
public function addPsrViolation(string $warning, string $className, string $path) : void {
$path = rtrim(strtr($path, '\\', '/'), '/');
$this->psrViolations[$path][] = [
'warning' => $warning,
'className' => $className,
];
}
public function clearPsrViolationsByPath(string $pathPrefix) : void {
$pathPrefix = rtrim(strtr($pathPrefix, '\\', '/'), '/');
foreach ($this->psrViolations as $path => $violations) {
if ($path === $pathPrefix || 0 === \strpos($path, $pathPrefix . '/')) {
unset($this->psrViolations[$path]);
}
}
}
/**
* @param class-string $className
* @param non-empty-string $path
*/
public function addAmbiguousClass(string $className, string $path) : void {
$this->ambiguousClasses[$className][] = $path;
}
public function count() : int {
return \count($this->map);
}
/**
* Get the raw psr violations
*
* This is a map of filepath to an associative array of the warning string
* and the offending class name.
* @return array<string, array<array{warning: string, className: string}>>
*/
public function getRawPsrViolations() : array {
return $this->psrViolations;
}
}
Members
Title Sort descending | Modifiers | Object type | Summary |
---|---|---|---|
ClassMap::$ambiguousClasses | private | property | |
ClassMap::$map | public | property | |
ClassMap::$psrViolations | private | property | |
ClassMap::addAmbiguousClass | public | function | |
ClassMap::addClass | public | function | |
ClassMap::addPsrViolation | public | function | |
ClassMap::clearPsrViolationsByPath | public | function | |
ClassMap::count | public | function | |
ClassMap::getAmbiguousClasses | public | function | A map of class names to their list of ambiguous paths |
ClassMap::getClassPath | public | function | |
ClassMap::getMap | public | function | Returns the class map, which is a list of paths indexed by class name |
ClassMap::getPsrViolations | public | function | Returns warning strings containing details about PSR-0/4 violations that were detected |
ClassMap::getRawPsrViolations | public | function | Get the raw psr violations |
ClassMap::hasClass | public | function | |
ClassMap::sort | public | function | Sorts the class map alphabetically by class names |