bidict/CONTRIBUTING.rst

172 lines
6.6 KiB
ReStructuredText
Raw Normal View History

.. Forward declarations for all the custom interpreted text roles that
Sphinx defines and that are used below. This helps Sphinx-unaware tools
(e.g. rst2html, PyPI's and GitHub's renderers, etc.).
.. role:: doc
.. role:: ref
Contributors' Guide
===================
2016-06-28 04:05:22 +00:00
Bug reports, feature requests, patches, and other contributions are warmly welcomed.
Contribution should be as easy and friendly as possible.
Below are a few guidelines contributors should follow to facilitate the process.
2018-02-24 09:14:42 +00:00
Getting Started
---------------
- `Create a GitHub account <https://github.com/join>`__ if you don't have one
2016-06-28 04:05:22 +00:00
already.
- Search through the `issue tracker <https://github.com/jab/bidict/issues>`__
to see if an issue or pull request has already been created for what you're interested in.
If so, feel free to add comments to it or just hit the "subscribe" button to follow progress.
If not, you can `join the chat room <https://gitter.im/jab/bidict>`__ to discuss there,
or go ahead and `create a new issue <https://github.com/jab/bidict/issues/new>`__:
- Clearly describe the issue giving as much relevant context as possible.
- If it is a bug, include reproduction steps,
all known environments in which the bug is exhibited,
and ideally a failing test case.
- If you would like to contribute a patch,
make sure you've `created your own fork <https://github.com/jab/bidict/fork>`__
2016-06-28 04:05:22 +00:00
and have cloned it to your computer.
2018-02-24 09:14:42 +00:00
Making Changes
--------------
- Before making changes, please install the extra packages required for development:
``pip install -e .[dev]``
2018-08-19 18:53:20 +00:00
We use `EditorConfig <https://editorconfig.org/>`__
and `pre-commit <https://pre-commit.com/>`__
to help achieve uniform style and quality standards
across a diversity of development environments.
pre-commit gets installed when you run ``pip install -e .[dev]``
and ensures that various code checks are run before every commit
(look in ``.pre-commit-config.yaml`` to see which hooks are run).
EditorConfig allows us to provide a single ``.editorconfig`` file
to configure settings like indentation consistently
2019-11-18 06:13:36 +00:00
across a variety of supported editors.
2018-08-19 18:53:20 +00:00
See https://editorconfig.org/#download to install the plugin for your editor.
- Create a topic branch off of master for your changes:
``git checkout -b <topic> master``
- Make commits of logical units.
- Match the existing code style and quality standards.
If you're adding a feature, include accompanying tests and documentation
demonstrating its correctness and usage.
- Run the tests locally with `tox <https://tox.readthedocs.io>`__
to make sure they pass for all supported Python versions
(see ``envlist`` in ``tox.ini`` for the complete list).
If you do not have all the referenced Python versions available locally,
you can also push the changes on your branch to GitHub
to automatically trigger a new `Travis-CI <https://travis-ci.org>`__ build,
which should run the tests for all supported Python versions.
You should be able to see the results at ``travis-ci.org/<user>/bidict``,
where ``<user>`` is the GitHub username you used to fork bidict.
- Create a concise but comprehensive commit message in the following style::
Include an example commit message in CONTRIBUTING guide #9999
Without this patch the CONTRIBUTING guide would contain no examples of
a model commit message. This is a problem because the contributor is left
to imagine what the commit message should look like and may not get it
right. This patch fixes the problem by providing a concrete example.
The first line is an imperative statement summarizing the changes with an
issue number from the tracker. The body describes the behavior without
the patch, why it's a problem, and how the patch fixes the problem.
2018-02-24 09:14:42 +00:00
Submitting Changes
------------------
- Push your changes to a topic branch in your fork of the repository:
``git push --set-upstream origin <topic>``
- Submit a pull request providing any additional relevant details necessary.
- Acknowledgment should typically be fast
but please allow 1-2 weeks for a full response / code review.
- The code review process often involves some back-and-forth
to get everything right before merging.
This is typical of quality software projects that accept patches.
- All communication should be supportive and appreciative of good faith efforts to contribute,
creating a welcoming and inclusive community.
Expect nothing less of any project.
2016-06-28 04:05:22 +00:00
2018-02-24 09:14:42 +00:00
Other Ways to Contribute
------------------------
2016-06-28 04:05:22 +00:00
.. image:: https://img.shields.io/badge/Gumroad-Chip%20in-orange.svg
:target: https://gumroad.com/l/bidict
2018-02-24 09:14:42 +00:00
:alt: Chip in via Gumroad
.. image:: https://img.shields.io/badge/PayPal-Chip%20in-blue.svg
:target: https://www.paypal.com/cgi-bin/webscr?cmd=_xclick&business=jab%40math%2ebrown%2eedu&lc=US&item_name=Support%20bidict&button_subtype=services&currency_code=USD&bn=PP%2dBuyNowBF%3aPaypal%2dBuy%2520a%2520Drink%2dblue%2esvg%3aNonHosted
2018-02-24 09:14:42 +00:00
:alt: Chip in via PayPal
.. 2020-1-1: bountysource.com domain expired, commented out here + removed from .github/FUNDING.yml
image:: https://img.shields.io/badge/Bountysource-Chip%20in-brightgreen.svg
:target: https://www.bountysource.com/teams/bidict
:alt: Chip in via Bountysource
.. duplicated in README.rst
(would use `.. include::` but GitHub doesn't understand it)
2018-10-17 15:16:43 +00:00
Bidict is the product of hundreds of hours of unpaid, voluntary work.
If bidict has helped you accomplish your work,
especially work you've been paid for,
please consider chipping in toward the costs
of bidict's maintenance and development
and/or ask your organization to do the same.
Any amount contributed is gratefully received.
Besides chipping in financially,
filing issues,
and submitting pull requests,
there are other ways to contribute.
2016-06-28 04:05:22 +00:00
- If you read the code and learned something new,
please :ref:`let me know <home:Notice of Usage>` [#fn-let-me-know]_.
2018-02-24 09:14:42 +00:00
- If you're using bidict in a project you work on,
please post about your experience and send me a link.
2018-02-24 09:14:42 +00:00
- If you come across other people who could find bidict useful,
please spread the word.
2015-11-28 14:30:28 +00:00
**Please support bidict:**
2015-11-28 14:30:28 +00:00
.. image:: https://raw.githubusercontent.com/jab/bidict/master/assets/support-on-gumroad.png
:target: https://gumroad.com/l/bidict
:alt: Support bidict
2016-06-28 04:05:22 +00:00
2018-02-24 09:14:42 +00:00
2016-06-28 04:05:22 +00:00
Code of Conduct
---------------
2016-06-28 04:05:22 +00:00
All participation in this project should respect the
:doc:`code-of-conduct`. [#fn-coc]_
2016-06-28 04:05:22 +00:00
By participating, you are expected to honor this code.
.. [#fn-let-me-know] `<https://bidict.readthedocs.io/#notice-of-usage>`__
.. [#fn-coc] `<CODE_OF_CONDUCT.rst>`_ | `<https://bidict.readthedocs.io/code-of-conduct.html>`__