Hi there! We're thrilled that you'd like to contribute to this project. Your help is essential for keeping it great.
There are many ways you can send your contributions to ggez. You can either report a bug, or you can make the changes yourself and submit a pull request!
Please report bugs and open issues generously. Don't be afraid that your idea is silly, or you're reporting a duplicate. We're happy to hear from you. Seriously.
Please Note: ggez is written by volunteers. If you encounter a problem while using it, we'll do our best to help you, but the authors cannot offer any support.
Known bugs and feature requests are all in the issue tracker so that's a good place to start looking for places to help. Bugs marked *EASY*
are fairly self-contained and probably don't need lots and lots of research. Bugs marked *LESS EASY*
will require a bit of finesse, or larger/broader changes to the library.
- Fork and clone the repository
- Create a new branch: git checkout -b my-branch-name
- Make your changes
- Push to your fork and submit a pull request
- Pat your self on the back and wait for your pull request to be reviewed.
If you're unfamiliar with how pull requests work, GitHub's documentation on them is very good.
Here are a few things you can do that will increase the likelihood of your pull request being accepted:
- Update the documentation as necessary, as well as making code changes.
- Keep your change as focused as possible. If there are multiple changes you would like to make that are not dependent upon each other, consider submitting them as separate pull requests.
- Write a good commit message.
All of ggez's in-progress work happens on the master
branch. When we make a major release, we make a new branch for that release number, and only backwards-compatible changes get merged from master
into it.
For example, when we release 0.3.0
, it gets its own branch. If we then discover and fix a bug in master
, we can merge the changes fixing that bug into the 0.3
branch, and make a 0.3.1
release from it.
Contributions to ggez (via pull request or otherwise) must be licensed under the same license as ggez