Note: If these contribution guidelines are not followed your issue or PR might be closed, so please read these instructions carefully.
- If you find a bug, please first report it using Github issues
- First, check if there is not already an issue for it; duplicated issues will be closed.
- In particular, make sure you have a raw-Hibernate equivalent of what you are trying to accomplish; Yawn is just a layer on top of Hibernate at the end of the day.
- If you'd like to submit a fix for a bug, please read the How To for how to send a Pull Request.
- Indicate on the open issue that you are working on fixing the bug and the issue will be assigned to you.
- Write
Fixes #xxxxin your PR text, where xxxx is the issue number (if there is one). - Include a test that isolates the bug and verifies that it was fixed.
- If you'd like to add a feature to the library that doesn't already exist, feel free to describe the feature in a new GitHub issue.
- If you'd like to implement the new feature, please wait for feedback from the project maintainers before spending too much time writing the code. In some cases, enhancements may not align well with the project's future development direction.
- Implement the code for the new feature and please read the How To.
- If you have suggestions for improvements to the documentation or examples (or something else), we would love to hear about it.
- As always first file a Github issue.
- Implement the changes to the documentation, please read the How To.
For a contribution to be accepted:
- Follow the the style and formatting of the project when writing the code;
- Compile, test, format, and lint code using
./gradlew build(or your IDE of choice); - Documentation should always be updated or added (if applicable);
- Tests should always be updated or added (if applicable) -- check the [Test writing guide] for more details;
- The PR title should start with a conventional commit prefix (
feat:,fix:, etc).
If the contribution doesn't meet these criteria, a maintainer will discuss it with you on the issue or PR. You can still continue to add more commits to the branch you have sent the Pull Request from and it will be automatically reflected in the PR.
- If it is a bigger change or a new feature, first of all file a bug or feature report, so that we can discuss what direction to follow.
- Fork the project on GitHub.
- Clone the forked repository to your local development machine (e.g.
git clone git@github.com:<YOUR_GITHUB_USER>/yawn.git).
Yawn is managed with the included Gradle wrapper, which should download the appropriate version for you. You will also need Java 21 or newer.
To run the "build", which includes compilation, tests, lint, formatting, and other checks, run:
./gradlew buildIf you want to run the spellchecker locally, you will have to install cspell; you can do so using npm or yarn:
npm install -g cspellThen you can run it with the following arguments:
./scripts/cspell-run.shIf you want to lint the markdown files you have to install markdownlint-cli; once that is installed you can
run scripts/markdownlint-run.sh to check if the markdown follows the rules.
Note that, sadly, a particularly laborious rule, MD013, does not provide an auto-fix option. However,
you can use other tools to circumvent this. For example, the extension Rewrap for VSCode, when
configured with rewrap.wrappingColumn=160, will do the trick for you.
We use prettier for YAML formatting and actionlint for GitHub Actions workflow validation.
To run YAML linting locally:
# Check YAML files
scripts/yaml-lint-run.sh
# Check and auto-fix YAML formatting issues
scripts/yaml-lint-run.sh --fixThe script will automatically check for and install the required tools (prettier and actionlint) if they're not already available.
The prettier configuration is defined in .github/yaml-lint/.prettierrc.yml.
- Create a new local branch from
main(e.g.git checkout -b my-new-feature) - Make your changes (try to split them up with one PR per feature/fix).
- When committing your changes, make sure that each commit message is clear
- Push your new branch to your own fork into the same remote branch
When doing breaking changes, a deprecation tag should be added first containing a message that conveys to what method should be used instead to perform the task.
Also don't forget to include the ! as part of your conventional commit prefix when actually removing old code.
Go to the pull request page of Yawn and in the top of the page it will ask you if you want to open a pull request from your newly created branch.
The title of the pull request should start with a conventional commit type.
Allowed types are:
fix:-- patches a bug and is not a new feature;feat:-- introduces a new feature;docs:-- updates or adds documentation or examples;test:-- updates or adds tests;refactor:-- refactors code but doesn't introduce any changes or additions to the public API;perf:-- code change that improves performance;build:-- code change that affects the build system or external dependencies;ci:-- changes to the CI configuration files and scripts;chore:-- other changes that don't modify source or test files;revert:-- reverts a previous commit.
If you introduce a breaking change the conventional commit type MUST end with an exclamation mark (e.g. feat!: Remove method XXX).
The sentence of the commit (after the :) should start with a verb in the present tense; as a rule of thumb, think that the commit message will complete the
sentence "This commit will ...". For example, "Add support for ..." or "Fix bug with ...".