Contributions are welcomed, and they are greatly appreciated! Every little bit helps, and credit will always be given.
Report bugs at https://github.com/LUXROBO/pymodi/issues. Fill in all the information required at issue template.
Look through the GitHub issues for bugs. You are welcome to implement anything tagged with "bug" and "help wanted".
Look through the GitHub issues for features. You are welcome to implement anything tagged with "bug" and "help wanted".
PyMODI could always use more documentation, whether it be part of the official PyMODI docs, docstrings, or even blog posts, articles, and such.
The best way to send feedback is to file an issue at
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 :)
You should be familiar with the following items.
- git-flow
- python unit-test
- git commit message naming convention
- docstring
- python type annotations
Please read the following to get ready for the contribution!!
-
Fork the pymodi repo on GitHub
^ Click this to fork the repo!!
-
In your device, clone your fork locally:
$ git clone [email protected]:your_name_here/LUXROBO/pymodi.git
-
Install the version of PyMODI in your branch:
$ python setup.py develop
Or, in the rootdir, use this command instead:
$ python -m pip install -e .
-
Setup the git hooks to facilitate contribution:
$ pre-commit install
-
Do NOT manipulate master branch or develop branch directly. Create a new branch for local development.
PyMODI's branch naming convention follows a git-flow convention,
If you fixed a bug:
$ git checkout -b hotfix/name-of-your-bug-fix
If you implemented a new feature:
$ git checkout -b feature/name-of-your-feature
-
Whenever you make major changes, make a commit to the repository:
$ git add file-you-have-changed $ git commit -m your-commit-message
PyMODI contribution follows a git naming convention for the commit messages. https://chris.beams.io/posts/git-commit/
TL;DR: When writing a commit message, imagine your message is preceded by
"This commit will... your-commit-mesage"
e.g.
$ git commit -m "Fix error in motor module communication" $ git commit -m "Refactor contribution document" $ git commit -m "Remove redundant import in modi.py"
-
After you push your changes to local branch, make sure your code passes all unittests and flake8 convention tests. If you have set your githooks path at step 4, git will automatically run the tests when you push your changes.
-
Make a pull request to LUXROBO/pymodi/develop branch.
Name the pull request based on the default PR templates. Choose either of the templates based on the type of your contribution.
-
Congratulations! You made a meaningful contribution to PyMODI.
If you have any questions regarding PyMODI, contact us at [email protected]