Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/progdrasil/pyo3-buildozer
https://github.com/progdrasil/pyo3-buildozer
Last synced: 15 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/progdrasil/pyo3-buildozer
- Owner: Progdrasil
- Created: 2020-08-02T21:47:02.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2020-08-03T15:27:26.000Z (over 4 years ago)
- Last Synced: 2024-11-06T08:32:39.619Z (2 months ago)
- Language: Python
- Size: 11.7 KB
- Stars: 2
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# PYO3 on android
This is an example of building a [PYO3] Library using [buildozer].
[buildozer]: https://github.com/kivy/buildozer
[pyo3]: https://github.com/PyO3/pyo3## Docker build
You can build the buildozer image with the following command:
```shell
docker build -t buildozer -f buildozer.Dockerfile .
```You can then start a build from outside the container with the following command:
```shell
docker run --rm -v "$(pwd)":/home/user/hostcwd buildozer android debug
```However the easiest way to deal with buildozer through docker is to run it interactivelly by entering it with bash.
To run on a device from docker you need to mount the usb bus to the container in priviledged mode.
Putting it all together looks like so:```shell
docker run --rm -v "$(pwd)":/home/user/hostcwd -v /dev/bus/usb:/dev/bus/usb --privileged -it --entrypoint=bash buildozer
```Now you can run any of the buildozer commands.
The most usefull ones are to build```sh
buildozer android debug
```And to deploy run and print the debug logs.
For debugging it is easiest to redirect to a file for later analysis.```sh
buildozer android deploy run logcat > out.log
```## Troubleshooting
If you are getting a runtime error of `ImportError: dlopen failed: cannot locate symbol "PyExc_BaseException"` or the same but for `_Py_NoneStruct` there is a workaround while the issue is being treated [upstream].
You must link to the `m` of libpython by either setting the rust flags in a `.cargo/config` or as the `RUSTFLAGS` environement variable at build time.
`.cargo/config`
```toml
[target.aarch64-linux-android]
rustflags = [ "-C", "link-args=-L -lpythonX.Ym"][target.armv7-linux-androideabi]
rustflags = [ "-C", "link-args=-L -lpythonX.Ym"]
```Or as we do here, the `RUSTFLAGs="-C link-args=-L -lpythonX.Ym"` variable is set in the [Python for android recipe].
[upstream]: https://github.com/PyO3/pyo3/issues/1077
[Python for android recipe]: https://github.com/Progdrasil/pyo3-buildozer/blob/master/p4a/my_lib/__init__.py#L24