Blame view

public/vendor/symfony/translation/Extractor/AbstractFileExtractor.php 1.87 KB
86143e36f   Андрей Ларионов   Коммит вторник
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
  <?php
  
  /*
   * This file is part of the Symfony package.
   *
   * (c) Fabien Potencier <fabien@symfony.com>
   *
   * For the full copyright and license information, please view the LICENSE
   * file that was distributed with this source code.
   */
  
  namespace Symfony\Component\Translation\Extractor;
  
  use Symfony\Component\Translation\Exception\InvalidArgumentException;
  
  /**
   * Base class used by classes that extract translation messages from files.
   *
   * @author Marcos D. Sánchez <marcosdsanchez@gmail.com>
   */
  abstract class AbstractFileExtractor
  {
      /**
       * @param string|iterable $resource Files, a file or a directory
       *
       * @return iterable
       */
      protected function extractFiles($resource)
      {
          if (is_iterable($resource)) {
              $files = [];
              foreach ($resource as $file) {
                  if ($this->canBeExtracted($file)) {
                      $files[] = $this->toSplFileInfo($file);
                  }
              }
          } elseif (is_file($resource)) {
              $files = $this->canBeExtracted($resource) ? [$this->toSplFileInfo($resource)] : [];
          } else {
              $files = $this->extractFromDirectory($resource);
          }
  
          return $files;
      }
  
      private function toSplFileInfo(string $file): \SplFileInfo
      {
          return new \SplFileInfo($file);
      }
  
      /**
       * @return bool
       *
       * @throws InvalidArgumentException
       */
      protected function isFile(string $file)
      {
          if (!is_file($file)) {
              throw new InvalidArgumentException(sprintf('The "%s" file does not exist.', $file));
          }
  
          return true;
      }
  
      /**
       * @return bool
       */
      abstract protected function canBeExtracted(string $file);
  
      /**
       * @param string|array $resource Files, a file or a directory
       *
       * @return iterable
       */
      abstract protected function extractFromDirectory($resource);
  }