Package Management

Termux uses apt and dpkg for package management, similar to Ubuntu or Debian. Many quirks from Ubuntu are carried over here. Development files and headers are provided in a separate package with "-dev" suffix, for example, development files for "apache2" package are in "apache2-dev".

Installing packages from APT repository
In Termux it is recommended to use package manager pkg which is a wrapper for apt. It simplifies installing or upgrading packages by automatically updating apt lists so you don't have to type  when installing or upgrading packages.

Install package:

pkg install [package name]

Remove package:

pkg uninstall [package name]

List all packages:

pkg list-all

For more information about available commands you can either just run pkg without arguments or like this:.

Warning: if you prefer to use apt over pkg - never run it as root as you will mess up file permissions and SELinux contexts so you won't be able to use it as normal user. If did this and your environment was broken, do not ask for help - this is your own fault !

Manual installation of *.deb files
If you have a *.deb package file, you can install it with dpkg. Note that packages downloaded from Ubuntu or from repositories of other Linux distributions will not work due to incompatible libc ABI, however statically compiled binaries may work.

Installing:

dpkg -i ./package.deb

Uninstalling:

dpkg --remove [package name]

Listing all installed packages:

dpkg -l

Since dpkg has many useful options, you may want to see it's manual via.

Official repositories
Some repositories can be enabled by installing packages ending with. The repositories that can be accessed in this way at the time of writing are

For a repository to be considered official it needs to have build scripts for cross-compilation available for all hosted packages. Packages built on device and thereafter packaged with  can therefore not be included in the official repositories.

All the repositories with build scripts in a repo at github.com/termux/ are maintained and signed by someone on the termux team, the keys used for signing are available in the package termux-keyring. For more information about how the repositories are signed, see termux-keyring.

Community repositories
In addition to the official repositories, there are repositories hosted by community members. You are welcome to host own Termux repository too.

You can create own repository by using termux-apt-repo from the command line and Github Pages as hosting. Be aware that Github has a strict limit of 100 MB per file and if your repository exceeds total size of 1 GB, you might receive a polite email from GitHub Support requesting that you reduce the size of the repository. So if you have really big packages you may want to use a different hostings. Choose hostings according to filetypes, for example, videos can be hosted at https://YouTube.com or similar.

By its-pointless (live_the_dream):
Repository of this community member includes gcc-7, gfortran, octave, r-cran (R language), rustc (with cargo), scipy and lots of games!

To add this repository, execute:

pkg install wget $PREFIX/bin/wget https://its-pointless.github.io/setup-pointless-repo.sh bash setup-pointless-repo.sh

The script essentially installs gnupg on your device, downloads and adds a public key to your apt keychain ensuring that all subsequent downloads are from the same source.

Package requests
Packages can be requested at https://github.com/termux/termux-packages/issues

Root packages can be requested at https://github.com/termux/termux-root-packages/issues

X11 packages can be requested at https://github.com/termux/x11-packages/issues/new?template=PACKAGE_REQUEST.md

Things to check before requesting a package:


 * No other issues have been created for the same package request.


 * Hardware requirements of the package is compatible with Android 5.0+ devices.


 * Package will be useful for other people.


 * Package is not a dead/unmaintained project.


 * Package is not interpreter based (except for shell-based) - they cannot be easily packaged into *.deb file. In most cases it can be installed by using appropriate package manager for your language (pip, gem, etc...), use it instead of opening package request.

Other package managers
Some programming languages have their own package manager. Everything that can be installed with such a manager is not packaged with Termux, but should be available on-the-fly on device.


 * Node.js Package Management (npm)
 * Perl Package Management (cpan)
 * Python Package Management (pip)
 * Ruby Package Management (gem)
 * TeX Live Package Management (tlmgr)

Cross-compiling
Packages from official Termux repository can be compiled by using a special environment termux-packages. It is recommended to use a docker image so you will not mess up your OS.

To setup a build environment, follow instructions written here: https://github.com/termux/termux-packages/blob/master/README.md

Compiling packages on device
Termux has enough power to compile software - use it to build your own programs or ones that is not available in official or community repositories.

Installing necessary software
By default, Termux has only few packages installed so you need additional packages. Execute in terminal to install must have tools: pkg upgrade && pkg install autoconf automake bison bzip2 clang cmake \ coreutils diffutils flex gawk git grep gzip libtool make patch perl \ sed silversearcher-ag tar wget pkg-config

Getting the dependencies
Many programs require additional software to work. You may not know all of them so this can result in errors in compile time or sometimes when using some features of built software. Use ArchLinux package database or other to find all needed dependencies for specific package. Since Termux has a large amount of packages (over 720), common libraries and headers are available and you can search for needed ones by query ending with "-dev" and install. For example, if your program needs library 'readline', then you need to execute the following command to install it: pkg install readline-dev Some dependencies may not be available in Termux repositories so you should compile them manually.

Preparing the source code
Many open source programs have hardcoded paths to various files.

The common hardcoded paths are:
 * /bin
 * /etc
 * /sbin
 * /tmp
 * /usr
 * /var

Use SilverSearcher (available via apt) to find them all and edit appropriate source file to append a prefix '/data/data/com.termux/files/usr'.

Example use of SilverSearcher to find references to '/tmp' (in e2fsprogs source code): [termux]:~/e2fsprogs-1.43.7:$ ag --cc /tmp lib/ext2fs/ismounted.c 237:	retval = check_mntent_file("/tmp/mtab", file, mount_flags, In the above example, an entry of '/tmp' was found at line 237 of file 'lib/ext2fs/ismounted.c'. So edited line should be: 237:	retval = check_mntent_file("/data/data/com.termux/files/usr/tmp/mtab", file, mount_flags,

You may want to read a manual about SilverSearcher by executing.

Compiling software (GNU autotools based)
If you found in root of the source tree files named 'configure', 'configure.ac', 'Makefile.in', then software uses a GNU build system called autotools. To build software that use this build system follow the instructions.

1. Update scripts 'config.sub' and 'config.guess' - without this, build may fail on configuration step because target environment cannot be determined. Execute these commands in root of the source tree: find. -name 'config.sub' -exec chmod u+w '{}' \; -exec cp -f "${PREFIX}/share/libtool/build-aux/config.sub" '{}' \; find. -name 'config.guess' -exec chmod u+w '{}' \; -exec cp -f "${PREFIX}/share/libtool/build-aux/config.guess" '{}' \;

2. You may view all available parameters for configuration script: ./configure --help But you probably shouldn't set them if you are don't know for what they needed - let the ./configure script to decide which configuration is best.

3. Run configuration script: ./configure --prefix="${PREFIX}" CC=clang CXX=clang++

You need to specify a compiler as clang since Termux provides gcc as an alias to it, this needed to avoid some possible errors because by default configure script expects a true GCC. You need to use variables CC and CXX as shown above.

Most of the configure scripts understand the following variables: CC          C compiler command (should be set to clang) CXX         C++ compiler command (should be set to clang++)

LIBS        Libraries to pass to the linker, e.g. -l
 * 1) This variable sometimes should be set to '-landroid-support' or such

CPP         C preprocessor CXXCPP      C++ preprocessor CFLAGS      C compiler flags LDFLAGS     Linker flags, e.g. -L if you have libraries in a             nonstandard directory CPPFLAGS    C/C++/Objective C preprocessor flags, e.g. -I if             you have headers in a nonstandard directory CXXFLAGS    C++ compiler flags
 * 1) These variables shouldn't be set unless you are know what you doing

4. Now run make. You may want to use parallel compilation if your device has multicore CPU: make -j4 Note that most of errors may come in this step, if error occur - you will have to deal with it on your own.

5. After successful compilation, the software can be installed. Be careful, as files installed in this step may silently overwrite files that already provided by Termux packages. make install

Compiling software (CMake based)
Some software uses CMake as build system (check if CMakeLists.txt is exist in the root of source tree). Follow the instructions to compile a cmake-based project.

1. Generate a makefile: mkdir build cd build cmake -DCMAKE_INSTALL_PREFIX="${PREFIX}" ..

2. Run make: make -j4

3. Installing compiled program, be careful at this step: make install

Other
Other project may have different build systems (such as scons). Small projects may have only makefile and can be built by simply running make but this may require manual editing of makefile to set the correct variables (such as PREFIX, CC, CXX).

Automating builds and packaging
While the execution of commands mentioned above may be suitable for one-time builds, it is easily to mess up the whole Termux installation (especially in  step). Also, each time when you need to rebuild your stuff, you have to remember all commands which you typed before. This is impractical and waste your time.

To solve these issues, the tool called termux-makepkg has been created by Xeffyr. When properly used, it will create a *.deb package that can be installed by running. The git repository for this tool is here: https://github.com/xeffyr/termux-stuff/tree/master/scripts/termux-makepkg, in it you can find  script and examples for some packages.

Backup and restore Termux installation
Here we will use a tool called Restic. This utility offers secure incremental backups and ability to save backups on the remote machine as well as on local.

Backing up Termux installation ($PREFIX). Following steps do not backup your $HOME.

1. Install restic. For now, it is located in the "unstable" repository (though, restic is very stable in Termux):

pkg install unstable-repo pkg install restic

2. In this example will be shown how to backup Termux to the local storage. Initializing local restic repository (you will be prompted for password):

mkdir -p /sdcard/termux-backups restic init -r /sdcard/termux-backups

3. Backing up current Termux installation ($PREFIX):

restic backup -r /sdcard/termux-backups --tag termux $PREFIX

Note that you will be prompted for password entered in step 2. Here we created tag "termux" so later it will be easier to distinguish snapshot purposes in case if you have multiple backups in repository. Restic does backups in incremental mode with deduplication - this makes backups take less space and finish faster.

If you need to backup Termux again, simply re-run command from the step 3.

Restoring Termux installation is more complicated. If you need to do this, follow next steps (applicable only for local backups).

1. Make sure that restic is available:

pkg install unstable-repo pkg install restic

2. Since we will remove $PREFIX, copy restic to $HOME - it is a portable binary and doesn't require any dependencies (except Android):

cp $PREFIX/bin/restic $HOME/restic

3. Unset LD_PRELOAD (disable termux-exec):

unset LD_PRELOAD

4. Remove old $PREFIX:

rm -rf $PREFIX

5. Restore Termux from backup:

$HOME/restic restore -r /sdcard/termux-backups --tag termux --target / latest

If everything done right, you should now have a Termux restored from the backup.

Info: if you do not want to enter restic password or specify repository each time, you can set environment variables "RESTIC_PASSWORD" and "RESTIC_REPOSITORY".