This repository has been archived on 2023-08-20. You can view files and clone it, but cannot push or open issues or pull requests.
symfony/src/Symfony/Component/Routing/Loader/AnnotationDirectoryLoader.php

121 lines
3.3 KiB
PHP
Raw Normal View History

2010-07-21 16:43:12 +01:00
<?php
/*
* This file is part of the Symfony package.
2010-07-21 16:43:12 +01:00
*
* (c) Fabien Potencier <fabien@symfony.com>
2010-07-21 16:43:12 +01:00
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
2010-07-21 16:43:12 +01:00
*/
namespace Symfony\Component\Routing\Loader;
use Symfony\Component\Routing\RouteCollection;
use Symfony\Component\Config\Resource\DirectoryResource;
2010-07-21 16:43:12 +01:00
/**
* AnnotationDirectoryLoader loads routing information from annotations set
* on PHP classes and methods.
*
* @author Fabien Potencier <fabien@symfony.com>
2010-07-21 16:43:12 +01:00
*/
class AnnotationDirectoryLoader extends AnnotationFileLoader
{
/**
* Loads from annotations from a directory.
*
* @param string $path A directory path
* @param string|null $type The resource type
2010-07-21 16:43:12 +01:00
*
* @return RouteCollection A RouteCollection instance
*
* @throws \InvalidArgumentException When the directory does not exist or its routes cannot be parsed
2010-07-21 16:43:12 +01:00
*/
public function load($path, $type = null)
2010-07-21 16:43:12 +01:00
{
$dir = $this->locator->locate($path);
2010-07-21 16:43:12 +01:00
$collection = new RouteCollection();
$collection->addResource(new DirectoryResource($dir, '/\.php$/'));
$files = iterator_to_array(new \RecursiveIteratorIterator(
new RecursiveCallbackFilterIterator(
new \RecursiveDirectoryIterator($dir),
function (\SplFileInfo $current) {
return '.' !== substr($current->getBasename(), 0, 1);
}
),
\RecursiveIteratorIterator::LEAVES_ONLY
));
usort($files, function (\SplFileInfo $a, \SplFileInfo $b) {
return (string) $a > (string) $b ? 1 : -1;
});
foreach ($files as $file) {
2010-07-21 16:43:12 +01:00
if (!$file->isFile() || '.php' !== substr($file->getFilename(), -4)) {
continue;
}
if ($class = $this->findClass($file)) {
$refl = new \ReflectionClass($class);
if ($refl->isAbstract()) {
continue;
}
$collection->addCollection($this->loader->load($class, $type));
2010-07-21 16:43:12 +01:00
}
}
return $collection;
}
/**
* {@inheritdoc}
2010-07-21 16:43:12 +01:00
*/
public function supports($resource, $type = null)
2010-07-21 16:43:12 +01:00
{
if (!\is_string($resource)) {
2014-06-25 21:19:01 +01:00
return false;
}
2016-06-20 17:47:20 +01:00
try {
$path = $this->locator->locate($resource);
} catch (\Exception $e) {
return false;
}
2014-06-25 21:19:01 +01:00
return is_dir($path) && (!$type || 'annotation' === $type);
2010-07-21 16:43:12 +01:00
}
}
/**
* @internal To be removed as RecursiveCallbackFilterIterator is available since PHP 5.4
*/
class RecursiveCallbackFilterIterator extends \FilterIterator implements \RecursiveIterator
{
private $iterator;
private $callback;
public function __construct(\RecursiveIterator $iterator, $callback)
{
$this->iterator = $iterator;
$this->callback = $callback;
parent::__construct($iterator);
}
public function accept()
{
return \call_user_func($this->callback, $this->current(), $this->key(), $this->iterator);
}
public function hasChildren()
{
return $this->iterator->hasChildren();
}
public function getChildren()
{
return new static($this->iterator->getChildren(), $this->callback);
}
}