Dev:Development Session 44


 * When: 2019-11-10 18:00 UTC
 * Where: https://gitter.im/termux/dev and #termux/development on freenode

Agenda 2019-11-10

 * Version 0.82 and 0.81 (with the lower version for Android 5&6) of the main termux app has been released.
 * Main thing is to fix bootstrap installation on android 5&6 by reverting back to installing bootstrap zips from termux.net (but updated ones, under http://termux.net/bootstrap/new/). Note that this does not affect Android 7+ devices using 0.82, which still has embedded bootstrap files.
 * Also a small improvement to terminal emulation and scroll margins, termux/termux-app#1340.

Thoughts from xeffyr on Android 10+
To have Termux working on future Android versions we will have stick to official ways of storing executable code inside APK. Proot may work on Android 10, but in future it may be broken in cases if Google will disallow mmap(PROT_EXEC), execmem or other similar. Proot has nice features, but I guess no one wants to change package distribution implementation each time after Google release newer security hardening solutions.

I see no more viable ways to distribute packages other than https://github.com/termux/termux-packages/wiki/Termux-and-Android-10#1-distribute-packages-bundled-in-apps (bundling inside APKs).

Bundling inside APKs and not using proot effectively kills all variants of user's native code, so compilers (clang, golang, rust) and all things related to them will be useless for Android 10. That is quite huge tradeoff for having Termux working on past API 29 and will have much more impact on user's experience than e.g. dropping Android 5.

Yes, we can wait with any decisions but I guess amount of possible solutions will not change - they are all around custom executable loader (proot) or packaging binaries in APK native lib directory (official Android way).

Few issues regarding in-apk packaging:


 * 1) How packages should be stored inside APKs? We may put everything inside native lib directory of APK. That will most likely break symlinks (e.g. being replaced either with a file or not extracted at all) and will introduce problem with prefix (it will be random on each installation). Another variant is to have executables in native lib directory and data in regular path - /data/data/com.termux/files/usr. In this case we will need to have dynamic prefix only for executable calls (e.g. cases like exec(/bin/sh, args)). Does not solve issue regarding symlinks for executables in lib directory.
 * 2) How to deal with packages having shared libraries in their data (e.g. Ruby & Python native extensions) ? (extension to packaging issue 1)
 * 3) Usability of lang-specific package managers: many things relying on native extensions, are gem, pip, cpan, npm and others still be useful and should be packaged even if in most cases they will fail ?
 * 4) What if Google Play will remove all non-SO files from native lib directory during splitting APK per architectures?

Storing executables as lib{name}.so is not a variant since they should be callable via their name (e.g. ffmpeg binary should be callable via ffmpeg and not libffmpeg.so).