This repository holds the Python bindings for ev3dev, ev3dev-lang-python.
Please make sure you have read the FAQ. If you are still encountering your problem, open an issue, and ensure that the questions asked by the issue template are completely answered with correct info. This will make it much easier for us to help you!
Contributions are welcome in the form of pull requests - but please take a moment to read our suggestions for happy maintainers and even happier users.
Sometimes, it isn't easy for us to pull your suggested change and run
rigorous testing on it. So please help us out by validating your changes
and mentioning what kinds of testing you did when you open your PR.
Please also consider adding relevant tests to api_tests.py
and documentation
changes within the docs
directory.
This is where the latest version of our library lives. It targets
ev3dev-stretch
, which is the current stable version of ev3dev.
We publish releases from this branch.
Breaking changes are discouraged, but sometimes they are necessary. A more common change is to add a new function or property to a class. If you add a new parameter to an existing function, give it a default value so as not to break existing code that calls the function.
Either way, if it's more than a bug fix, please add enough text to the comments in the pull request message so that we know what was updated and can easily discuss the breaking change and add it to the release notes.
Bug fixes are always welcome, especially if they are against known issues!
When you send a pull request that addresses an issue, please add a
note of the format Fixes #24
in the PR so that the PR links back
to its relevant issue and will automatically close the issue when the
PR is merged.
In an SSH terminal window with an EV3 with Internet access,
run the following commands:
(recall that the default sudo
password is maker
)
`shell
git clone https://github.com/ev3dev/ev3dev-lang-python.git
cd ev3dev-lang-python
sudo make install
`
To update the module, use the following commands:
cd ev3dev-lang-python
git pull
sudo make install
If you are developing micropython support, you can take a shortcut and use the following command to build and deploy the micropython files only:
cd ev3dev-lang-python
sudo make micropython-install
To re-install the latest release, use the following command:
sudo apt-get --reinstall install python3-ev3dev2
Or, to update your current ev3dev2 to the latest release, use the following commands:
sudo apt update
sudo apt install --only-upgrade micropython-ev3dev2
- Update the changelog, including a correct release date. Use
date -R
to get correctly-formatted date. - Commit the changelog. By convention, use message like
Update changelog for 2.1.0 release
. - Build/update pbuilder base images:
OS=debian DIST=stretch ARCH=amd64 pbuilder-ev3dev base
andOS=raspbian DIST=stretch ARCH=armhf pbuilder-ev3dev base
. ./debian/release.sh
and enter passwords/key passphrases as neededgit push
git push --tags
git tag -d stable
git tag stable
git push --tags --force
git tag -a 2.1.0 -m "python-ev3dev2 PyPi release 2.1.0"
git push --tags
Note that push order is important; the CI server will get confused if you push other tags pointing to the same commit after you push the PyPi release tag. This doesn't actually cause release issues, but does mark the CI builds as "failed" because it tried to publish the same release again.
Check all of the following after release is complete:
- Emails from package server don't include any errors
- All Travis CI builds succeeded
- New release is available on PyPi
- Release tags are up on GitHub
- ReadTheDocs is updated
- ReadTheDocs "stable" version points to latest release
- There is an explicit version tag for the last-released version (exeption:
2.1.0
) - There is an explicit version tag for this version (you will likely need to manually activate it)
- All ReadTheDocs builds succeeded