Contributions are welcome and will be fully credited.
We accept contributions via pull requests via Github.
- Fork the project.
- Create your bugfix/feature branch and write your (well-commented) code.
- Ensure you follow our coding style:
- Run
composer run style:check
to check. - Run
composer run style:fix
to automagically fix styling errors.
- Run
- Run basic static analysis on your code with
composer run analyze
and fix any errors. - Create unit tests for your code:
- Run
composer install --dev
in the root directory to install required testing packages. - Add your test classes/methods to the
/tests/
directory. - Run
composer run tests
and make sure everything passes (new and old tests).
- Run
- Updated any documentation (e.g. in
README.md
), if appropriate. - Commit your changes (and your tests) and push to your branch.
- Create a new pull request against this package's
master
branch.
-
Use the PHP-CS-Fixer Coding Standard. The easiest way to apply the conventions is to run
composer run style:fix
. -
Run static analysis with phpstan. The easiest way to check is with
composer run analyze
. Bonus points if you can bump up the analysis level inphpstan.dist.neon
! -
Add tests! Your pull request won't be accepted if it doesn't have tests.
-
Document any change in behaviour. Make sure the
README.md
and any other relevant documentation are kept up-to-date. -
Consider our release cycle. We try to follow SemVer v2.0.0. Randomly breaking public APIs is not an option.
-
Create feature branches. Don't ask us to pull from your master branch.
-
One pull request per feature. If you want to do more than one thing, send multiple pull requests.
-
Send coherent history. - Make sure each individual commit in your pull request is meaningful. If you had to make multiple intermediate commits while developing, please squash them before submitting.
-
Don't worry about updating
CHANGELOG.md
or.semver
. The package administrator will handle updating those when new releases are created.
Thank you!