• Home
  • Features
  • Pricing
  • Docs
  • Announcements
  • Sign In

api-platform / core / 14131982970

28 Mar 2025 03:08PM UTC coverage: 8.983% (+0.5%) from 8.517%
14131982970

push

github

soyuka
docs: changelog 4.1.4

13389 of 149040 relevant lines covered (8.98%)

24.16 hits per line

Source File
Press 'n' to go to next uncovered line, 'b' for previous

91.18
/src/Metadata/Util/ReflectionClassRecursiveIterator.php
1
<?php
2

3
/*
4
 * This file is part of the API Platform project.
5
 *
6
 * (c) Kévin Dunglas <dunglas@gmail.com>
7
 *
8
 * For the full copyright and license information, please view the LICENSE
9
 * file that was distributed with this source code.
10
 */
11

12
declare(strict_types=1);
13

14
namespace ApiPlatform\Metadata\Util;
15

16
/**
17
 * Gets reflection classes for php files in the given directories.
18
 *
19
 * @author Antoine Bluchet <soyuka@gmail.com>
20
 *
21
 * @internal
22
 */
23
final class ReflectionClassRecursiveIterator
24
{
25
    /**
26
     * @var array<string, array<class-string, \ReflectionClass>>
27
     */
28
    private static array $localCache;
29

30
    private function __construct()
31
    {
32
    }
×
33

34
    /**
35
     * @param string[] $directories
36
     *
37
     * @return array<class-string, \ReflectionClass>
38
     */
39
    public static function getReflectionClassesFromDirectories(array $directories): array
40
    {
41
        $id = hash('xxh3', implode('', $directories));
8✔
42
        if (isset(self::$localCache[$id])) {
8✔
43
            return self::$localCache[$id];
4✔
44
        }
45

46
        $includedFiles = [];
4✔
47
        foreach ($directories as $path) {
4✔
48
            $iterator = new \RegexIterator(
4✔
49
                new \RecursiveIteratorIterator(
4✔
50
                    new \RecursiveDirectoryIterator($path, \FilesystemIterator::SKIP_DOTS | \FilesystemIterator::FOLLOW_SYMLINKS),
4✔
51
                    \RecursiveIteratorIterator::LEAVES_ONLY
4✔
52
                ),
4✔
53
                '/^(?!.*Test\.php$).+\.php$/i',
4✔
54
                \RecursiveRegexIterator::GET_MATCH
4✔
55
            );
4✔
56

57
            foreach ($iterator as $file) {
4✔
58
                $sourceFile = $file[0];
4✔
59

60
                if (!preg_match('(^phar:)i', (string) $sourceFile)) {
4✔
61
                    $sourceFile = realpath($sourceFile);
4✔
62
                }
63

64
                try {
65
                    require_once $sourceFile;
4✔
66
                } catch (\Throwable) {
×
67
                    // invalid PHP file (example: missing parent class)
68
                    continue;
×
69
                }
70

71
                $includedFiles[$sourceFile] = true;
4✔
72
            }
73
        }
74

75
        $sortedClasses = get_declared_classes();
4✔
76
        sort($sortedClasses);
4✔
77
        $sortedInterfaces = get_declared_interfaces();
4✔
78
        sort($sortedInterfaces);
4✔
79
        $declared = [...$sortedClasses, ...$sortedInterfaces];
4✔
80
        $ret = [];
4✔
81
        foreach ($declared as $className) {
4✔
82
            $reflectionClass = new \ReflectionClass($className);
4✔
83
            $sourceFile = $reflectionClass->getFileName();
4✔
84
            if (isset($includedFiles[$sourceFile])) {
4✔
85
                $ret[$className] = $reflectionClass;
4✔
86
            }
87
        }
88

89
        return self::$localCache[$id] = $ret;
4✔
90
    }
91
}
STATUS · Troubleshooting · Open an Issue · Sales · Support · CAREERS · ENTERPRISE · START FREE · SCHEDULE DEMO
ANNOUNCEMENTS · TWITTER · TOS & SLA · Supported CI Services · What's a CI service? · Automated Testing

© 2025 Coveralls, Inc