monomelodies / codein
PHP code analysis library
Requires
- monolyth/cliff: ^0.7.0
- simoneast/simple-ansi-colors: ^1.0
Requires (Dev)
- gentry/gentry: ^0.14.0
- gentry/toast: ^0.1.1
- toast/unit: ^2.1
This package is auto-updated.
Last update: 2025-01-08 18:50:02 UTC
README
Code analysis, creation and modification library
Installation
$ composer require --dev monomelodies/codein
Usage
Codein is a CLI tool to inspect PHP files or directories of PHP files for code smells. It currently works best on classes.
$ vendor/bin/codein [OPTIONS] path/to/file/or/directory
If the supplied argument is a PHP file, just that file is analysed. If it is a directory, all PHP files in it are scanned.
Options
-r|--recursive Recursively iterate underlying directories --check=name/of/check One or more names of things to check
Adding checks
By default, Codein only scans for PHP parsing errors (hopefully, your editor is already set up to do that!). To make it more useful, one should add plugins.
Why plugins one might ask? Well, my coding style isn't going to be yours, and what I consider a code smell (missing return type hint, for instance) might be perfectly valid in your codebase (because you need to support legacy PHP versions, for instance).
Let's add a check for those return type hints:
$ composer require --dev monomelodies/codein-typehints $ vendor/bin/codein --check=monomelodies/codein-typehints path/to/file
Writing plugins
Each plugin should extend Sensi\Codein\Check
. The grunt of the work is done in
the check
method. It takes a single argument (the name of the file to check)
and returns a Generator
. Every time your plugin encounters a code smell, it
should yield
a string containing an error message. You can use the builtin
extractClass
method to get the name of the class contained in the file,
allowing you to inspect.
Codein auto-appends the classname Check
to the namespace specified in the
--check=...
option. Normal namespace resolution rules are applied:
- forward slashes are replaced with backward slashes;
- each part starts with a capital letter;
- dashes are converted to snakeCase.
E.g., monomelodies/codein-typehints
resolves to the class
Monomelodies\CodeinTypehints\Check
.
Look at existing plugins to get a feel for this.
The yielded messages are formatted using
simple ansi colors, with a
"<reset>\n"
automatically appended. You can play with the colors; use
for something really bad, for a warning etc.
The codein.json
config file
Codein looks for a codein.json
config file in the current working directory.
It allows you to specify a few things:
- A default array of
checks
. The checks are run no matter what--check=...
options you specify. Handy, because with multiple plugins typing them all out each time quickly becomes old. - A string or array of
bootstrap
files (relative togetcwd()
, again). Your project, for instance, may rely on dependency injection, configured in a central file. - A
constructors
object containing a key/value store of classnames with an array of the arguments to be used during construction when inspecting. Note that these arguments are verbatim; e.g. a string should be written as"'this is a string'"
(note the nested quotes). This is because some classes will expect an instantiated object in their constructor arguments, allowing you to specify something like "new FooBar" as well.