Thanks for your help in improving the HedgeDoc project!
Please note we have a code of conduct, please follow it in all your interactions with the project.
- Feel free to post your question on our community forum or join our matrix community chat.
-
Ensure the bug wasn't already reported by searching on GitHub under Issues.
-
If you're unable to find an open issue addressing the problem, open a new one. Be sure to use one of the templates we provide if your request applies to them.
-
Open a new GitHub pull request with the patch. See the section submitting a pull request for details on this.
-
Ensure the PR description is precise about the problem and your solution. Just fill out our template. That should cover the most important information.
-
Please note that we only accept PRs for the 1.x releases if they fix critical issues. If you are unsure if your fix is critical, it's best to ask us before you start coding.
-
Choose the correct base branch:
The code for 1.x lives in themaster
branch. docs.hedgedoc.org is also deployed from there until 2.0 is released.
HedgeDoc 2.x is developed in thedevelop
branch.
- Suggest your idea via a new GitHub issue. After a confirmation about your idea, you can start writing code. Our maintainers and other project developers can provide useful details about the architecture and show you relevant issues and discussions.
- If you want to improve a translation or add a new translation altogether, we handle those via POEditor.
HedgeDoc is a volunteer effort. We encourage you to pitch in and help us to make this project even better.
By contributing to this project you agree to the Developer Certificate of Origin (DCO). This document was created by the Linux Kernel community and is a simple statement that you, as a contributor, have the legal right to make the contribution. The DCO is a legally binding statement, please read it carefully.
If you can certify it, then just add a line to every git commit message:
Signed-off-by: Random J Developer <[email protected]>
Use your real name (sorry, no pseudonyms or anonymous contributions).
If you set your user.name
and user.email
git configs, you can sign your commit automatically with git commit -s
.
You can also use git aliases
like git config --global alias.ci 'commit -s'
. Now you can commit with git ci
and the commit will be signed.
- Submit an issue describing your proposed change. We will try to respond to your issue promptly.
- Fork this repo, develop and test your code changes. Ensure you follow the commit guidelines (see below) and signed all your commits (see above for details).
- Submit a pull request against this repo's
develop
branch for 2.x or themaster
branch for 1.x. - Your branch may be merged once all configured checks pass.
-
Follow these rules when writing a commit message:
- Separate subject from body with a blank line
- Limit the subject line to 50 characters
- If you worked on a specific part of the application, you can prefix your commit message with that Example: " MediaService: Get media backend from configuration"
- Capitalize the subject line
- Do not end the subject line with a period
- Use the imperative mood in the subject line
- Wrap the body at 72 characters
- Use the body to explain what and why vs. how
These are inspired by https://chris.beams.io/posts/git-commit/
-
Split your change into small, atomic commits. This helps reviewing the changes and enables the use of
git bisect
. -
Ensure the commit history is easy to follow. Use
git rebase -i
to sort and squash your commits if neccessary. -
If your branch includes fixup commits (like "Fix typo...", "Fix tests..."), use
git rebase -i
to clean them up before submitting a pull request. -
When refactoring something, take care to not include any functional changes into the same commit. Mixing refactoring and functional changes makes it hard to find the cause of regressions.