Skip to content
This repository has been archived by the owner on Jan 14, 2022. It is now read-only.

Frequently Asked Questions

jackpal edited this page Dec 19, 2014 · 48 revisions

Is "Terminal Emulator for Android" the same app as "Android Terminal Emulator"?

Yes. The name was changed due to Google Play branding guidelines. Unfortunately Google Play does not allow applications that start with the word "Android".

What is a terminal emulator?

A terminal emulator is a program that makes your Android phone act like an old fashioned computer terminal. It is useful for accessing the Linux command line shell that is built into every Android phone. This lets you run various Linux command line utilities.

If you don't know what all that means, and why it's cool, then this probably isn't the program for you. (Sorry!)

Help, I'm lost. How do I use the Android shell?

I've written a brief, incomplete, guide to using the built-in Android shell: Android Shell Command Reference

What sort of games does this emulator play?

Sorry, this is a terminal emulator, not a game emulator. It has nothing to do with games.

Does Terminal Emulator for Android allow me to "Root" or "Hack" my phone?

Sorry, no. Terminal Emulator for Android does not help you root or hack your phone.

How can I root or hack my phone?

I don't know how to do that. I use "developer" edition Android phones that don't need to be rooted, and I don't have any interest in hacking phones. Maybe ask on an enthusiast web site like http://forum.xda-developers.com/

Is Terminal Emulator for Android useful on an ordinary phone, that hasn't been rooted?

Yes! You can access the entire /sdcard file system, and you can install and run Linux command-line applications in the parts of the /data file system that are accessible to the Terminal Emulator for Android process.

You can also run command-line programs that access the Internet.

Why do I get "permission denied" errors when I try to run commands in the terminal?

This message is being printed out by the Android shell. It means one of two things:

  1. It might simply mean that you have misspelled the command name, or are trying to use a command that is not installed on you device. The Android shell will print "permission denied" when it just can't find the command, instead of a more accurate error message like "command not found".

  2. It could mean that the command exists, but you don't have permission to run it. By default Terminal Emulator for Android runs using the permissions of the Terminal Emulator for Android application. You may need to become "root" in order to gain permissions to run some commands. You can use the "su" command to do this. Of course, most consumer Android devices don't have root access enabled by default, so you may not be able to use the "su" command on your device.

Why does Terminal Emulator for Android request Internet and Photos/Media/Files permissions?

By itself, Terminal Emulator for Android doesn't access the Internet or Photos/Media/Files. However, many users of Terminal Emulator for Android want to run command line programs that do these things.

The way Linux (and therefore Android) works, a child process inherits the permissions of the parent. Terminal Emulator for Android requests the Internet and Photos/Media/Files write permissions so that the command-line programs that it runs can have access to the Internet and Photos/Media/Files stored on the device and any attached SD Cards.

If giving these permissions to the terminal emulator makes you uncomfortable, you could download the source code to Terminal Emulator for Android and compile your own version. (Edit the AndroidManifest.xml file to remove the INTERNET and WRITE_EXTERNAL_STORAGE permissions.)

On Android 5.0 and above, why does Android Terminal Emulator request

Why don't the Arrow Keys / DPAD / Trackball work ?

They do work, sort of. They send the proper escape sequences for VT-100 terminal arrow keys. It is up to the "shell" to interpret these escape sequences.

Pre-Gingerbread (pre 2.3) versions of the default Android shell do not handle these escape sequences. Gingerbread (Android 2.3) and later versions of Android work correctly. But that doesn't help people with older versions of Android.

If you have a Froyo (2.2) or earlier version of Android, you can fix this problem by installing an alternate shell, such as the one in Busybox. The Busybox "ash" shell recognizes the arrow escape sequences sent by the terminal emulator.

Even on newer versions of Android people sometimes run into this problem when they switch between shells. (as when using the "su" command, which starts a new shell process for the root account.) You may need to take extra steps, such as manually setting the "TERM" environment variable in your new shell environment.

Why doesn't the Back key work?

It sends the "ESC" character by default. Use the Preferences panel to change this behavior:

Menu Key -> "More"-> "Preferences" -> Back button behavior

Swype soft keyboard has problems typing a lowercase 'i'. Is there a work-around?

Several people have reported this bug. Unfortunately, I can't reproduce it using Swype 3.25 Beta on Android 2.3.6. Maybe it's fixed in the latest version of Swype. Please try installing Swype 3.25 or later and see if that fixes the problem.

SlideIt soft keyboard always types upper-case letters. Is there a work-around?

I have reproduced this with SlideIt version 4.0.1 on Android 2.3.6. There is a work-around, which is to tap on the "ABC" button on the upper-right-hand-corner of the SlideIt soft keyboard. This switches SlideIt into letter-at-a-time mode.

Could you make a full programmer soft keyboard with ctrl, tab, esc?

Many people report good results using the free Hacker's Keyboard IME. Also available from Hacker's Keyboard Download on github

Why don't you include a telnet or ssh client?

That's a good question! I guess I really ought to. Maybe one of these days I'll get around to it. In the meantime, see Installing BusyBox and ssh without Rooting your Device

Could you make tab completion work?

Similar to the "Arrow Keys" question above, tab completion is the job of the shell, not the terminal emulator. The built-in Android shell prior to the Ice Cream Sandwich release does not provide tab completion. You can turn on tab completion by installing an alternate shell, such as the one that comes with Busybox.

What is Busybox?

Busybox is a collection of Linux utility programs that is designed to be run on small Linux devices, such as your Android phone.

Where can I get Busybox for my Android Phone?

Do a web search for "Android Busybox" and read through the results.

Do I need root access to install and use Busybox?

No! If you have Android 2.3 or newer, see Installing BusyBox and ssh without Rooting your Device

I'm building my own Android ROM, can I include Terminal Emulator for Android in my ROM?

Sure, go for it. Tips for Including Terminal Emulator for Android in a custom ROM

How can I get the menu key to work with Terminal Emulator for Android on my Nook?

The Nook does not have a physical menu key. If you want Terminal Emulator for Android to work with a Nook, you will have to install a version of Android that supports soft menu keys. Android 3.0 (Honeycomb) provides support for soft menu keys.

How can I contribute a localization?

See the instructions here: Translating to Other Languages

Why does Terminal Emulator for Android ask for certain permissions?

Please read the Terminal Emulator for Android Privacy Policy.

I am using Android version 4.3 or newer and I can't get 'su' or 'ping' to work. Why?

In order to better protect ordinary users from malware, the Android OS enhanced its security model in the 4.3 and 4.4 releases.

One of the security enhancements made in Android 4.3 was to remove the ability to run setuid/setgid programs. Setuid and setgid are Linux features that enable programs to run with elevated permissions. The ping command is an example of a setuid program. Ping needs the elevated permissions in order to send and receive the special network packets used in the ping network protocol. When the ping command is run by Terminal Emulator for Android under Android 4.3 or later, the setuid/setgid feature is disabled. The ping command fails because ordinary Android applications do not have permission to send or receive the network packets used in the ping network protocol.

For similar reasons, some techniques for getting 'su' root access no longer work correctly on Android 4.3 and 4.4.

I don't follow the rooting scene, so I don't have any advice for how to work around these new security enhancements in Android 4.3 and 4.4. I guess it might be possible to create a custom ROM with a non-standard security policy, that for example allowed setuid/setgid to work again. But I don't know if anyone's doing that. If you're interested I guess you need to read up on the Android ROM hacking scene. (Which I also don't follow, so I can't suggest which ROMs are good or not. A few years ago xda-forum and CyanogenMOD were popular, but I don't know if that's still the case today. Good luck!)

How do I fix "Unknown error code during application install: -505"?

This error means that there is a custom permission conflict between "Terminal Emulator for Android" and some other application that is installed on your device. Terminal Emulator for Android declares three custom permissions, and starting with Android 5.0 Lollipop, only one application at a time can be installed for any given custom permission.

The three custom permissions are:

jackpal.androidterm.permission.RUN_SCRIPT
jackpal.androidterm.permission.APPEND_TO_PATH
jackpal.androidterm.permission.PREPEND_TO_PATH

One relatively straightforward way to figure out which applications conflict with Terminal Emulator for Android is to:

  1. Uninstall all the apps you suspect might be using these permissions.

  2. Install Terminal Emulator for Android.

  3. Try to reinstall the suspected apps.

  4. The conflicting app should fail to reinstall.

Hey, my bash is vulnerable to the Shellshock bug. How do I fix that?

Shellshock is a security bug in some versions of the bash shell. You can test whether your version of the bash shell is vulnerable by running this line in the terminal

env x='() { :;}; echo vulnerable' bash -c "echo this is a test"

If you see output like this then your version of bash is vulnerable:

vulnerable
this is a test

Stock Android does not include the bash shell, so most Android devices do not have this bug. Some custom ROMs like CyanogenMOD 10 and 11 are reported to come with vulnerable versions of bash.

In addition, you could have manually installed your own version of bash, by for example installing a Debian chroot.

If you discover that your Android device has a vulnerable version of bash, you will need to figure out where the vulnerable version of bash comes from (either the ROM or something you installed) and then contact the vendor and ask them for a fix.

Unfortunately there's nothing Terminal Emulator for Android can do to help (or hinder) this. It just runs whatever version of bash you have installed on your device.