Completed
Pull Request — master (#290)
by Enrico
04:49 queued 02:11
created

Factory   A

Complexity

Total Complexity 15

Size/Duplication

Total Lines 175
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 2

Test Coverage

Coverage 98.13%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
dl 0
loc 175
ccs 105
cts 107
cp 0.9813
rs 10
c 1
b 0
f 0
wmc 15
lcom 1
cbo 2

6 Methods

Rating   Name   Duplication   Size   Complexity  
A getPassesConfigurations() 0 18 4
B factory() 0 43 4
A getPassesMetadata() 0 18 4
B getStatementPasses() 0 27 1
B getExpressionPasses() 0 35 1
A getScalarPasses() 0 6 1
1
<?php
2
/**
3
 * @author Patsura Dmitry https://github.com/ovr <[email protected]>
4
 */
5
6
namespace PHPSA\Analyzer;
7
8
use PHPSA\Analyzer;
9
use PHPSA\Configuration;
10
use Symfony\Component\Config\Definition\Builder\NodeDefinition;
11
use Webiny\Component\EventManager\EventManager;
12
use PHPSA\Analyzer\Pass as AnalyzerPass;
13
14
class Factory
15
{
16
    /**
17
     * @return NodeDefinition[]
18
     */
19 3
    public static function getPassesConfigurations()
20
    {
21 2
        $configs = [];
22
23 2
        foreach (self::getExpressionPasses() as $passClass) {
24 2
            $configs[] = $passClass::getMetadata()->getConfiguration();
25 2
        }
26
27 3
        foreach (self::getStatementPasses() as $passClass) {
28 2
            $configs[] = $passClass::getMetadata()->getConfiguration();
29 2
        }
30
31 2
        foreach (self::getScalarPasses() as $passClass) {
32 2
            $configs[] = $passClass::getMetadata()->getConfiguration();
33 2
        }
34
35 2
        return $configs;
36
    }
37
38
    /**
39
     * @return \PHPSA\Analyzer\Pass\Metadata[]
40
     */
41 1
    public static function getPassesMetadata()
42
    {
43 1
        $meta = [];
44
45 1
        foreach (self::getExpressionPasses() as $passClass) {
46 1
            $meta[] = $passClass::getMetadata();
47 1
        }
48
49 1
        foreach (self::getStatementPasses() as $passClass) {
50 1
            $meta[] = $passClass::getMetadata();
51 1
        }
52
53 1
        foreach (self::getScalarPasses() as $passClass) {
54 1
            $meta[] = $passClass::getMetadata();
55 1
        }
56
57 1
        return $meta;
58
    }
59
60
    /**
61
     * @param EventManager $eventManager
62
     * @param Configuration $config
63
     * @return Analyzer
64
     */
65 50
    public static function factory(EventManager $eventManager, Configuration $config)
0 ignored issues
show
Best Practice introduced by
Using PHP4-style constructors that are named like the class is not recommend; better use the more explicit __construct method.
Loading history...
66
    {
67 50
        $analyzersConfig = $config->getValue('analyzers');
68
69
        $filterEnabled = function ($passClass) use ($config, $analyzersConfig) {
70
            /** @var AnalyzerPass\Metadata $passMetadata */
71 50
            $passMetadata = $passClass::getMetadata();
72
73 50
            if (!isset($analyzersConfig[$passMetadata->getName()])) {
74 49
                return false;
75
            }
76
77 50
            if (!$analyzersConfig[$passMetadata->getName()]['enabled']) {
78
                return false;
79
            }
80
81 50
            if (!$passMetadata->allowsPhpVersion($config->getValue('language_level'))) {
82
                return false;
83
            }
84
85 50
            return true;
86 50
        };
87
88 50
        $instanciate = function ($passClass) use ($analyzersConfig) {
89 50
            $passName = $passClass::getMetadata()->getName();
90
91 50
            return new $passClass($analyzersConfig[$passName]);
92 50
        };
93
94 50
        $analyzer = new Analyzer($eventManager);
95 50
        $analyzer->registerExpressionPasses(
96 50
            array_map($instanciate, array_filter(self::getExpressionPasses(), $filterEnabled))
97 50
        );
98 50
        $analyzer->registerStatementPasses(
99 50
            array_map($instanciate, array_filter(self::getStatementPasses(), $filterEnabled))
100 50
        );
101 50
        $analyzer->registerScalarPasses(
102 50
            array_map($instanciate, array_filter(self::getScalarPasses(), $filterEnabled))
103 50
        );
104 50
        $analyzer->bind();
105
106 50
        return $analyzer;
107
    }
108
109
    /**
110
     * @return array
111
     */
112 52
    private static function getStatementPasses()
113
    {
114
        return [
115 52
            AnalyzerPass\Statement\MagicMethodParameters::class,
116 52
            AnalyzerPass\Statement\GotoUsage::class,
117 52
            AnalyzerPass\Statement\GlobalUsage::class,
118 52
            AnalyzerPass\Statement\HasMoreThanOneProperty::class,
119 52
            AnalyzerPass\Statement\MissingBreakStatement::class,
120 52
            AnalyzerPass\Statement\MissingVisibility::class,
121 52
            AnalyzerPass\Statement\MethodCannotReturn::class,
122 52
            AnalyzerPass\Statement\UnexpectedUseOfThis::class,
123 52
            AnalyzerPass\Statement\TestAnnotation::class,
124 52
            AnalyzerPass\Statement\MissingDocblock::class,
125 52
            AnalyzerPass\Statement\OldConstructor::class,
126 52
            AnalyzerPass\Statement\ConstantNaming::class,
127 52
            AnalyzerPass\Statement\MissingBody::class,
128 52
            AnalyzerPass\Statement\InlineHtmlUsage::class,
129 52
            AnalyzerPass\Statement\AssignmentInCondition::class,
130 52
            AnalyzerPass\Statement\StaticUsage::class,
131 52
            AnalyzerPass\Statement\OptionalParamBeforeRequired::class,
132 52
            AnalyzerPass\Statement\YodaCondition::class,
133 52
            AnalyzerPass\Statement\ForCondition::class,
134 52
            AnalyzerPass\Statement\PropertyDefinitionDefaultValue::class,
135 52
            AnalyzerPass\Statement\ReturnAndYieldInOneMethod::class,
136 52
            AnalyzerPass\Statement\ReturnVoid::class,
137 52
        ];
138
    }
139
140
    /**
141
     * @return array
142
     */
143 52
    private static function getExpressionPasses()
144
    {
145
        return [
146
            // Another
147 52
            AnalyzerPass\Expression\ErrorSuppression::class,
148 52
            AnalyzerPass\Expression\MultipleUnaryOperators::class,
149 52
            AnalyzerPass\Expression\StupidUnaryOperators::class,
150 52
            AnalyzerPass\Expression\VariableVariableUsage::class,
151 52
            AnalyzerPass\Expression\Casts::class,
152 52
            AnalyzerPass\Expression\EvalUsage::class,
153 52
            AnalyzerPass\Expression\FinalStaticUsage::class,
154 52
            AnalyzerPass\Expression\CompareWithArray::class,
155 52
            AnalyzerPass\Expression\DivisionFromZero::class,
156 52
            AnalyzerPass\Expression\DivisionByOne::class,
157 52
            AnalyzerPass\Expression\BacktickUsage::class,
158 52
            AnalyzerPass\Expression\LogicInversion::class,
159 52
            AnalyzerPass\Expression\ExitUsage::class,
160 52
            AnalyzerPass\Expression\NestedTernary::class,
161
            // Arrays
162 52
            AnalyzerPass\Expression\ArrayShortDefinition::class,
163 52
            AnalyzerPass\Expression\ArrayDuplicateKeys::class,
164 52
            AnalyzerPass\Expression\ArrayIllegalOffsetType::class,
165
            // Function call
166 52
            AnalyzerPass\Expression\FunctionCall\AliasCheck::class,
167 52
            AnalyzerPass\Expression\FunctionCall\DebugCode::class,
168 52
            AnalyzerPass\Expression\FunctionCall\RandomApiMigration::class,
169 52
            AnalyzerPass\Expression\FunctionCall\SleepUsage::class,
170 52
            AnalyzerPass\Expression\FunctionCall\UseCast::class,
171 52
            AnalyzerPass\Expression\FunctionCall\DeprecatedIniOptions::class,
172 52
            AnalyzerPass\Expression\FunctionCall\RegularExpressions::class,
173 52
            AnalyzerPass\Expression\FunctionCall\ArgumentUnpacking::class,
174 52
            AnalyzerPass\Expression\FunctionCall\UnsafeUnserialize::class,
175 52
            AnalyzerPass\Expression\FunctionCall\DeprecatedFunctions::class,
176 52
        ];
177
    }
178
179
    /**
180
     * @return array
181
     */
182 52
    private static function getScalarPasses()
183
    {
184
        return [
185 52
            AnalyzerPass\Scalar\CheckLNumberKind::class,
186 52
        ];
187
    }
188
}
189