Total Complexity | 4 |
Total Lines | 28 |
Duplicated Lines | 0 % |
Coverage | 100% |
Changes | 1 | ||
Bugs | 0 | Features | 0 |
1 | <?php declare(strict_types=1); |
||
24 | final class CodeParser |
||
25 | { |
||
26 | 31 | public static function fromConfiguration(CodeParserConfiguration $configuration): CodeParser |
|
27 | { |
||
28 | 31 | $resolvers = $configuration->extractAssociations() |
|
29 | 9 | ? RelationshipsResolvers::withAssociations() |
|
30 | 22 | : RelationshipsResolvers::withoutAssociations(); |
|
31 | |||
32 | 31 | return new CodeParser(PhpCodeParser::fromConfiguration($configuration), $resolvers); |
|
33 | } |
||
34 | |||
35 | 31 | private function __construct(private readonly PhpCodeParser $parser, private readonly RelationshipsResolvers $resolvers) |
|
|
|||
36 | { |
||
37 | } |
||
38 | |||
39 | /** |
||
40 | * The parsing process is as follows |
||
41 | * |
||
42 | * 1. Parse the code and populate the `Codebase` with definitions |
||
43 | * 2. Add external definitions (built-in/third party), if needed |
||
44 | */ |
||
45 | 25 | public function parse(SourceCode $sourceCode): Codebase |
|
46 | { |
||
47 | 25 | $codebase = $this->parser->parse($sourceCode); |
|
48 | |||
49 | 25 | $this->resolvers->addExternalDefinitionsTo($codebase); |
|
50 | |||
51 | 25 | return $codebase; |
|
52 | } |
||
54 |