mobi / coding-standards
Mobilteitsdiensten Coding Standards
Conflicts
- php: <8.0
- friendsofphp/php-cs-fixer: <3.11
- phpmd/phpmd: <2.0
- phpstan/phpstan: <0.12.50
This package is auto-updated.
Last update: 2025-12-31 00:17:22 UTC
README
Bevat files voor de coding standaarden die gehanteerd worden binnen Mobiliteitsdiensten Nederland. Het bevat coding standaarden voor php cs fixer, phpstan en phpmd.
Installeren
Voeg de dependency toe als een (dev) dependency via Composer.
composer require mobi/coding-standards:dev-master --dev
Let op! Hiermee zijn nog niet alle benodigde tools geïnstalleerd. Deze package bevat enkel configuratie bestanden.
Configuratie
PHP-CS-Fixer
Voeg een .php-cs-fixer.php bestand toe aan je project met de volgende minimale configuratie:
<?php
$finder = PhpCsFixer\Finder::create()
->in(__DIR__)
->path([
'/^app/',
'/^src/',
...
]);
/** @var PhpCsFixer\Config $config */
$config = include 'vendor/mobi/coding-standards/rules/php-cs-fixer.php';
return $config->setFinder($finder);
vendor/bin/php-cs-fixer fix --dry-run --diff --show-progress=dots --verbose
Veel van de beschikbare php-cs-fixer regels kunnen worden gebruikt om de voorgedefinieerde regels aan te passen of extra regels toe te voegen:
return $config->setFinder($finder)
->setRules(
array_merge($config->getRules(), [
'no_space_around_double_colon' => false,
])
);
Let op: het gebruik van
array_merge($config->getRules(), [])is nodig om de voorgedefinieerde regels aan te vullen.
PHPStan
Voeg een phpstan.neon bestand toe aan je project met de volgende minimale configuratie:
includes:
- ./vendor/mobi/coding-standards/rules/phpstan.neon
parameters:
paths:
- app
- src
...
vendor/bin/phpstan analyze --memory-limit=2G
Veel van de beschikbare phpstan configuratie kan worden gebruikt voor het aanpassen van onder andere voorgedefinieerde regels of eventueel errors die genegeerd mogen worden:
parameters:
ignoreErrors:
- '#Parameter \#3 \$count of method Illuminate\\Database\\Eloquent\\Builder(.*)::has\(\) expects int, Illuminate\\Database\\Query\\Expression given.#'
checkUnionTypes: false
PHPMD
Voeg een phpmd.xml bestand toe aan je project met de volgende minimale configuratie:
<?xml version="1.0"?>
<ruleset name="Mobiliteitsdiensten phpmd configuration"
xmlns="http://pmd.sf.net/ruleset/1.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://pmd.sf.net/ruleset/1.0.0 http://pmd.sf.net/ruleset_xml_schema.xsd"
xsi:noNamespaceSchemaLocation=" http://pmd.sf.net/ruleset_xml_schema.xsd">
<rule ref="vendor/mobi/coding-standards/rules/phpmd.xml" />
</ruleset>
vendor/bin/phpmd app src ... phpmd.xml
Veel van de beschikbare phpmd regels kunnen worden gebruikt in de configuratie om bijvoorbeeld de voorgedefinieerde regels aan te passen of extra regels toe te voegen:
<rule ref="vendor/mobi/coding-standards/rules/phpmd.xml" />
<rule ref="rulesets/codesize.xml/CyclomaticComplexity">
<priority>1</priority>
<properties>
<property name="reportLevel" value="5" />
</properties>
</rule>
<rule ref="rulesets/naming.xml">
<exclude name="LongVariable" />
</rule>