Thank you for your interest in contributing to the project.
All types of contributions are valued and encouraged, though there are a few guidelines which must be followed to make the contribution process easy and consistent. See the Table of Contents for different ways to help and details about how this project handles them.
If you like the project, but don't have time to contribute, there are other easy ways to show your support and appreciation, such as:
- Star the project
- Refer to this project in another project
- Mention or share the project at local meetups and tell your colleagues
This project and everyone who participates in it is governed by the project's Code of Conduct.
By participating, you are expected to uphold this code. Please report unacceptable behavior to the project maintainer(s).
Before asking a question, it is best to search for existing Issues or Discussions that may help. In case you've found a suitable issue or discussion and still need clarification, you may comment directly on the issue or discussion. It is also advisable to search the internet for answers.
If you then still have a question or need clarification, you may create a new discussion or new issue and provide as much context and detail as possible.
When contributing to this project, you must agree that you have authored 100% of the content, that you have the necessary rights to the content, and that the content you contribute may be provided under the project license.
We use GitHub issues to track bugs and errors. If you run into an issue with the project, please create a new issue with the following in consideration:
- Explain the behavior you would expect and the actual behavior.
- Please provide as much context as possible and describe the reproduction steps that someone else can follow to recreate the issue on their own. This usually includes your code. If possible, please isolate the problem and create a test case.
Once you have submitted an issue on GitHub, we will label it and follow-up accordingly.
We use GitHub issues to track feature and enhancement requests. If you'd like to suggest a feature or enhancement, please create a new issue with the following in consideration:
- Make sure that you are using the latest version.
- Make sure that you are using the latest Ewon firmware.
- Check for updates at https://www.ewon.biz/technical-support/pages/firmware.
- Read the Documentation carefully to find out if the functionality is already covered.
- Perform a search for existing Issues or Discussions to see if the feature or enhancement has already been suggested.
- If the feature or enhancement has already been suggested, add a comment to the existing issue or discussion instead of opening a new one.
- Make sure the feature or enhancement is with the scope and aims of the project. New features shall be useful to the majority of users, not a small subset.
- If a feature or enhancement targets a minority of users, it is advised to consider writing an add-on or library.
The development environment for this project uses the standard Ewon Java development environment, which is Eclipse. Alternative IDEs can be used but may not be fully compatible with the Ewon Java Toolkit and thus are not guaranteed nor officially supported by HMS.
Documentation and additional information about the Ewon Java development environment is available in the Ewon Java Toolkit User Guide (J2SE) at https://developer.ewon.biz/content/java-0#dev-documents.
Changes made to the documentation in this project must be made in an individual commit, or accompany the commit with the relevant source code changes.
Documentation for this project shall be written in present passive voice and is governed by the project's Code of Conduct.
Changes made to the source code in this project must be organized into individual commits, each with an individual objective.
Source code in this project adheres to the Google Java Style Guide, and any changes must follow the same format. Detailed information about the Google Java Style Guide can be found at https://google.github.io/styleguide/javaguide.html.
Source code changes which do not adhere to the Google Java Style Guide will be rejected automatically during the pull request phase.
Each commit to this project should have very limited scope. All changes in each commit should have a common theme, and you should be able to describe the scope of the change as a single statement. Hint: If you can not describe the commit without using the word "and" or creating a list, the commit should be broken up.
To ensure a clean and productive Git history, commits which do not follow those guidelines should be reorganized, otherwise they may be rejected during the pull request phase.
Each commit must contain a message describing the change(s) made. The commit message must meet the following guidelines:
- Subject (First Line)
- Must not be more than 50 characters in length
- Must describe commit change-set concisely
- Must capitalize first character
- Must not end with a period
- Must be followed by a blank line (unless body omitted)
- Body
- Must not be more than 72 characters in length, per line
- Must describe commit change-set thoroughly
- Must use proper capitalization, grammar, and punctuation
- Must use blank lines to separate paragraphs
Subject line
More detailed explanatory text, if necessary. Wrap to 72 characters
or less. The blank line between the subject line and commit body is
critical (unless commit body is omitted).
Additional paragraphs can be added after another blank line. Bullet
points and other rich text can be included as well.
1. Example Change
2. Example Addition
3. Example Bug Fix
All code committed to this project must follow the pull request procedure before it can be merged to the main or master branch. The pull request procedure ensures that all changes have been reviewed by a project maintainer, and tested to function properly.
In addition to any automated testing which may be performed for pull requests, all modified or newly-introduced code must be thoroughly tested prior to creating a pull request.
Once a pull request has been created, the following must be performed:
- Designate pull request assignee
- Under most circumstances, the person creating the pull request shall be designated as the assignee. Should another person become responsible for the pull request, that person shall be designated as the assignee.
- Add content labels
- Pull requests and other GitHub content can be labeled to document the type of content addressed. These labels can be found and assigned in the pull request sidebar.
- Add linked issues
- If the pull request resolves or otherwise addresses an issue documented using GitHub Issues, the issue should be linked to the pull request. Linked issues can be found and assigned in the pull request sidebar.
- Add pull request reviewers
- Pull requests must be reviewed by at least one, but preferably two, reviewers or code-owners. These reviewers should be chosen based on project familiarity, code language, and dependencies. In some scenarios, a code-owner may automatically be assigned to a pull request.