Description
Checklist
- [ x] the issue is indeed a bug and not a support request
- [ x] issue doesn't already exist: https://github.com/kivy/python-for-android/issues
- [x ] I have a short, runnable example that reproduces the issue
- [ x] I reproduced the problem with the latest development version (
p4a.branch = develop
) - [ x] I used the grave accent (aka backticks) to format code or logs when appropriated
Versions
- Python: 3.11
- OS: WSL/Ubuntu
- Kivy: 2.2.1
- Cython: 0.29.33
- OpenJDK: 17
Description
In buildozer.spec , setting:
android.extra_manifest_application_arguments = somefile.xml
Where somefile.xml
contains:
android:usesCleartextTraffic="true"
results in an excaped string argument from Buildozer to p4a:
# Run ['/usr/bin/python3', '-m', 'pythonforandroid.toolchain', 'apk', '--bootstrap', 'sdl2', '--dist_name', 'oauth_gspread_example', '--name', 'OG', '--version', '0.1', '--package', 'org.reallyatest.oauth_gspread_example', '--minsdk', '21', '--ndk-api', '21', '--private', '/home/bobf/ex/oauth_gspread_example/.buildozer/android/app', '--permission', 'INTERNET', '--android-entrypoint', 'org.kivy.android.PythonActivity', '--android-apptheme', '@android:style/Theme.NoTitleBar', '--orientation', 'portrait', '--window', '--enable-androidx', '--copy-libs', '--add-source', '/home/bobf/ex/oauth_gspread_example/java', '--extra-manifest-application-arguments="android:usesCleartextTraffic=\\"true\\" "', '--arch', 'arm64-v8a', '--color=always', '--storage-dir=/home/bobf/ex/oauth_gspread_example/.buildozer/android/platform/build-arm64-v8a', '--ndk-api=21', '--ignore-setup-py', '--debug']
the key part to note is the value from somefile.xml
has been quoted and escaped:
'--extra-manifest-application-arguments="android:usesCleartextTraffic=\\"true\\" "'
The value is written without interpretation to AndroidManifest.xml
as an escaped string
<application android:label="@string/app_name"
android:debuggable="true"
android:icon="@mipmap/icon"
android:allowBackup="true"
"android:usesCleartextTraffic=\"true\" "
android:theme="@android:style/Theme.NoTitleBar"
Gradle dies with:
AndroidManifest.xml; lineNumber: 53; columnNumber: 18; Element type "application" must be followed by either attribute specifications, ">" or "/>".
The last but one line in the AndroidManifest.xml
snippet above should the same a the contents of somefile.xml
android:usesCleartextTraffic="true"
Presumably, Buildozer has to quote and escape in order to pass the argument, so the issue is assumed to be a failure of the p4a parser to decode the argument.
Since we presumably know Buildozer's (quote and escape) encoding algorithm, it should be possible to successfully decode. A simpler approach might be a new p4a argument receiving the file name, and Buildozer supplying the file name.
I didn't test but this may also apply to the buildozer.spec
android.extra_manifest_xml
option.