Development Environments

Termux is often used for software development, information science education and experimentation. Here are some articles and links with information on how to make it possible with one of the following programming environments.

= APKs =

APKs (Android Package Kits) can be built in Termux on device with https://BuildAPKs.github.io/buildAPKs/

pkg install curl

curl -OL https://raw.githubusercontent.com/BuildAPKs/buildAPKs/master/setup.buildAPKs.bash

bash setup.buildAPKs.bash



= C = Package: clang

Description: C language frontend for LLVM

Homepage: http://clang.llvm.org/

Related Issues: https://github.com/termux/termux-packages/issues?q=clang

= D = Package: ldc

Description: D programming language compiler, built with LLVM

Homepage: https://dlang.org/

Instructions: https://wiki.dlang.org/Build_D_for_Android

= Go = Package: golang

Description: D programming language compiler, built with LLVM

Homepage: https://golang.org/

Instructions: https://gobyexample.com/hello-world

= Haskell = Related Issues: https://github.com/termux/termux-packages/issues?q=haskell

= Java = Related Issues: https://github.com/termux/termux-packages/issues?q=java

= JavaScript = See packages: quickjs, duktape, nodejs

ECJ
Package: ecj

Description: Eclipse Compiler for Java

Homepage: http://www.eclipse.org/jdt/core/

Related Issues: https://github.com/termux/termux-packages/issues?q=ecj

OpenJDK
There is a disabled package  in the termux-packages' repository.

This package is built from the mobile/dev branch of openjdk-9. OpenJDK is not available in the official repositories because it is not stable at all. It uses more CPU than any other process and may hang up the Android GUI.

Extended run of this java process can result in a cold reboot of the device. This makes the package unfit for official repository.

You can build it yourself by following instructions on from the packages' repo.

Related Issues: https://github.com/termux/termux-packages/issues?q=openjdk

= Lisp =

https://github.com/termux/termux-packages/issues?q=lisp

= OCaml =
 * Compiling and setting up OCaml (a copy of the article http://ygrek.org.ua/p/ocaml-termux.html)

https://ocaml.org/learn/description.html

Related Issues: https://github.com/termux/termux-packages/issues?q=ocaml

= Octave = Octave is available from a community repository. Setup up its-pointless' repository.

https://github.com/termux/termux-packages/issues?q=octave

= PHP = Related Issues: https://github.com/termux/termux-packages/issues?q=php = Picolisp =
 * The original article: https://picolisp.com/wiki/?TermuxPentiPicoLisp

Related Issues: https://github.com/termux/termux-packages/issues?q=picolisp

= Python =

Related Issues: https://github.com/termux/termux-packages/issues?q=python

SciPy

 * Installing Scipy The Easy Way

Jupyter
https://github.com/ravish0007/AndroJupy
 * Installing Jupyter Notebook
 * Additional kernels

Related Issues: https://github.com/termux/termux-packages/issues?q=scipy

= Ruby =

Related Issues: https://github.com/termux/termux-packages/issues?q=ruby

= Rust = Rust and cargo are available from the main repository. Install the latest stable version of rustc and cargo by running.

Test out the newly installed Rust by installing ripgrep (super-fast, silversearcher-ag like source search tool written in Rust). cargo install ripgrep

Related Issues: https://github.com/termux/termux-packages/issues?q=rust

= See Also =
 * Editors
 * IDEs