3.3 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	How to contribute to PMD
First off, thanks for taking the time to contribute!
Please note that this project is released with a Contributor Code of Conduct. By participating in this project you agree to abide by its terms.
You can find the code of conduct in the file code_of_conduct.md.
| NB: the rule designer is developed over at pmd/pmd-designer. Please refer to the specific contributor documentation if your issue, feature request or PR touches the designer. | 
|---|
Pull requests
- 
Please create your pull request against the masterbranch. We will rebase/merge it to the maintenance branches, if necessary.
- 
We are using checkstyle to enforce a common code style. The check is integrated into the default build - so, make sure, you can build PMD without errors. See code style for more info. 
Bug reports
We use the issue tracker on Github. Please report new bugs at https://github.com/pmd/pmd/issues.
When filing a bug report, please provide as much information as possible, so that we can reproduce the issue:
- The name of the rule, that is buggy
- A code snippet, which triggers a false positive/negative or crash
- How do you execute PMD? (command line, ant, maven, gradle, other)
Documentation
There is some documentation available under https://pmd.github.io/latest. Feel free to create a bug report if documentation is missing, incomplete or outdated. See Bug reports.
The documentation is generated as a Jekyll site, the source is available at: https://github.com/pmd/pmd/tree/master/docs. You can find build instructions there. For more on contributing documentation check https://pmd.github.io/pmd/pmd_devdocs_writing_documentation.html
Questions
There are various channels, on which you can ask questions:
- 
On StackOverflow: Make sure, to tag your question with "pmd". 
- 
Create a new discussion for your question at https://github.com/pmd/pmd/discussions. 
- 
Ask your question on Gitter https://gitter.im/pmd/pmd. 
Code Style
PMD uses checkstyle to enforce a common code style.
See pmd-checkstyle-config.xml for the configuration and the eclipse configuration files that can be imported into a fresh workspace.
Add yourself as contributor
We use All Contributors.
To add yourself to the table of contributors, follow the bot usage instructions ;).
Or use the CLI:
- Install the CLI: npm i(in PMD's top level directory)
- Add yourself: npx all-contributors add <username> <contribution>
Where username is your GitHub username and contribution is a ,-separated list
of contributions. See Emoji Key for a list
of valid types. Common types are: "code", "doc", "bug", "blog", "talk", "test", "tutorial".
See also cli documentation
