Passed
Pull Request — master (#69)
by Dave
02:17
created

JsonOutputFormatter::getIdentifier()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
cc 1
eloc 1
nc 1
nop 0
dl 0
loc 3
rs 10
c 0
b 0
f 0
1
<?php
2
3
declare(strict_types=1);
4
5
namespace DaveLiddament\StaticAnalysisResultsBaseliner\Plugins\OutputFormatters;
6
7
use DaveLiddament\StaticAnalysisResultsBaseliner\Domain\OutputFormatter\OutputFormatter;
8
use DaveLiddament\StaticAnalysisResultsBaseliner\Domain\ResultsParser\AnalysisResults;
9
use DaveLiddament\StaticAnalysisResultsBaseliner\Domain\Utils\JsonUtils;
10
11
class JsonOutputFormatter implements OutputFormatter
12
{
13
    public function outputResults(
14
        AnalysisResults $baseLineRemovedResults
15
    ): string {
16
        $results = [];
17
18
        foreach ($baseLineRemovedResults->getAnalysisResults() as $analysisResult) {
19
            $location = $analysisResult->getLocation();
20
            $results[] = [
21
                'file' => $location->getAbsoluteFileName()->getFileName(),
22
                'line' => $location->getLineNumber()->getLineNumber(),
23
                'type' => $analysisResult->getType()->getType(),
24
                'message' => $analysisResult->getMessage(),
25
            ];
26
        }
27
28
        return JsonUtils::toString($results);
29
    }
30
31
    public function getIdentifier(): string
32
    {
33
        return 'json';
34
    }
35
}
36