123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128 |
- .. highlight:: shell
- ============
- Contributing
- ============
- Contributions are welcome, and they are greatly appreciated! Every little bit
- helps, and credit will always be given.
- You can contribute in many ways:
- Types of Contributions
- ----------------------
- Report Bugs
- ~~~~~~~~~~~
- Report bugs at https://github.com/audreyr/py_thesis_toolbox/issues.
- If you are reporting a bug, please include:
- * Your operating system name and version.
- * Any details about your local setup that might be helpful in troubleshooting.
- * Detailed steps to reproduce the bug.
- Fix Bugs
- ~~~~~~~~
- Look through the GitHub issues for bugs. Anything tagged with "bug" and "help
- wanted" is open to whoever wants to implement it.
- Implement Features
- ~~~~~~~~~~~~~~~~~~
- Look through the GitHub issues for features. Anything tagged with "enhancement"
- and "help wanted" is open to whoever wants to implement it.
- Write Documentation
- ~~~~~~~~~~~~~~~~~~~
- py_thesis_toolbox could always use more documentation, whether as part of the
- official py_thesis_toolbox docs, in docstrings, or even on the web in blog posts,
- articles, and such.
- Submit Feedback
- ~~~~~~~~~~~~~~~
- The best way to send feedback is to file an issue at https://github.com/audreyr/py_thesis_toolbox/issues.
- If you are proposing a feature:
- * Explain in detail how it would work.
- * Keep the scope as narrow as possible, to make it easier to implement.
- * Remember that this is a volunteer-driven project, and that contributions
- are welcome :)
- Get Started!
- ------------
- Ready to contribute? Here's how to set up `py_thesis_toolbox` for local development.
- 1. Fork the `py_thesis_toolbox` repo on GitHub.
- 2. Clone your fork locally::
- $ git clone git@github.com:your_name_here/py_thesis_toolbox.git
- 3. Install your local copy into a virtualenv. Assuming you have virtualenvwrapper installed, this is how you set up your fork for local development::
- $ mkvirtualenv py_thesis_toolbox
- $ cd py_thesis_toolbox/
- $ python setup.py develop
- 4. Create a branch for local development::
- $ git checkout -b name-of-your-bugfix-or-feature
- Now you can make your changes locally.
- 5. When you're done making changes, check that your changes pass flake8 and the
- tests, including testing other Python versions with tox::
- $ flake8 py_thesis_toolbox tests
- $ python setup.py test or pytest
- $ tox
- To get flake8 and tox, just pip install them into your virtualenv.
- 6. Commit your changes and push your branch to GitHub::
- $ git add .
- $ git commit -m "Your detailed description of your changes."
- $ git push origin name-of-your-bugfix-or-feature
- 7. Submit a pull request through the GitHub website.
- Pull Request Guidelines
- -----------------------
- Before you submit a pull request, check that it meets these guidelines:
- 1. The pull request should include tests.
- 2. If the pull request adds functionality, the docs should be updated. Put
- your new functionality into a function with a docstring, and add the
- feature to the list in README.rst.
- 3. The pull request should work for Python 3.5, 3.6, 3.7 and 3.8, and for PyPy. Check
- https://travis-ci.com/audreyr/py_thesis_toolbox/pull_requests
- and make sure that the tests pass for all supported Python versions.
- Tips
- ----
- To run a subset of tests::
- $ python -m unittest tests.test_py_thesis_toolbox
- Deploying
- ---------
- A reminder for the maintainers on how to deploy.
- Make sure all your changes are committed (including an entry in HISTORY.rst).
- Then run::
- $ bump2version patch # possible: major / minor / patch
- $ git push
- $ git push --tags
- Travis will then deploy to PyPI if tests pass.
|