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
|
2011-03-16 14:58:03 +00:00
|
|
|
project. We also welcome feedback, bug reports, feature requests, documentation
|
2011-01-29 19:21:36 +00:00
|
|
|
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.
|
|
|
|
|
2011-03-16 14:58:03 +00:00
|
|
|
Feedback
|
|
|
|
--------
|
|
|
|
|
|
|
|
This is by far the easiest way to contribute something. If you're using
|
|
|
|
Kivy for your own project, don't hesitate sharing. It doesn't have to be a
|
|
|
|
high-class enterprise app, obviously. It's just incredibly motivating to
|
|
|
|
know that people use the things you develop and what it enables them to
|
|
|
|
do. If you have something that you would like to tell us, please don't
|
|
|
|
hesitate. Screenshots and videos are also very welcome!
|
|
|
|
We're also interested in the problems you had when getting started. Please
|
|
|
|
feel encouraged to report any obstacles you encountered such as missing
|
|
|
|
documentation, misleading directions or similar.
|
|
|
|
We are perfectionists, so even if it's just a typo, let us know.
|
2011-01-29 19:21:36 +00:00
|
|
|
|
2012-06-13 22:33:49 +00:00
|
|
|
.. _reporting_issues:
|
|
|
|
|
2011-03-16 19:18:07 +00:00
|
|
|
Reporting an Issue
|
2011-02-17 14:00:02 +00:00
|
|
|
------------------
|
|
|
|
|
|
|
|
If you found anything wrong, a crash, segfault, missing documentation, invalid
|
|
|
|
spelling, weird example, please take 2 minutes to report the issue.
|
|
|
|
|
|
|
|
#. Move your logging level to debug by editing `<user_directory>/.kivy/config.ini`::
|
|
|
|
|
|
|
|
[kivy]
|
|
|
|
log_level = debug
|
|
|
|
|
2012-06-13 21:23:33 +00:00
|
|
|
#. Execute again your code, and copy/paste the complete output to http://gist.github.com/,
|
2012-07-08 09:36:49 +00:00
|
|
|
including the log from Kivy and the python backtrace.
|
2011-12-16 09:54:33 +00:00
|
|
|
#. Open https://github.com/kivy/kivy/issues/
|
2011-02-17 14:00:02 +00:00
|
|
|
#. Write a title of your issue
|
|
|
|
#. Explain how we can do to reproduce the issue + paste the link of the output previously sent on pocoo
|
|
|
|
#. Validate the issue, you're done !
|
|
|
|
|
|
|
|
|
|
|
|
If you feel good, you can also try to resolve the bug, and contribute by sending us
|
|
|
|
the patch :) Read the next section about how to do it.
|
|
|
|
|
2011-01-29 19:21:36 +00:00
|
|
|
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).
|
|
|
|
|
2012-07-21 23:15:45 +00:00
|
|
|
|
|
|
|
Coding style
|
|
|
|
~~~~~~~~~~~~
|
|
|
|
|
2012-07-21 23:19:55 +00:00
|
|
|
- If you didn't do it yet, read the
|
|
|
|
`PEP8 <http://www.python.org/dev/peps/pep-0008/>`_ about coding style in python.
|
2012-07-21 23:15:45 +00:00
|
|
|
|
|
|
|
- Activate pep8 check on git commit like this::
|
|
|
|
|
|
|
|
make hook
|
|
|
|
|
|
|
|
This will pass the code added to git staging zone (about to be committed)
|
|
|
|
thought a pep8 checker program when you do a commit, and check that you didn't
|
|
|
|
introduce pep8 errors, if so, the commit will be rejected, correct the errors,
|
|
|
|
and try again.
|
|
|
|
|
|
|
|
Performances
|
|
|
|
~~~~~~~~~~~~
|
|
|
|
|
2012-07-21 23:19:55 +00:00
|
|
|
- take care of performance issues, read
|
|
|
|
`Python performance tips <http://wiki.python.org/moin/PythonSpeed/PerformanceTips>`_
|
2012-07-21 23:15:45 +00:00
|
|
|
- cpu intensive parts of Kivy are written in cython, if you are doing a lot of
|
|
|
|
computation, consider using it too.
|
|
|
|
|
2011-01-29 19:21:36 +00:00
|
|
|
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
|
|
|
|
~~~~~~~~~~~~~
|
|
|
|
|
2011-01-30 12:43:20 +00:00
|
|
|
So here is the initial setup to begin with our workflow (you only need to do
|
2011-01-30 19:16:09 +00:00
|
|
|
this once to install Kivy). Basically you follow the installation
|
|
|
|
instructions from :ref:`dev-install`, but you don't clone our repository,
|
|
|
|
but the fork you create with the following steps:
|
2011-01-29 19:21:36 +00:00
|
|
|
|
|
|
|
#. Log in to GitHub
|
2011-12-16 09:54:33 +00:00
|
|
|
#. Create a fork of the `Kivy repository <https://github.com/kivy/kivy>`_ by
|
2011-01-29 19:21:36 +00:00
|
|
|
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'.
|
2011-01-30 19:16:09 +00:00
|
|
|
#. Compile and set up PYTHONPATH or install (see :ref:`dev-install`).
|
2011-01-29 19:21:36 +00:00
|
|
|
#. Install our pre-commit hook that ensures your code doesn't violate our
|
2012-06-13 22:17:17 +00:00
|
|
|
styleguide by executing `make hook` from the root directory of your
|
2012-07-21 23:15:45 +00:00
|
|
|
clone. This will run our styleguide check whenever you do a commit,
|
|
|
|
and if there are violations in the parts that you changed, your commit
|
2012-06-13 22:17:17 +00:00
|
|
|
will be aborted. Fix & retry.
|
2012-07-21 23:15:45 +00:00
|
|
|
#. Add kivy repo as a remote source::
|
|
|
|
|
|
|
|
git remote add kivy https://github.com/kivy/kivy.git
|
2011-01-29 19:21:36 +00:00
|
|
|
|
|
|
|
Now, whenever you want to create a patch, you follow the following steps:
|
2011-01-29 21:04:35 +00:00
|
|
|
|
2011-01-29 19:21:36 +00:00
|
|
|
#. 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
|
2012-07-21 23:15:45 +00:00
|
|
|
changes without pulling any other stuff that is not supposed to be pulled.)::
|
|
|
|
|
|
|
|
git checkout -b new_feature
|
|
|
|
|
2011-01-29 19:21:36 +00:00
|
|
|
#. Modify the code to do what you want (e.g., fix it).
|
2011-01-29 21:04:35 +00:00
|
|
|
#. Test the code. Try to do this even for small fixes. You never know
|
|
|
|
whether you have introduced some weird bug without testing.
|
2011-01-29 19:21:36 +00:00
|
|
|
#. 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
|
2011-03-16 19:18:07 +00:00
|
|
|
doesn't logically belong to this fix or feature. This is **not** about
|
2011-01-29 21:04:35 +00:00
|
|
|
creating one commit per line changed. Use ``git add -p`` if necessary.
|
2011-01-29 19:21:36 +00:00
|
|
|
#. 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
|
2012-07-21 23:15:45 +00:00
|
|
|
changed, you should do the merge::
|
|
|
|
|
|
|
|
git pull kivy master
|
|
|
|
|
|
|
|
#. Push to your remote repository on GitHub::
|
|
|
|
|
|
|
|
git push
|
|
|
|
|
2011-01-29 19:21:36 +00:00
|
|
|
#. 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.)
|
|
|
|
|
2011-03-16 19:18:07 +00:00
|
|
|
.. warning::
|
|
|
|
If you change parts of the code base that require compilation, you
|
|
|
|
will have to recompile in order for your changes to take effect. The ``make``
|
|
|
|
command will do that for you (see the Makefile if you want to know
|
|
|
|
what it does). If you need to clean your current directory from compiled
|
2011-01-30 12:43:20 +00:00
|
|
|
files, execute ``make clean``. If you want to get rid of **all** files that are
|
|
|
|
not under version control, run ``make distclean``
|
|
|
|
(**Caution:** If your changes are not under version control, this
|
|
|
|
command will delete them!)
|
|
|
|
|
2011-01-29 19:21:36 +00:00
|
|
|
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.
|
2011-10-14 14:14:24 +00:00
|
|
|
|
|
|
|
|
2012-07-21 23:15:45 +00:00
|
|
|
Docstrings
|
|
|
|
~~~~~~~~~~
|
|
|
|
|
|
|
|
Every module/class/method/function need a docstring, use the following keyword
|
|
|
|
when relevant
|
|
|
|
|
|
|
|
- ``.. versionadded::`` to mark the version the feature was added.
|
|
|
|
- ``.. versionchanged::`` to mark the version behaviour of the feature was
|
|
|
|
changed.
|
|
|
|
- ``.. note::`` to add additional info about how to use the feature or related
|
|
|
|
feature.
|
|
|
|
- ``.. warning::`` to indicate a potential issue the user might run into using
|
|
|
|
the feature.
|
|
|
|
|
|
|
|
Examples::
|
|
|
|
|
|
|
|
def my_new_feature(self, arg):
|
|
|
|
"""
|
|
|
|
New feature is awesome
|
|
|
|
|
|
|
|
.. versionadded:: 1.1.4
|
|
|
|
|
|
|
|
.. note:: This new feature will likely blow your mind
|
|
|
|
|
|
|
|
.. warning:: Please take a seat before trying this feature
|
|
|
|
"""
|
|
|
|
|
|
|
|
Will result in:
|
|
|
|
|
|
|
|
def my_new_feature(self, arg):
|
|
|
|
"""
|
|
|
|
New feature is awesome
|
|
|
|
|
|
|
|
.. versionadded:: 1.1.4
|
|
|
|
|
|
|
|
.. note:: This new feature will likely blow your mind
|
|
|
|
|
|
|
|
.. warning:: Please take a seat before trying this feature
|
2012-07-22 15:08:33 +00:00
|
|
|
|
2012-07-21 23:15:45 +00:00
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
|
|
When refering to other parts of the api use:
|
|
|
|
|
|
|
|
- ``:mod:`~kivy.module``` to refer to a module
|
|
|
|
- ``:class:`~kivy.module.Class``` to refer to a class
|
|
|
|
- ``:meth:`~kivy.module.Class.method``` to refer to a method
|
|
|
|
- ``:doc:`api-kivy.module``` to refer to the documentation of a module (same
|
|
|
|
for a class and a method)
|
|
|
|
|
|
|
|
Obviously replacing `module` `class` and `method` with their real name, and
|
|
|
|
using using '.' to separate modules refering to imbricated modules, e.g::
|
|
|
|
|
|
|
|
:mod:`~kivy.uix.floatlayout`
|
|
|
|
:class:`~kivy.uix.floatlayout.FloatLayout`
|
|
|
|
:meth:`~kivy.core.window.WindowBase.toggle_fullscreen`
|
|
|
|
:doc:`/api-kivy.core.window`
|
|
|
|
|
|
|
|
Will result in:
|
|
|
|
|
|
|
|
:mod:`~kivy.uix.floatlayout`
|
|
|
|
:class:`~kivy.uix.floatlayout.FloatLayout`
|
|
|
|
:meth:`~kivy.core.window.WindowBase.toggle_fullscreen`
|
|
|
|
:doc:`/api-kivy.core.window`
|
|
|
|
|
|
|
|
`:doc:` and `:mod:` are essentially the same, except for an anchor in the url,
|
|
|
|
this makes `:doc:` prefered, for the cleaner url.
|
|
|
|
|
2012-08-08 22:20:10 +00:00
|
|
|
To build your documentation, run::
|
|
|
|
|
2012-08-08 23:10:17 +00:00
|
|
|
make html
|
2012-08-08 22:20:10 +00:00
|
|
|
|
|
|
|
If you updated your kivy install, and have some trouble compiling docs, run::
|
|
|
|
|
2012-08-08 23:10:17 +00:00
|
|
|
make clean force html
|
2012-08-08 22:20:10 +00:00
|
|
|
|
|
|
|
The doc will be generated in ``build/html``.
|
2012-07-21 23:15:45 +00:00
|
|
|
|
2011-10-14 14:14:24 +00:00
|
|
|
Unit tests contributions
|
|
|
|
------------------------
|
|
|
|
|
|
|
|
For testing team, we have the document :doc:`contribute-unittest` that
|
2012-07-08 09:36:49 +00:00
|
|
|
explain how Kivy unit test is working, and how you can create your own. Use the
|
2011-10-14 14:14:24 +00:00
|
|
|
same approach as the `Code Workflow` to submit new tests.
|
2012-01-23 14:39:43 +00:00
|
|
|
|
|
|
|
.. toctree::
|
|
|
|
:maxdepth: 2
|
|
|
|
|
|
|
|
contribute-unittest
|
|
|
|
|