To contribute to this project, you must follow the Code of Conduct and Coding Standards, as well as observe the guidelines for Pull Requests.
-
Keep your criticism constructive. Discussion over algorithms, implementations, and documentation/comment wording is constructive. Personal attacks are not constructive.
-
You may not harass other contributors in any way, nor other contributors of other projects, nor do anything that would promote a culture of hostility to prevent others from contributing. Contributing to this project makes you a tangential representative of it. Act accordingly.
-
The bracing style is Allman, for the most part. Some try/catches use K&R. The primary maintainer of this codebase prefers consistency within code over arguing the merits of each style. Discussions over a change of style will not be entertained.
-
Hard tabs in code. Again, the primary maintainer of this codebase prefers consistency within code over arguing the merits of each style. Discussions over a change of style will not be entertained.
-
You are contributing to a general library/API. As such, all public and protected fields and methods must have Javadoc comments. Private or default method/field Javadocs are optional (but may be encouraged if the method is very complex), but sometimes just a comment is fine, for elucidation.
-
Unless the variable is temporary or "throwaway," use descriptive names. We have IDEs, now. Autocomplete is a thing.
-
Methods must have purposeful names, but not excessively large, descriptive ones. That's what documentation is for.
-
You may not add additional dependencies to this project. Stay in the java.base module (and its child dependencies). However, removal of dependencies, if any, are a welcome proposition.
-
All Pull Requests are subject to review before acceptance. If your feature or contribution is not accepted, understand that it may be due to it not aligning with the project's philosophy or purpose, coding standards aside. Don't worry - there's no shame in use using this library as a dependency for your toolset!
-
All Pull Requests must be made against
master
or a "master-derivative" branch. -
You must specify what you are adding or fixing. Without context for the PR, it cannot be reviewed adequately, nor ultimately accepted.
-
Understand that not all contributions are worthy by default - any new features must fill a utilitarian deficit or fix a clear bug ("bug" is this case is defined as an unintended behavior).
-
Refactorings of existing classes/packages are at the discretion of the primary maintainer. Please ask if you are unsure whether or not a feature requires a new package, and accept direction if another or different package (or project) is necessary to accommodate your feature.
-
"Bikeshed" features/corrections will not be accepted without adequate justification.
-
The primary maintainer of this codebase is not a believer in "Good or readable code needs no comments." If you are asked to clarify sections of code with plain English, do so or you will risk the rejection of your request.
-
New public/protected methods/classes should contain a
@since [NOW]
descriptor in the Javadocs, so that when a new release is cut, the "NOW" can be replaced with the next release version. -
Deprecated public/protected/default methods/classes should contain a
@deprecated Since [NOW]
entry in the javadoc comment, so that when a new release is cut, the new deprecations can be adequately documented, and the "NOW" can be replaced with the next release version. -
Please amend the CHANGELOG - add a "Changed in [NOW]" section if it doesn't exist.
-
Your code must be compatible with the license of this project, and be written with the understanding that it will be published under this project's license.