2011-01-29 20:17:05 +00:00
|
|
|
.. _contributing:
|
|
|
|
|
2011-01-29 19:21:36 +00:00
|
|
|
Contributing
|
|
|
|
============
|
|
|
|
|
|
|
|
There are many ways in which you can contribute to Kivy.
|
|
|
|
Code patches are just one thing amongst others that you can submit to help the
|
|
|
|
project. We also welcome bug reports, feature requests, documentation
|
|
|
|
improvements, advertisement & advocating, testing, graphics contributions and
|
|
|
|
many different things. Just talk to us if you want to help, and we will help you
|
|
|
|
help us.
|
|
|
|
|
|
|
|
|
|
|
|
Code Contributions
|
|
|
|
------------------
|
|
|
|
|
|
|
|
Code contributions (patches, new features) are the most obvious way to help with
|
|
|
|
the project's development. Since this is so common we ask you to follow our
|
|
|
|
workflow to most efficiently work with us. Adhering to our workflow ensures that
|
|
|
|
your contribution won't be forgotten or lost. Also, your name will always be
|
|
|
|
associated with the change you made, which basically means eternal fame in our
|
|
|
|
code history (you can opt-out if you don't want that).
|
|
|
|
|
|
|
|
Git & GitHub
|
|
|
|
~~~~~~~~~~~~
|
|
|
|
|
|
|
|
We use git as our version control system for our code base. If you have never
|
|
|
|
used git or a similar DVCS (or even any VCS) before, we strongly suggest you
|
|
|
|
take a look at the great documentation that is available for git online.
|
|
|
|
The `Git Community Book <http://book.git-scm.com/>`_ or the
|
|
|
|
`Git Screencasts <http://gitcasts.com/>`_ are both great ways to learn git.
|
|
|
|
Trust us when we say that git is a great tool. It may seem daunting at first,
|
|
|
|
but after a while you'll (hopefully) love it as much as we do. Teaching you git,
|
|
|
|
however, is well beyond the scope of this document.
|
|
|
|
|
|
|
|
Also, we use `GitHub <http://github.com>`_ to host our code. In the following we
|
|
|
|
will assume that you have a (free) GitHub account. While this part is optional,
|
|
|
|
it allows for a tight integration between your patches and our upstream code
|
|
|
|
base. If you don't want to use GitHub, we assume you know what you do anyway.
|
|
|
|
|
|
|
|
Code Workflow
|
|
|
|
~~~~~~~~~~~~~
|
|
|
|
|
|
|
|
So here is the initial setup to begin with our workflow (You only need to do
|
|
|
|
this once):
|
|
|
|
|
|
|
|
#. Log in to GitHub
|
|
|
|
#. Create a fork of the `Kivy repository <https://github.com/tito/kivy>`_ by
|
|
|
|
clicking the *fork* button.
|
|
|
|
#. Clone your fork of our repository to your computer. Your fork will have
|
|
|
|
the git remote name 'origin' and you will be on branch 'master'.
|
|
|
|
#. Install our pre-commit hook that ensures your code doesn't violate our
|
|
|
|
styleguide by executing 'make hook' in your clone.
|
|
|
|
|
|
|
|
Now, whenever you want to create a patch, you follow the following steps:
|
|
|
|
#. See if there is a ticket in our bug tracker for the fix or feature and
|
|
|
|
announce that you'll be working on it if it doesn't yet have an assignee.
|
|
|
|
#. Create a new, appropriately named branch in your local repository for
|
|
|
|
that specific feature or bugfix.
|
|
|
|
(Keeping a new branch per feature makes sure we can easily pull in your
|
|
|
|
changes without pulling any other stuff that is not supposed to be pulled.)
|
|
|
|
#. Modify the code to do what you want (e.g., fix it).
|
|
|
|
#. Make sure the code follows
|
|
|
|
#. Do one or more minimal, atomic commits per fix or per feature.
|
|
|
|
Minimal/Atomic means *keep the commit clean*. Don't commit other stuff that
|
|
|
|
doesn't logically belong to this fix or feature. This is NOT about
|
|
|
|
creating one commit per line changed. Use git add -p if necessary.
|
|
|
|
#. Give each commit an appropriate commit message, so that others who are
|
|
|
|
not familiar with the matter get a good idea of what you changed.
|
|
|
|
#. Once you are satisfied with your changes, merge with our upstream
|
|
|
|
repository. We can pull your stuff, but since you know best what you
|
|
|
|
changed, you should do the merge.
|
|
|
|
#. Push to your remote repository on GitHub.
|
|
|
|
#. Send a *Pull Request* with a description of what you changed via the button
|
|
|
|
in the GitHub interface of your repository. (This is why we forked
|
|
|
|
initially. Your repository is linked against ours.)
|
|
|
|
|
|
|
|
Now we will receive your pull request. We will check whether your changes are
|
|
|
|
clean and make sense (if you talked to us before doing all of this we will have
|
|
|
|
told you whether it makes sense or not). If so, we will pull them and you will
|
|
|
|
get instant karma. Congratulations, you're a hero!
|
|
|
|
|
|
|
|
|
|
|
|
Documentation Contributions
|
|
|
|
---------------------------
|
|
|
|
|
|
|
|
Documentation contributions generally follow the same workflow as code
|
|
|
|
contributions, just a bit more lax. We don't ask you to go through all the
|
|
|
|
hassle just to correct a single typo. For more complex contributions, please
|
|
|
|
consider following the suggested workflow though.
|