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" package.

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 run pkg without arguments.

Manual installation of *.deb files
If you have a *.deb package, you can install it with dpkg. Note that packages downloaded from Ubuntu or from repositories of other linux distributions will not work (even if CPU architecture is correct). 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.

Other Package Managers
Some programming languages have their own package manager. Everything that can be installed with such a manager isn't 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)
 * Texlive Package Management (tlmgr)

Community Repositories
In addition, to the official repository, there are other compatible Termux repositories too. You can create some yourself simply by using termux-apt-repo from the command line and Github as hosting. Be aware that Github has a limit of 100 MB per file in repository so if you have a really big packages you may need to use a different.

auxilus
This repository hosted by Auxilus contains some handy tools (more tools are yet to be added). There is a little under-development survival manual in this repo based on Field Manual FM 3-05.70, which you can install using  after adding the repo. You can add this repository by executing following commands: pkg install apt-transport-https echo "deb [trusted=yes] https://Auxilus.github.io/files termux extras" >> $PREFIX/etc/apt/sources.list pkg update

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 apt-transport-https wget wget https://its-pointless.github.io/setup-pointless-repo.sh bash setup-pointless-repo.sh The script essentially installs gnupg on your device and downloads and adds a public key to your apt keychain ensuring that all subsequent downloads are from the same source.

sdrausty
sdrausty hosts community repositories from an Android smartphone at Github Pages.

https://sdrausty.github.io/repo/ is one of the Termux community repositories hosted at sdrausty.github.io through Github Pages at Github.

You can add this repository by copying and pasting the next three command lines into the Termux window: pkg install apt-transport-https echo "deb [trusted=yes] https://sdrausty.github.io/repo termux extras" >> $PREFIX/etc/apt/sources.list pkg update

This will allow  to access the repo repository at sdrausty.github.io from within Termux through   on your portable device.

xeffyr
Xeffyr's Termux repository hosts X/GUI packages which are currectly experimental.

If you want to use packages like tigervnc, use the following instructions to enable repository in sources.list file. 1. Add gnupg key: pkg install apt-transport-https gnupg wget wget https://xeffyr.github.io/termux-x-repository/pubkey.gpg apt-key add pubkey.gpg 2. Edit $PREFIX/etc/apt/sources.list by adding one of the following lines. Choose line with correct CPU architecture. deb [arch=all,aarch64] https://xeffyr.github.io/termux-x-repository/ termux x-gui
 * 1) For AArch64

deb [arch=all,arm] https://xeffyr.github.io/termux-x-repository/ termux x-gui
 * 1) For ARM

deb [arch=all,i686] https://xeffyr.github.io/termux-x-repository/ termux x-gui
 * 1) For i686

deb [arch=all,x86_64] https://xeffyr.github.io/termux-x-repository/ termux x-gui 3. Update apt lists: pkg update Issues related to this repository/packages could be posted here: https://github.com/xeffyr/termux-x-repository/issues
 * 1) For x86_64

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

Some dos before requesting a package:


 * Hardware requirements of the package is compatible for Android 5.0+ devices,


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


 * In case of interpreter based packages (python, ruby, etc...), the package is not easily installable using the custom package managers (pip, gem),


 * Packages requiring root privileges are generally discouraged, except if they can be patched to work under normal user,


 * Packages in active development are favoured over long dead projects.

Cross-compiling packages
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 not available in official or community repositories.

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

Termux has a prefixed rootfs, this means that build system of software that you want to compile may have incorrect paths to various tools (e.g gawk or sed). To avoid such compatibility problems, you can use termux-exec - feature that allows to execute software from directories like /bin. To enable termux-exec, type in terminal: export LD_PRELOAD=${PREFIX}/lib/libtermux-exec.so exec bash

Also, make sure that environment variable 'PREFIX' is set as it will be used in further instructions: export PREFIX=/data/data/com.termux/files/usr

Getting the dependencies
Many programs require additional programs or libraries 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 libraries may not be available and require compiling from source code.

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 then 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. View all available parameters for configuration script - software may have some useful features that you want to use: ./configure --help

3. Run configuration script with specified prefix - Termux is a prefixed system so option '--prefix' is mandatory: ./configure --prefix="${PREFIX}" CC=clang CXX=clang++

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, sometimes manual editing of makefile is required.

Backup and restore packages
Create a list of currently installed packages:

dpkg --get-selections | cut -f1 > mypackages.txt
 * 1) generate installed package list

Restore all packages from a previously created package list:

xargs -0 apt install -y < <(tr \\n \\0 < mypackages.txt)
 * 1) install packages

When using the commands from scripts it might be more convenient to use "$1" instead of mypackages.txt so that you can pass the file name as a command line argument.