123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172 |
- <?php
- /*
- * This file is part of the Symfony package.
- *
- * (c) Fabien Potencier <fabien.potencier@symfony-project.com>
- *
- * For the full copyright and license information, please view the LICENSE
- * file that was distributed with this source code.
- */
- namespace Symfony\Component\Config\Resource;
- /**
- * DirectoryResource represents a resources stored in a subdirectory tree.
- *
- * @author Fabien Potencier <fabien.potencier@symfony-project.com>
- */
- class DirectoryResource implements ResourceInterface
- {
- protected $resource;
- /**
- * Constructor.
- *
- * @param string $resource The file path to the resource
- */
- public function __construct($resource)
- {
- $this->resource = realpath($resource);
- }
- /**
- * Returns a string representation of the Resource.
- *
- * @return string A string representation of the Resource
- */
- public function __toString()
- {
- return (string) $this->resource;
- }
- /**
- * Returns the resource tied to this Resource.
- *
- * @return mixed The resource
- */
- public function getResource()
- {
- return $this->resource;
- }
- /**
- * Returns true if the resource has not been updated since the given timestamp.
- *
- * @param integer $timestamp The last time the resource was loaded
- *
- * @return Boolean true if the resource has not been updated, false otherwise
- */
- public function isFresh($timestamp)
- {
- if (!file_exists($this->resource)) {
- return false;
- }
- $newestMTime = 0;
- foreach (new \RecursiveIteratorIterator(new \RecursiveDirectoryIterator($this->resource), \RecursiveIteratorIterator::LEAVES_ONLY) as $file) {
- $newestMTime = max(filemtime($file), $newestMTime);
- }
- return $newestMTime < $timestamp;
- }
- }
|