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.
-
While this is intended to be an end-user utility package, all non-getter/setter 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 without adequate justification or review. "Adequate justification" is defined by the code maintainer. Stay in the java.desktop module (and its child dependencies). Removal of dependencies, if any, are always a welcome proposition and are subject to less scrutiny.
-
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.
-
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 documentation." If you are asked to clarify sections of code with plain English, do so or you will risk the rejection of your request.
-
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.