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

eliashaeussler / phpstan-config / 22732864626

05 Mar 2026 07:21PM UTC coverage: 40.945% (-55.7%) from 96.654%
22732864626

Pull #132

github

eliashaeussler
[FEATURE] Add custom rule to compare composer.json and ext_emconf.php
Pull Request #132: [FEATURE] Add custom rule to compare composer.json and ext_emconf.php

3 of 369 new or added lines in 12 files covered. (0.81%)

260 of 635 relevant lines covered (40.94%)

3.59 hits per line

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

0.0
/src/Resource/JsonFile.php
1
<?php
2

3
declare(strict_types=1);
4

5
/*
6
 * This file is part of the Composer package "eliashaeussler/phpstan-config".
7
 *
8
 * Copyright (C) 2023-2026 Elias Häußler <elias@haeussler.dev>
9
 *
10
 * This program is free software: you can redistribute it and/or modify
11
 * it under the terms of the GNU General Public License as published by
12
 * the Free Software Foundation, either version 3 of the License, or
13
 * (at your option) any later version.
14
 *
15
 * This program is distributed in the hope that it will be useful,
16
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18
 * GNU General Public License for more details.
19
 *
20
 * You should have received a copy of the GNU General Public License
21
 * along with this program. If not, see <https://www.gnu.org/licenses/>.
22
 */
23

24
namespace EliasHaeussler\PHPStanConfig\Resource;
25

26
use JsonException;
27

28
use function file_get_contents;
29
use function is_array;
30
use function json_decode;
31

32
/**
33
 * JsonFile.
34
 *
35
 * @author Elias Häußler <elias@haeussler.dev>
36
 * @license GPL-3.0-or-later
37
 */
38
final class JsonFile
39
{
40
    /**
41
     * @var array<string, array<mixed>|null>
42
     */
43
    private static array $parsed = [];
44

NEW
45
    public function __construct(
×
46
        public readonly string $path,
NEW
47
    ) {}
×
48

49
    /**
50
     * @return array<mixed>|null
51
     */
NEW
52
    public function parse(): ?array
×
53
    {
NEW
54
        if ((self::$parsed[$this->path] ?? null) !== null) {
×
NEW
55
            return self::$parsed[$this->path];
×
56
        }
57

NEW
58
        $content = file_get_contents($this->path);
×
59

NEW
60
        if (false === $content) {
×
NEW
61
            return null;
×
62
        }
63

64
        try {
NEW
65
            $decoded = json_decode($content, true, 512, JSON_THROW_ON_ERROR);
×
NEW
66
        } catch (JsonException) {
×
NEW
67
            return null;
×
68
        }
69

NEW
70
        if (!is_array($decoded)) {
×
NEW
71
            $decoded = null;
×
72
        }
73

NEW
74
        return self::$parsed[$this->path] = $decoded;
×
75
    }
76
}
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

© 2026 Coveralls, Inc