Mercurial > hg > isophonics-drupal-site
annotate vendor/symfony/validator/Mapping/Loader/FilesLoader.php @ 19:fa3358dc1485 tip
Add ndrum files
author | Chris Cannam |
---|---|
date | Wed, 28 Aug 2019 13:14:47 +0100 |
parents | 129ea1e6d783 |
children |
rev | line source |
---|---|
Chris@0 | 1 <?php |
Chris@0 | 2 |
Chris@0 | 3 /* |
Chris@0 | 4 * This file is part of the Symfony package. |
Chris@0 | 5 * |
Chris@0 | 6 * (c) Fabien Potencier <fabien@symfony.com> |
Chris@0 | 7 * |
Chris@0 | 8 * For the full copyright and license information, please view the LICENSE |
Chris@0 | 9 * file that was distributed with this source code. |
Chris@0 | 10 */ |
Chris@0 | 11 |
Chris@0 | 12 namespace Symfony\Component\Validator\Mapping\Loader; |
Chris@0 | 13 |
Chris@0 | 14 /** |
Chris@0 | 15 * Base loader for loading validation metadata from a list of files. |
Chris@0 | 16 * |
Chris@0 | 17 * @author Bulat Shakirzyanov <mallluhuct@gmail.com> |
Chris@0 | 18 * @author Bernhard Schussek <bschussek@gmail.com> |
Chris@0 | 19 * |
Chris@0 | 20 * @see YamlFilesLoader |
Chris@0 | 21 * @see XmlFilesLoader |
Chris@0 | 22 */ |
Chris@0 | 23 abstract class FilesLoader extends LoaderChain |
Chris@0 | 24 { |
Chris@0 | 25 /** |
Chris@0 | 26 * Creates a new loader. |
Chris@0 | 27 * |
Chris@0 | 28 * @param array $paths An array of file paths |
Chris@0 | 29 */ |
Chris@0 | 30 public function __construct(array $paths) |
Chris@0 | 31 { |
Chris@0 | 32 parent::__construct($this->getFileLoaders($paths)); |
Chris@0 | 33 } |
Chris@0 | 34 |
Chris@0 | 35 /** |
Chris@0 | 36 * Returns an array of file loaders for the given file paths. |
Chris@0 | 37 * |
Chris@0 | 38 * @param array $paths An array of file paths |
Chris@0 | 39 * |
Chris@0 | 40 * @return LoaderInterface[] The metadata loaders |
Chris@0 | 41 */ |
Chris@0 | 42 protected function getFileLoaders($paths) |
Chris@0 | 43 { |
Chris@17 | 44 $loaders = []; |
Chris@0 | 45 |
Chris@0 | 46 foreach ($paths as $path) { |
Chris@0 | 47 $loaders[] = $this->getFileLoaderInstance($path); |
Chris@0 | 48 } |
Chris@0 | 49 |
Chris@0 | 50 return $loaders; |
Chris@0 | 51 } |
Chris@0 | 52 |
Chris@0 | 53 /** |
Chris@0 | 54 * Creates a loader for the given file path. |
Chris@0 | 55 * |
Chris@0 | 56 * @param string $path The file path |
Chris@0 | 57 * |
Chris@0 | 58 * @return LoaderInterface The created loader |
Chris@0 | 59 */ |
Chris@0 | 60 abstract protected function getFileLoaderInstance($path); |
Chris@0 | 61 } |