diff --git a/README.md b/README.md index 84e5b72bc..8941d7ea6 100644 --- a/README.md +++ b/README.md @@ -9,7 +9,7 @@ This project contains scripts and patches to build packages for the [Termux](https://termux.com/) Android application. Note that on-device package building is supported only partially for now. -More information can be found in the [docs](docs/) directory. +More information can be found in the project's [Wiki](https://github.com/termux/termux-packages/wiki). ## Directory Structure diff --git a/docs/BUILD.md b/docs/BUILD.md deleted file mode 100644 index 72a81f51e..000000000 --- a/docs/BUILD.md +++ /dev/null @@ -1,218 +0,0 @@ -# Build Documentation - -This document is intended to describe how to build a package. - -## Flow of a Build - -### Basics - -Package build flow is controlled by script [build-package.sh](../build-package.sh) -and is split into the following stages: - -1. Read `packages/$PKG/build.sh` to obtain package metadata (e.g. version, - description, dependencies), URLs for source code and steps to build package. - -2. Extract the archives with source code into `$HOME/.termux-build/$PKG/src`. - This step is not performed when `TERMUX_PKG_SKIP_SRC_EXTRACT` is set. - -3. Build package for the host. This step is performed only when - `TERMUX_PKG_HOSTBUILD` is set. - -4. Set up a standalone Android NDK toolchain and patch NDK sysroot from patches - located in [ndk-patches](../ndk-patches) directory. This step performed only - one time per each architecture. - -5. Search for patches in `packages/$TERMUX_PKG_NAME/*.patch` and apply them. - -6. Build the package under directory `$HOME/.termux-build/$PKG/build`. If - `TERMUX_PKG_BUILD_IN_SRC` is set, then build will be done in directory `$HOME/.termux-build/$PKG/src`. - -7. Install built stuff into `$TERMUX_PREFIX`. - -8. Find modified files in `$TERMUX_PREFIX` and extract them into - `$HOME/.termux-build/$PKG/massage`. - -9. Perform "massage" on files in `$HOME/.termux-build/$PKG/massage`. For example, - split files between subpackages. - -10. Create a debian archive file that is ready for distribution. - -### Details Table - -| Order | Function Name | Overridable | Description | -| -----:|:-------------:| -----------:|:----------- | -| 0.1 | `termux_error_exit` | no | Stop script and output error. | -| 0.2 | `termux_download` | no | Utility function to download any file. | -| 0.3 | `termux_setup_golang` | no | Setup Go Build environment. | -| 0.4 | `termux_setup_rust` | no | Setup Cargo Build. | -| 0.5 | `termux_setup_ninja` | no | Setup Ninja make system. | -| 0.6 | `termux_setup_meson` | no | Setup Meson configure system. | -| 0.7 | `termux_setup_cmake` | no | Setup CMake configure system. | -| 1 | `termux_step_handle_arguments` | no | Handle command line arguments. | -| 2 | `termux_step_setup_variables` | no | Setup essential variables like directory locations and flags. | -| 3 | `termux_step_handle_buildarch` | no | Determines architecture to build for. | -| 4 | `termux_step_get_repo_files` | no | Install dependencies if `-i` option supplied. | -| 4.1 | `termux_download_deb` | no | Download packages for installation | -| 5 | `termux_step_start_build` | no | Setup directories and files required. Read `build.sh` for variables. | -| 6 | `termux_step_extract_package` | yes | Download source package. | -| 7 | `termux_step_post_extract_package` | yes | Hook to run commands before host builds. | -| 8 | `termux_step_handle_host_build` | yes | Determine whether a host build is required. | -| 8.1 | `termux_step_host_build` | yes | Conduct a host build. | -| 9 | `termux_step_setup_toolchain` | no | Setup C Toolchain from Android NDK. | -| 10 | `termux_step_patch_package` | no | Patch all `*.patch` files as specified in the package directory. | -| 11 | `termux_step_replace_guess_scripts` | no | Replace `config.sub` and `config.guess` scripts. | -| 12 | `termux_step_pre_configure` | yes | Hook to run commands before configures. | -| 13 | `termux_step_configure` | yes | Determine the configure method. | -| 13.1 | `termux_step_configure_autotools` | no | Run `configure` by GNU Autotools. | -| 13.2 | `termux_step_configure_cmake` | no | Run `cmake`. | -| 13.3 | `termux_step_configure_meson` | no | Run `meson`. | -| 14 | `termux_step_post_configure` | yes | Hook to run commands before make. | -| 15 | `termux_step_make` | yes | Make the package. | -| 16 | `termux_step_make_install` | yes | Install the package. | -| 17 | `termux_step_post_make_install` | yes | Hook before extraction. | -| 18 | `termux_step_install_license` | yes | ln or cp package LICENSE to usr/share/PKG/. | -| 19 | `termux_step_extract_into_massagedir` | no with `make_install` | Extracts installed files. | -| 20 | `termux_step_massage` | no | Remove unusable files. | -| 20.1 | `termux_create_subpackages` | no | Creates all subpackages. | -| 21 | `termux_step_post_massage` | yes | Final hook before packaging. | -| 22 | `termux_step_create_datatar` | no | Archive package files. | -| 23 | `termux_step_create_debfile` | no | Create package. | -| 23.1 | `termux_step_create_debscripts` | yes | Create additional Debian package files. | -| 24 | `termux_step_compare_debfiles` | no | Compare packages if `-i` option is specified. | -| 25 | `termux_step_finish_build` | no | Notification of finish. | - -Order specifies function sequence. 0 order specifies utility functions. - -Suborder specifies a function triggered by the main function. Functions with -different suborders are not executed simultaneously. - -For more detailed descriptiom on each step, you can read [build-package.sh](../build-package.sh) - -## Normal Build Process - -Remarks: Software Developers should provide build instructions either in README -or INSTALL files. Otherwise good luck trying how to build :joy:. - -Follow the instructions until you get a working build. If a build succeeds after -any step, skip the remaining steps. - -1. Create a `build.sh` file using the [sample package template](sample/build.sh). - -2. Create a `subpackage.sh` for each subpackage using the [sample package template](sample/subpackage.sh). - -3. Run `./build-package.sh $PKG` to see what errors are found. - -4. If any steps complain about an error line, first copy the file to another - directory. - -5. Edit the original file. - -6. When tests succeed for the file, create a patch by - `diff -u > packages//.patch` - -7. Repeat steps 4-6 for each error file. - -8. If extra configuration or make arguments are needed, specify in `build.sh` - as shown in sample package. - -9. (optional but appreciated) Test the package by yourself. - -## Common Porting Problems - -- Most programs expect that target is [FHS](https://uk.wikipedia.org/wiki/Filesystem_Hierarchy_Standard) - compliant. They have hardcoded paths like `/etc`, `/bin`, `/usr/share`, `/tmp` - which are not available in Termux at standard locations but only in `$TERMUX_PREFIX`. - -- The Android bionic libc does not have iconv and gettext/libintl functionality - built in. A `libandroid-support` package contains these and may be used by all - packages. - -- "error: z: no archive symbol table (run ranlib)" usually means that the build - machine's libz is used instead of the one for cross-compilation due to the - builder library -L path being setup incorrectly. - -- rindex(3) does not exist, but strrchr(3) is preferred anyway. - -- <sys/termios.h> does not exist, but <termios.h> is the standard - location. - -- <sys/fcntl.h> does not exist, but <fcntl.h> is the standard - location. - -- <sys/timeb.h> does not exist (removed in POSIX 2008), but ftime(3) can - be replaced with gettimeofday(2). - -- <glob.h> does not exist, but is available through the `libandroid-glob` - package. - -- SYSV shared memory is not supported by the kernel. A `libandroid-shmem` - package, which emulates SYSV shared memory on top of the [ashmem](http://elinux.org/Android_Kernel_Features#ashmem) - shared memory system, is available. Use it with `LDFLAGS+=" -landroid-shmem`. - -- SYSV semaphores are not supported by the kernel. Use unnamed POSIX semaphores - instead (named semaphores are unimplemented). - -- Starting from Android 8, a [Seccomp](https://android-developers.googleblog.com/2017/07/seccomp-filter-in-android-o.html) - was enabled for applications. Seccomp forbids usage of some system calls - which results in crash with `Bad system call` errors. - -- Starting from Android 8, programs cannot use `tcsetattr()` with `TCSAFLUSH` - parameter due to SELinux. Use `TCSANOW` instead. - -- Starting from Android 9, [Seccomp](https://android-developers.googleblog.com/2017/07/seccomp-filter-in-android-o.html) - began to block `setuid()`-related system calls. Since Termux is primarily for - single-user non-root usage, setuid/setgid functionality is discouraged anyway. - -### dlopen() and RTLD_* flags - -<dlfcn.h> declares -```C -RTLD_NOW=0; RTLD_LAZY=1; RTLD_LOCAL=0; RTLD_GLOBAL=2; RTLD_NOLOAD=4; // 32-bit -RTLD_NOW=2; RTLD_LAZY=1; RTLD_LOCAL=0; RTLD_GLOBAL=0x00100; RTLD_NOLOAD=4; // 64-bit -``` -These differs from glibc ones in that - -1. They differ in value from glibc ones, so cannot be hardcoded in files - (DLFCN.py in python does this) - -2. They are missing some values (`RTLD_BINDING_MASK`, ...) - -### Android Dynamic Linker - -The Android dynamic linker is located at `/system/bin/linker` (32-bit) or -`/system/bin/linker64` (64-bit). Here are source links to different versions of the linker: - -- [Android 5.0 linker](https://android.googlesource.com/platform/bionic/+/lollipop-mr1-release/linker/linker.cpp) - -- [Android 6.0 linker](https://android.googlesource.com/platform/bionic/+/marshmallow-mr1-release/linker/linker.cpp) - -- [Android 7.0 linker](https://android.googlesource.com/platform/bionic/+/nougat-mr1-release/linker/linker.cpp) - -Some notes about the linker: - -- The linker warns about unused [dynamic section entries](https://docs.oracle.com/cd/E23824_01/html/819-0690/chapter6-42444.html) - with a `WARNING: linker: $BINARY: unused DT entry: type ${VALUE_OF_d_tag}` - message. - -- The supported types of dynamic section entries have increased over time. - -- The Termux build system uses [termux-elf-cleaner](https://github.com/termux/termux-elf-cleaner) - to strip away unused ELF entries causing the above mentioned linker warnings. - -- Symbol versioning is supported only as of Android 6.0, so is stripped away. - -- `DT_RPATH`, the list of directories where the linker should look for shared - libraries is not supported, so is stripped away. - -- `DT_RUNPATH`, the same as above but looked at after `LD_LIBRARY_PATH`, is - supported only from Android 7.0, so is stripped away. - -- Symbol visibility when opening shared libraries using `dlopen()` works - differently. On a normal linker, when an executable linking against a shared - library libA dlopen():s another shared library libB, the symbols of libA are - exposed to libB without libB needing to link against libA explicitly. This - does not work with the Android linker, which can break plug-in systems where - the main executable dlopen():s a plug-in which doesn't explicitly link against - some shared libraries already linked to by the executable. - See [the relevant NDK issue](https://github.com/android-ndk/ndk/issues/201) - for more information. diff --git a/docs/BUILD_ENVIRONMENT.md b/docs/BUILD_ENVIRONMENT.md deleted file mode 100644 index b525fca38..000000000 --- a/docs/BUILD_ENVIRONMENT.md +++ /dev/null @@ -1,67 +0,0 @@ -# Build Environment Documentation - -This document is inteneded to describe how to set up a build environment. - -Builds are run on Ubuntu installations. - -## Docker - -For most people the best way to obtain an environment for building packages is -by using Docker. This should work everywhere Docker is supported (replace `/` -with `\` if using Windows) and ensures an up to date build environment that is -tested by other package builders. - -Run the following script to setup a container (from an image created by -[scripts/Dockerfile](../scripts/Dockerfile)) suitable for building packages: -```Shell -./scripts/run-docker.sh -``` -This source folder is mounted as the `/root/termux-packages` data volume, so -changes are kept in sync between the host and the container when trying things -out before committing, and built deb files will be available on the host in the -`debs/` directory just as when building on the host. - -The docker container used for building packages is a Ubuntu installation with -necessary packages pre-installed. The default user is a non-root user to avoid -problems with package builds modifying the system by mistake, but `sudo` can be -used to install additional Ubuntu packages to be used during development. - -Build commands can be given to be executed in the docker container directly: -```Shell -./scripts/run-docker.sh ./build-package.sh libandroid-support -``` -will launch the docker container, execute the `./build-package.sh libandroid-support` -command inside it and afterwards return you to the host prompt, with the newly -built deb in `debs/` to try out. - -For Windows users, there is also a PowerShell script available to start the -docker. Run with (be aware of backslashes and normal slashes): -```PowerShell -.\scripts\run-docker.ps1 ./build-package.sh libandroid-support -``` -Note that building packages can take up a lot of space (especially if `build-all.sh` -is used to build all packages) and you may need to [increase the base device size](http://www.projectatomic.io/blog/2016/03/daemon_option_basedevicesize/) -if running with a storage driver using a small base size of 10 GB. - -## Ubuntu PC - -If you can't run Docker you can use a Ubuntu 19.04 installation by using the -below scripts: - -- Run `scripts/setup-ubuntu.sh` to install required packages and setup the - `/data/` folder. - -- Run `scripts/setup-android-sdk.sh` to install the Android SDK and NDK at - `$HOME/lib/android-{sdk,ndk}`. - -## Ubuntu VM - -There is a [Vagrantfile](../scripts/Vagrantfile) for setting up a VirtualBox -Ubuntu installation. - -- Run `vagrant plugin install vagrant-disksize` to install disksize plugin for - Vagrant. - -- Run `cd scripts && vagrant up` to setup and launch the virtual machine. - -- Run `vagrant ssh` to ssh into the virtual machine. diff --git a/docs/FORMAT.md b/docs/FORMAT.md deleted file mode 100644 index a028c7b01..000000000 --- a/docs/FORMAT.md +++ /dev/null @@ -1,66 +0,0 @@ -# Formatting Guidelines - -All files should adhere to these formatting guidelines. - -## Shell Script Formatting - -- All `build.sh` files should be set to `644` permission. - -- All scripts should use tabs rather than spaces. - -- All parantheses of shell functions should not be preceded with a space. - -- Avoid trailing spaces and tabs. - -- Avoid usage of non UTF-8 encoding. - -- Comments should be compact. Do not tab them if not necessary. - -## Shell Script Coding Practices - -- Do not define global scope variables if not necessary. - -- Do not export variables if not necessary. - -- Custom variables in build.sh scripts should be defined inside functions. - If you need a "global scope" variable at build time, just define it in - `termux_step_pre_configure()`. If you still need to define variable outside - of function, make sure that it does not use command or process substitution. - -- Dollar parentheses `$()` rather than backticks ``` `` ``` should be employed - in command substitution. - -- Usage of `sudo` or `su` in build scripts is disallowed. - -- Utility `install` is preferred over `cp` as the file installation program. - -- Do not hardcode version numbers. Instead, use the `$TERMUX_PKG_VERSION` and - `$TERMUX_PKG_REVISION` variables. - -- Do not hardcode Termux prefix directory. Instead, use the `$TERMUX_PREFIX` - variable. - -- Do not hardcode Termux home directory. Instead, use the `$TERMUX_ANDROID_HOME` - variable. - -## Markdown Formatting - -- All `filenames` should be under code formatting, unless they are links. - -- All titles should be indented with hashes rather than equal signs. - -- All unnumbered lists should be indented with hyphens. - -- All Markdown should be edited on alternate line. - -- All Markdown should use tabs rather than spaces. - -- All `.md` should be set to `644` permission. - -- All special characters should be escaped. - -- All names of `.md` should be capitalised. - -- All code blocks should be enclosed in backticks, with language specified. - -- Lines shouldn't be longer than 80 characters. diff --git a/docs/RESOURCES.md b/docs/RESOURCES.md deleted file mode 100644 index 3ffdc6226..000000000 --- a/docs/RESOURCES.md +++ /dev/null @@ -1,11 +0,0 @@ -# External Resources Links - -- [Android changes for NDK developers](https://android.googlesource.com/platform/bionic/+/master/android-changes-for-ndk-developers.md) - -- [Linux From Scratch](http://www.linuxfromscratch.org/lfs/view/stable/) - -- [Beyond Linux From Scratch](http://www.linuxfromscratch.org/blfs/view/stable/) - -- [OpenWrt](https://openwrt.org/) as an embedded Linx distribution contains [patches and build scripts](https://dev.openwrt.org/browser/packages) - -- [Kivy recipes](https://github.com/kivy/python-for-android/tree/master/pythonforandroid/recipes) contains recipes for building packages for Android. diff --git a/docs/UTILITIES.md b/docs/UTILITIES.md deleted file mode 100644 index 7d93ca078..000000000 --- a/docs/UTILITIES.md +++ /dev/null @@ -1,25 +0,0 @@ -# Additional Utilities List - -The following utility scripts are available: - -- [build-all.sh](../build-all.sh): - used for building all packages in the correct order (using buildorder.py). - -- [clean.sh](../clean.sh): - used for cleaning build environment. - -- [scripts/check-built-packages.py](../scripts/check-built-packages.py): - used for comparing git (local) and apt (remote) package versions. - -- [scripts/check-pie.sh](../scripts/check-pie.sh): - used for verifying that all binaries are using PIE, which is required for - Android 5+. - -- [scripts/check-versions.sh](../scripts/check-versions.sh): - used for checking for package updates. - -- [scripts/list-packages.sh](../scripts/list-packages.sh): - used for listing all packages with a one-line summary. - -- [scripts/package_uploader.sh](../scripts/package_uploader.sh): - used for uploading packages to Bintray.