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 (cmake 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 the repository
To install something in Termux you can run:

pkg install packagename

Example:

pkg install nano

Getting a list of all packages
pkg list-all

Searching for a package
pkg search calculator

Showing more information about a package
pkg show nano

Installing .deb files
Manually downloaded .deb files (those from official Debian or Ubuntu repos won't work!) can be installed using:

or directly using :

apt and pkg
By default Termux doesn't have a cron daemon running. Therefore users generally need to run `apt update` themselves. This has caused some confusion. As a result of this, a wrapper script for apt, pkg was implemented. It will call  automatically before trying to install something.

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 from the command line and Github and/or another host source for your repo.

its-pointless (live_the_dream)
This community member hosts a repository for Termux using GitHub Pages.

This repository includes,   (R language),  ,  ,  ,   and lots of games! To add this repository, execute:

curl -L https://its-pointless.github.io/setup-pointless-repo.sh | 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

Auxilus
This repository hosted by Auxilus contains some handy tools ( more tools are yet to be added )

You can add this repository by executing following commands 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 pkg install apt-transport-https echo "deb [trusted=yes] https://Auxilus.github.io/files termux extras" >> $PREFIX/etc/apt/sources.list pkg update

cocodevienne
This community member host some pretty cool self written apps for python. This includes

Add this repo using pkg install apt-transport-https echo "deb [trusted=yes] http://cocodevienne.gitlab.io/aptpackages/termuxpackages termux extras" >> $PREFIX/etc/apt/sources.list pkg update

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: apt 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.

Compiling packages
Packages for Termux are cross-compiled using build scripts (build.sh). These can be found here. To build a package, follow the instructions described in the README.md file from this repository.

All packages available in the official package repository are built under a docker container.

Compiling programs from Source
A lot of programs can be compiled from source.

You download source, get autotools and other dependencies. For a lot of programs you simply have to run: termux-fix-shebang configure ./configure make make install For other programs you need to follow instructions on the corresponding website.

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.