In this article, I will give you a step-by-step guide on how to configure CodeSniffer for PhpStorm + Docksal. For Docker it should not be a big difference in settings.
data:image/s3,"s3://crabby-images/735ad/735ad2250d6b1de8f29b9c2111b4fecd1d8fdf5e" alt="Profile picture for user Dima Suharchuk"
In this article, I will give you a step-by-step guide on how to configure CodeSniffer for PhpStorm + Docksal. For Docker it should not be a big difference in settings.
“I'd like to show you how to set up tools to help make your code presentable.”
CodeSniffer will continuously check your code for standards inconsistencies and mark it as warnings in the IDE. You should pay attention to the fact that this is a fairly resource-intensive process, and you should have a pretty powerful computer.
First, you need to install the PHP_CodeSniffer and Drupal coder libraries: `fin composer require squizlabs/php_codesniffer drupal/coder`.
Now we can go directly to the "CodeSniffer settings" in PhpStorm.
Go to settings `Ctrl+Alt+S` > PHP and add a PHP interpreter.
Add an interpreter following the instructions below.
You have to select the cli-image of the project in "Image name". If you are not sure, or you don’t know what to choose here, then you can find out it using this command: `fin config | grep "image: docksal/cli"`. If you get nothing, then you need to check the file `.docksal/docksal.env`, also `.docksal/docksal-local.env` and `.docksal/services/cli/Dockerfile`, if they exist.
If everything is done correctly, you will see the following screen. Press OK.
Note that the PhpStorm has set the project path as `/opt/project`, but this doesn’t work for Docksal. You need to edit that path and set `/var/www`.
If done correctly, the path should change here.
After setting up the PHP interpreter, it will appear on the select list here: PHP > Quality Tools. Select the interpreter in the select list you just added and click "Apply".
Now you need to add paths for CodeSniffer. To do this, in the same modal dialog, you should go to the configuration.
PhpStorm has already prescribed all the paths, so click "Validate" and after a few seconds you will see a message below saying which version of CodeSniffer is installed. Click "Apply".
Next, you need to go to PHP_CodeSniffer Inspection on the same modal window:
Now you need to:
Going in "PHP_CodeSniffer inspection" again.
Now the standards have been added to the select list, and we choose the Drupal standard.
Also note that more file types can be added here. I added "module" and "theme".
Click OK on all modal windows.
You have set up CodeSniffer in PhpStorm! ???????????? You can now open any class/file of your module and press `Alt+6`. You will be shown all the problems that PhpStorm + CodeSniffer found. The code will be underlined as well.
To disable CodeSniffer, just uncheck one checkbox here.
Consider subscribing to our social media.
We much appreciate it.
If you have Docksal, but you don’t use PhpStorm or don’t want to load the processor with continuously checking for standards, then there is an option of using CodeSniffer in manual mode.
For convenience, put the addon: `fin addon install phpcs`.
A script to manually run the Drupal standards check with CodeSniffer will be placed in the ".docksal" directory of your project.
To run the script, enter the command: `fin phpcs cs {FILE/DIR PATH}`.
The console will display the non-compliance with the standards code, which CodeSniffer will find in the file or directory (recursively).
If there is no error in the file, nothing will be displayed in the console.
Another tool worth mentioning is the PHP Code Beautifier and Fixer. It can fix some minor inaccuracies in the code such as wrong indents, extra spaces, etc.
It can be launched with the following command: `fin phpcs cbf {FILE/DIR PATH}`.
Actually, if you work in PhpStorm, this tool will not be very useful, because PhpStorm has a built-in code formatting function called by the `Ctrl+Alt+L` hotkey (additional function settings are called by `Ctrl+Alt+Shift+L`).
So, I hope this article helped you and your code will always be clean and well documented! :)