laravel / pint by taylorotwell

An opinionated code formatter for PHP.
42,385,573
2,673
35
Package Data
Maintainer Username: taylorotwell
Maintainer Contact: enunomaduro@gmail.com (Nuno Maduro)
Package Create Date: 2022-06-14
Package Last Update: 2024-04-23
Home Page: https://laravel.com
Language: PHP
License: MIT
Last Refreshed: 2024-04-24 03:00:35
Package Statistics
Total Downloads: 42,385,573
Monthly Downloads: 3,105,069
Daily Downloads: 138,674
Total Stars: 2,673
Total Watchers: 35
Total Forks: 123
Total Open Issues: 1

Introduction

Laravel Pint is an opinionated PHP code style fixer for minimalists. Pint is built on top of PHP-CS-Fixer and makes it simple to ensure that your code style stays clean and consistent.

Installation

Laravel Pint requires PHP 8.0+.

You may use Composer to install Pint into your PHP project:

composer require laravel/pint --dev

Once Pint has been installed, the pint binary will be available in your project's vendor/bin directory:

./vendor/bin/pint

Running Pint

When running Pint, it will output a list of files that have been fixed. It is possible to see the changes made in more detail using the -v option:

./vendor/bin/pint -v

In addition, if you would like Pint to simply inspect your code for style errors without actually changing the files, you may use the --test option:

./vendor/bin/pint --test

Configuring Pint

By default, Pint does not require any configuration and will fix code style issues in your code by following the opinionated coding style of Laravel.

However, if you wish to customize the presets, rules, or inspected folders, you may do so by creating a pint.json file in your project's root directory:

{
    "preset": "laravel"
}

In addition, if you wish to use a pint.json from a specific directory, you may use the --config option:

pint --config vendor/my-company/coding-style/pint.json

Presets

Presets define a set of rules that can be used to fix code style issues in your code. By default, Pint uses the laravel preset, which fixes issues by following the opinionated coding style of Laravel.

However, you can use a different preset by passing the --preset option:

pint --preset psr12

If you wish, you may also set the preset in your project's pint.json file:

{
    "preset": "psr12"
}

The currently supported presets are: laravel, psr12, and symfony.

Rules

Rules are style guidelines that Pint will use to fix code style issues in your code. As mentioned above, presets are predefined groups of rules that should be perfect for most PHP projects, so you typically will not need to worry about the individual rules they contain.

However, if you wish, you may enable or disable specific rules in your pint.json file:

{
    "preset": "laravel",
    "rules": {
        "simplified_null_return": true,
        "braces": false,
        "new_with_braces": {
            "anonymous_class": false,
            "named_class": false
        }
    }
}

Pint is built on top of PHP-CS-Fixer. Therefore, you may use any of its rules to fix code style issues in your project: PHP-CS-Fixer Configurator.

Exclude Folders

By default, Pint will inspect all .php files in your project except those in the vendor folder. If you wish to exclude more folders, you may do so by using the exclude configuration option:

{
    "exclude": [
        "my-specific/folder"
    ]
}

Exclude Files

If you wish to exclude file with specified name, you may do so by using the notName configuration option:

{
    "notName": [
        "*-my-file.php"
    ]
}

If you want to exclude file from exact path, you may do so by using the notPath configuration option:

{
    "notPath": [
        "path/to/excluded-file.php"
    ]
}

Contributing

Thank you for considering contributing to Pint! You can read the contribution guide here.

Code of Conduct

In order to ensure that the Laravel community is welcoming to all, please review and abide by the Code of Conduct.

Security Vulnerabilities

Please review our security policy on how to report security vulnerabilities.

License

Pint is open-sourced software licensed under the MIT license.