mobi/coding-standards

Mobilteitsdiensten Coding Standards

Installs: 19

Dependents: 0

Suggesters: 0

Security: 0

pkg:composer/mobi/coding-standards

dev-master 2024-09-03 09:21 UTC

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>