Skip to content

List of common environment variables in linux

Notifications You must be signed in to change notification settings

mandober/enwars

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

12 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Index of Environment Variables

List of environment variables (aka env vars, envars, enwars) on Linux.

Environment Variables

About envars

Environment variables (aka env vars, envars, enwars) are just shell variables that have been exported; that is, they are palin bash variables with the -x attribute set. This is usually done through the export builtin (export PATH), which may optinally be followed by the variable's definition (export PATH=:.::..:./..:), or by explicitly giving the attribute -x, just like any other attribute, when declaring a variable (declare -x NAME). The least used method is issuing set -a (or, more verbosely, set -o allexport) which then automatically marks new or modified variables for export.

A parent shell always spawns a child process, a subshell, to execute external commands. It tends to execute internal commands in the same environment, although the situation may sometimes require that even builtins and functions be executed in a subshell (necessarily so in pipelines). The child shell inherits the (execution) environment from the parent which includes almost everything. This is especially evident when you consider how the fork syscall makes an identical copy of the parent process, which then goes on to become its own sovereign process (for a few ns, then it's killed, abruptly). One would think that making a duplicate of the (bash parent shell) process would also include all defined shell variables - but it doesn't. Only variables explicitly marked for export - aka envars - are made available in the subshell. Plain ol' shell variables are not (maybe envp arg of execve et al. syscalls' got something to do with it).

This has implications in choosing the approapriate rc file in which to place your env vars. The ~/.profile seems a decent place as it is only loaded on (any) shell startup, while ~/.bashrc is read: "when an interactive shell, that is not a login shell, starts", which is every time you spawn a new bash tab. Not that it makes too much difference (probably), but the envars should be loaded only once, preferrably at the beginning of the "root" bash session, letting the other bash instances to inherit 'em from there. This suggests using .profile for environmental configuration. Bash functions are (famously) exportable as well, and bash aliases may as well stay in .bashrc (functions are used in scripts, but aliases rarely, so their availability to scripts must be made explicit - forgot how, there's a 'shopt' probably).

There's also a way to make a shell variable available to the child process without exporting it - via temporary environemnt augmentation; i.e. by placing an assignment statement before the command, e.g. IFS=$'\x3a' read -a. To relax this "only as prefix" rule and allow also suffixes, use set -k, or, more verbosely, set -o keyword, then "all assignment arguments are placed in the environment for a command, not just those that precede the command name". What's more, latter assignments may refer to former (e.g. x=1 : z=$x).

Values of envars

Values of envars are basically strings even when they look like numbers. When reading envars in C, for example, all values are interpreted as strings even if the given envar has the integer attribute (-i) set.

  • Scalar values
  • Compound values
    • csv: colon-separated values
    • csp: colon-separated paths
    • lsch: juxtaposed list of characters

Legend

  • crucial: its presence is crucial
  • very-common: always defined
  • user-changeable: user can access it and change it freely
  • special: special envar - once set to null it looses its special properties

Index

BROWSER

Set path to default browser. If only name is set, uses PATH to search for it.

CDPATH

A colon-separated list of dirs used like PATH but for dirs. Consulted by cd. User-settable env var.

If the target directory of the cd command is specified as a relative path name, the cd first searches for the target directory in cwd. If the target is not found, the path names that are listed in the CDPATH variable are searched consecutively until the target directory is found and the directory change is completed. If the target directory is not found, the current working directory is left unmodified. For example, if CDPATH is set to /home/jean, and there are home/jean/{bin,doc}. If cwd is /home/jean/bin typing cd doc changes cwd to /home/jean/doc.

  • origin: bash
  • value: colon-separated list of dirs
  • read-by: cd
  • access: user-settable
  • purpose: navigation

CHILD_MAX

Set the number of exited child status values for the shell to remember. Bash will not allow this value to be decreased below a POSIX-mandated minimum, and there is a maximum value (currently 8192) that this may not exceed. The minimum value is system-dependent.

Shell: bash

COLUMNS

Used by the select command to determine the terminal width when printing selection lists. Automatically set if the checkwinsize option is enabled (see The Shopt Builtin), or in an interactive shell upon receipt of a SIGWINCH.

COMP_CWORD

An index into ${COMP_WORDS} of the word containing the current cursor position. This variable is available only in shell functions invoked by the programmable completion facilities.

Shell: bash, readline, completion

COMP_LINE

The current command line. This variable is available only in shell functions and external commands invoked by the programmable completion facilities.

Shell: bash, readline

COMP_POINT

The index of the current cursor position relative to the beginning of the current command. If the current cursor position is at the end of the current command, the value of this variable is equal to ${#COMP_LINE}. This variable is available only in shell functions and external commands invoked by the programmable completion facilities.

Shell: bash, readline

COMP_TYPE

Set to an integer value corresponding to the type of completion attempted that caused a completion function to be called: TAB, for normal completion, '?', for listing completions after successive tabs, '!', for listing alternatives on partial word completion, '@', to list completions if the word is not unmodified, or '%', for menu completion. This variable is available only in shell functions and external commands invoked by the programmable completion facilities.

Shell: bash, readline

COMP_KEY

The key (or final key of a key sequence) used to invoke the current completion function.

Shell: bash, readline

COMP_WORDBREAKS

The set of characters that the Readline library treats as word separators when performing word completion. If COMP_WORDBREAKS is unset, it loses its special properties, even if it is subsequently reset.

Shell: bash, readline

COMP_WORDS

An array variable consisting of the individual words in the current command line. The line is split into words as Readline would split it, using COMP_WORDBREAKS as described above. This variable is available only in shell functions invoked by the programmable completion facilities.

Shell: bash, readline

COMPREPLY

An array variable from which Bash reads the possible completions generated by a shell function invoked by the programmable completion facility. Each array element contains one possible completion.

Shell: bash, readline

COPROC

An array variable created to hold the file descriptors for output from and input to an unnamed coprocess.

DIRSTACK

An array variable containing the current contents of the directory stack. Directories appear in the stack in the order they are displayed by the dirs builtin. Assigning to members of this array variable may be used to modify directories already in the stack, but the pushd and popd builtins must be used to add and remove directories. Assignment to this variable will not change the current directory. If DIRSTACK is unset, it loses its special properties, even if it is subsequently reset.

DISPLAY

Set X display name. export DISPLAY=:0.1

DOMAIN

domain name

EDITOR

Set name of default (line) text editor.

EMACS

If Bash finds this variable in the environment when the shell starts with value 't', it assumes that the shell is running in an Emacs shell buffer and disables line editing.

ENV

Similar to BASH_ENV; used when the shell is invoked in POSIX Mode.

filename, sh, bash, sh hook

EUID

The numeric effective user id of the current user. This variable is readonly.

EXECIGNORE

A colon-separated list of shell patterns defining the list of filenames to be ignored by command search using PATH.

Files whose full pathnames match one of these patterns are not considered executable files for the purposes of completion and command execution via PATH lookup. This does not affect the behavior of the [, test, and [[ commands. Full pathnames in the command hash table are not subject to EXECIGNORE. Use this variable to ignore shared library files that have the executable bit set, but are not executable files. The pattern matching honors the setting of the extglob shell option.

FCEDIT

The editor used as a default by the -e option to the fc builtin command.

FIGNORE

A colon-separated list of suffixes to ignore when performing filename completion. A filename whose suffix matches one of the entries in FIGNORE is excluded from the list of matched filenames. A sample value is '.o:~'

FUNCNAME

An array variable containing the names of all shell functions currently in the execution call stack. The element with index 0 is the name of any currently-executing shell function. The bottom-most element (the one with the highest index) is "main". This variable exists only when a shell function is executing. Assignments to FUNCNAME have no effect. If FUNCNAME is unset, it loses its special properties, even if it is subsequently reset.

This variable can be used with BASH_LINENO and BASH_SOURCE. Each element of FUNCNAME has corresponding elements in BASH_LINENO and BASH_SOURCE to describe the call stack. For instance, ${FUNCNAME[$i]} was called from the file ${BASH_SOURCE[$i+1]} at line number ${BASH_LINENO[$i]}. The caller builtin displays the current call stack using this information.

FUNCNEST

If set to a numeric value greater than 0, defines a maximum function nesting level. Function invocations that exceed this nesting level will cause the current command to abort.

GLOBIGNORE

A colon-separated list of patterns defining the set of filenames to be ignored by filename expansion. If a filename matched by a filename expansion pattern also matches one of the patterns in GLOBIGNORE, it is removed from the list of matches. The pattern matching honors the setting of the extglob shell option.

GROUPS

An array variable containing the list of groups of which the current user is a member. Assignments to GROUPS have no effect. If GROUPS is unset, it loses its special properties, even if it is subsequently reset.

histchars

Up to three characters which control history expansion, quick substitution, and tokenization (see History Interaction). The first character is the history expansion character, that is, the character which signifies the start of a history expansion, normally '!'. The second character is the character which signifies 'quick substitution' when seen as the first character on a line, normally '^'. The optional third character is the character which indicates that the remainder of the line is a comment when found as the first character of a word, usually '#'. The history comment character causes history substitution to be skipped for the remaining words on the line. It does not necessarily cause the shell parser to treat the rest of the line as a comment.

HOME

  • $HOMEholds the current user's home directory
  • auto set by login(1), to the value taken from passwd(4) file
  • dobles as default argument for cd
  • old systems have used LOGDIR instead
  • enwar_flavour: single directory name, as a string of course
  • enwar_popularity: all-time fave, possibly no.1, always in top 5
  • enwar_deference: revered by the lot
  • enwar_necessity: high possibility of strange behavior. If unavailable at login, the user gets a tmp slum home hard-linked public toilet.

HOSTALIASES

  • gives the name of a file containing aliases to be used with gethostbyname(3)
  • enwar_origin:

HISTCMD

  • the history number, or index in the history list, of the current command.
  • if unset, it loses its special properties, even if subsequently reset.
  • enwar_precious: has special properties but may easily loose 'em for good
  • enwar_precious:

HISTCONTROL

A colon-separated list of values controlling how commands are saved on the history list. If the list of values includes 'ignorespace', lines which begin with a space character are not saved in the history list. A value of 'ignoredups' causes lines which match the previous history entry to not be saved. A value of 'ignoreboth' is shorthand for 'ignorespace' and 'ignoredups'. A value of 'erasedups' causes all previous lines matching the current line to be removed from the history list before that line is saved. Any value not in the above list is ignored. If HISTCONTROL is unset, or does not include a valid value, all lines read by the shell parser are saved on the history list, subject to the value of HISTIGNORE. The second and subsequent lines of a multi-line compound command are not tested, and are added to the history regardless of the value of HISTCONTROL.

HISTFILE

The name of the file to which the command history is saved. The default value is ~/.bash_history.

HISTFILESIZE

The maximum number of lines contained in the history file. When this variable is assigned a value, the history file is truncated, if necessary, to contain no more than that number of lines by removing the oldest entries. The history file is also truncated to this size after writing it when a shell exits. If the value is 0, the history file is truncated to zero size. Non-numeric values and numeric values less than zero inhibit truncation. The shell sets the default value to the value of HISTSIZE after reading any startup files.

bash

HISTIGNORE

A colon-separated list of patterns used to decide which command lines should be saved on the history list. Each pattern is anchored at the beginning of the line and must match the complete line (no implicit '*' is appended). Each pattern is tested against the line after the checks specified by HISTCONTROL are applied. In addition to the normal shell pattern matching characters, '&' matches the previous history line. '&' may be escaped using a backslash; the backslash is removed before attempting a match. The second and subsequent lines of a multi-line compound command are not tested, and are added to the history regardless of the value of HISTIGNORE. The pattern matching honors the setting of the extglob shell option. HISTIGNORE subsumes the function of HISTCONTROL. A pattern of '&' is identical to ignoredups, and a pattern of '[ ]*' is identical to ignorespace. Combining these two patterns, separating them with a colon, provides the functionality of ignoreboth.

HISTSIZE

The maximum number of commands to remember on the history list. If the value is 0, commands are not saved in the history list. Numeric values less than zero result in every command being saved on the history list (there is no limit). The shell sets the default value to 500 after reading any startup files.

bash

HISTTIMEFORMAT

If this variable is set and not null, its value is used as a format string for strftime to print the time stamp associated with each history entry displayed by the history builtin. If this variable is set, time stamps are written to the history file so they may be preserved across shell sessions. This uses the history comment character to distinguish timestamps from other history lines.

bash

HOSTFILE

Contains the name of a file in the same format as /etc/hosts that should be read when the shell needs to complete a hostname. The list of possible hostname completions may be changed while the shell is running; the next time hostname completion is attempted after the value is changed, Bash adds the contents of the new file to the existing list. If HOSTFILE is set, but has no value, or does not name a readable file, Bash attempts to read /etc/hosts to obtain the list of possible hostname completions. When HOSTFILE is unset, the hostname list is cleared.

bash

HOSTNAME

The name of the current host.

HOSTTYPE

A string describing the machine Bash is running on.

bash

HTTP_PROXY

This variable defnes which proxy server should be used for an Internet connection.

IFS

List of characters that separate fields, when shell splits words as part of expansion.

bash

IGNOREEOF

Controls the action of the shell on receipt of an EOF character as the sole input. If set, the value denotes the number of consecutive EOF characters that can be read as the first character on an input line before the shell will exit. If the variable exists but does not have a numeric value (or has no value) then the default is 10. If the variable does not exist, then EOF signifies the end of input to the shell. This is only in effect for interactive shells.

bash

INPUTRC

The name of the Readline initialization file, overriding the default of ~/.inputrc.

readline

LANG

Used to determine the locale category for any category not specifically selected with a variable starting with LC_.

LC_ALL

This variable overrides the value of LANG and any other LC_ variable specifying a locale category.

LC_COLLATE

This variable determines the collation order used when sorting the results of filename expansion, and determines the behavior of range expressions, equivalence classes, and collating sequences within filename expansion and pattern matching.

LC_CTYPE

This variable determines the interpretation of characters and the behavior of character classes within filename expansion and pattern matching.

LC_MESSAGES

This variable determines the locale used to translate double-quoted strings preceded by a $.

LC_NUMERIC

This variable determines the locale category used for number formatting.

LC_TIME

determines the locale category used for data and time formatting.

LD_LIBRARY_PATH

On many Unix systems with a dynamic linker, contains a colon-separated list of directories that the dynamic linker should search for shared objects when building a process image after exec, before searching in any other, default, directories. LD_LIBRARY_PATH, LD_PRELOAD, and other LD_* variables influence the behavior of the dynamic loader/linker.

LINENO

The line number in the script or shell function currently executing.

LINES

Used by the select command to determine the column length for printing selection lists. Automatically set if the checkwinsize option is enabled, or in an interactive shell upon receipt of a SIGWINCH.

LOGNAME

The name of the logged-in user (used by some System-V derived programs). The default value of LOGNAME is automatically set by the login program to the user name that is specified in the passwd file. You should only need to refer to, not reset, this variable.

LPDEST

PRINTER or LPDEST may specify the desired printer to use. See lpr(1).

LS_COLORS

ls command's spec for colors

MACHTYPE

A string that fully describes the system type on which Bash is executing, in the standard GNU cpu-company-system format.

MAIL

If this parameter is set to a filename or directory name (and the MAILPATH variable is not set), Bash informs the user of the arrival of mail in the specified file or Maildir-format directory. Overridden by MAILPATH.
This variable can be used to monitor any file or directory:

  • if file is monitored, the shell will print alerts when file's content is changed
  • if directory is monitored, the shell will alert when new files are added or deleted from it To monitor several files/directories and specify custom alert messages, see MAILPATH.
    Example: MAIL=$HOME/.bashrc

filename, hook

MAILCHECK

Specifies how often (in seconds) the shell checks for mail (as specified in the MAILPATH or MAIL). The default is 60 seconds. When it is time to check for mail, the shell does so before displaying the primary prompt. If not set to an integer greater than 0, the shell disables mail checking.

integer

MAILPATH

A colon-separated list of filenames which the shell periodically checks for new mail.
Each list entry can specify the message that is printed when new mail arrives in the mail file by separating the filename from the message with a ?. When used in the text of the message, $_ expands to the name of the current mail file (but it must be inside single quotes, otherwise it will expand into shell variable, $_, which contains the last argument of the previous command).
This variable can be used to monitor any file or directory: see MAIL.
Example: MAILPATH=$HOME/.bashrc?'$_ modified!':$HOME/dots?'New file added in $_'

filename and paths, hook

MANPATH

Colon separated list of directories to search for manual pages.

MAPFILE

An array variable created to hold the text read by the mapfile builtin when no variable name is supplied.

NNTPSERVER

Specify a news server that some Usenet news readers require to access the news (nntp) server.

OLDPWD

The previous working directory as set by the cd builtin.

OPTARG

The value of the last option argument processed by the getopts builtin.

OPTIND

The index of the last option argument processed by the getopts builtin.

OPTERR

If set to the value 1, Bash displays error messages generated by the getopts builtin command.

OSTYPE

A string describing the operating system Bash is running on.

PAGER

Name of the program to be used for paging output. Default: pager

PATH

The search path; a colon-separated list of path names, each considered as a parent folder when searching for an executable known only by a filename; e.g. bash is a bare filename and needs to be resolved into a full path (usually /bin/bash), which is done by searching for bash in every directory in the PATH. If unset, a default search path of /usr/local/bin:/bin:/usr/bin is used.

Path resolution is basically a bounded for-loop that takes each entry in the PATH, concatenates the filename to it, then checks if it resolves to a file existing in the file system and having appropriate permissions. Path resolution only happens in case of bare names - if the name contains a slash anywhere, then it is either an absolute or relative path, so it is resolved directly.

Path resolution also happens with the source (aka .) builtin when bash searches for a file to source; e.g. . file will search the PATH for FILE.

Bash caches the resolved names in an internal dictionary exposed as the BASH_CMDS env var (associative array). Bash also has a builtin called hash that can also be used to manipulate this array. Next time bash needs to resolve a name, it will first consult the BASH_CMDS associative array, and if it finds an entry there (no, it won't blindly execute it), it will make sure the cached path checks out (but the resolution is cut down significantly since only a single folder needs to be checked) before it runs the file. After the BASH_CMDS has filled up, preserving it across bash sessions can significantly improve path resolution.

Entries, aka path prefixes, in PATH are colon-separated. An entry need not have a trailing slash as it is automatically added; even if it has a trailing slash, juxtaposing multiple directory separators (forward slashes) is not known to cause problems. A zero-length prefix indicates the cwd, and it may appear as two adjacent colons (PATH=/bin::/sbin), a leading colon (PATH=::/bin:/sbin), a trailing colon (PATH=/bin:/sbin::). Placing the actual name for the cwd (i.e. .) in the PATH acts the same as an empty (zero-length) prefix. You can easily loose yourself with dots and colons (PATH=./:.:..:..:.::..:../..). The order of entries matters since the earlier entries are searched first and the search stops once a name is resolved; the same name will resolve with an earlier prefix that is then said to shadow a latter one. Some say that putting the cwd in the PATH presents a security risk (but that is highly dubious and means you have already been penetrated).

PATH is system-dependent and its entries are initially set by the terminal, some are configured as part of the login process, some are explicitly set by the admin. Entries may also be inherited from a parent environment. The system-wide PATH is also affected by the scripts in /etc/profile.d.

Suitable files for persistant PATH and other environment variable settings that affect just a particular user are ~/.pam_environment and ~/.profile.

Users can change the PATH value. The user PATH shares most entries with the system PATH, after which user's custom entries are listed.

If the PATH env var is unset or annulled, the path resolution is implementation dependent; usually defaults to PATH=/usr/local/bin:/usr/local/sbin:/usr/bin:/usr/sbin:/bin:/sbin.

When bash cannot resolve a name, it will, as the last effort, call the command-not-found-handler function (if defined), passing it the command line. On Ubuntum the c-n-f package, installed by default, uses this hook to search for the typed name in the database of programs, suggesting its installation if possible. Unfortunately, despite being a bash function, the handler is called in a subshell.

tags: [ csv | crucial | very-common | user-changeable ]

PIPESTATUS

An array variable (see Arrays) containing a list of exit status values from the processes in the most-recently-executed foreground pipeline (which may contain only a single command).

POSIXLY_CORRECT

In a few cases, default behavior of the GNU utilities is incompatible with the POSIX standard. To suppress these incompatibilities, define this environment variable; unless you are checking for POSIX conformance, you probably don't need it.

For example: normally, options and operands can appear in any order, and programs act as if all the options appear before any operands, e.g. diff lao tzu -C 2 acts like diff -C 2 lao tzu, since 2 is an option-argument of -C. However, if POSIXLY_CORRECT is set, options must appear before operands, unless otherwise specified for a particular command.

Newer versions of POSIX are occasionally incompatible with older versions. For example, older versions of POSIX allowed the command diff -c -10 to have the same meaning as diff -C 10, but POSIX 1003.1-2001 diff no longer allows digit-string options like -10.

[bash] If this variable is in the environment when bash starts, the shell enters POSIX mode before reading the startup files, as if the bash --posix invocation option had been supplied. If it is set while the shell is running, bash enables POSIX mode, as if the command set -o posix had been executed.
<gnu> <bash> <user>

_POSIX2_VERSION

The GNU utilities normally conform to the version of POSIX that is standard for your system. To cause them to conform to a different version of POSIX, define the _POSIX2_VERSION environment variable to a value of the form YYYYMM specifying the year and month the standard was adopted. Two values are currently supported: 199209 stands for POSIX 1003.2-1992, and 200112 stands for POSIX 1003.1-2001. For example, if you are running older software that assumes an older version of POSIX and uses diff -c -10, you can work around the compatibility problems by setting _POSIX2_VERSION=199209 in your environment.

PREFIX

Holds a root directory for new program installation. Usually /usr/local. It will contain a third-level file hierarchy under it (bin, etc, include, lib, sbin, share, src). Many utilities will look up this variable upon installation to place their files there.

PPID

[bash] The process ID of the shell's parent process. This variable is read-only.

PRINTER

PRINTER or LPDEST may specify the desired printer to use. See lpr(1).

PROMPT_COMMAND

If set, the value is interpreted as a command to execute before the printing of each primary prompt ($PS1).

PROMPT_DIRTRIM

If set to a number greater than zero, the value is used as the number of trailing directory components to retain when expanding the \w and \W prompt string escapes (see Controlling the Prompt). Characters removed are replaced with an ellipsis.

PS0

The value of this parameter is expanded like PS1 and displayed by interactive shells after reading a command and before the command is executed.

PS1

The primary prompt string. The default value is \s-\v\$

PS2

The secondary prompt string. The default value is >

PS3

The value of this variable is used as the prompt for the select command. If this variable is not set, the select command prompts with '#? '

PS4

The value is the prompt printed before the command line is echoed when the -x option is set (see The Set Builtin). The first character of PS4 is replicated multiple times, as necessary, to indicate multiple levels of indirection. The default is '+ '.

PWD

This variable points to the current directory. Equivalent to the output of the command pwd when called without arguments. Changes to PWD are maintained by the cd command.

RANDOM

Each time this parameter is referenced, a random integer between 0 and 32767 is generated. Assigning a value to this variable seeds the random number generator.

READLINE_LINE

The contents of the Readline line buffer, for use with 'bind -x' (see Bash Builtins).

READLINE_POINT

The position of the insertion point in the Readline line buffer, for use with 'bind -x' (see Bash Builtins).

REPLY

The default variable for the read builtin.

SECONDS

This variable expands to the number of seconds since the shell was started. Assignment to this variable resets the count to the value assigned, and the expanded value becomes the value assigned plus the number of seconds since the assignment.

SHELL

The full pathname to the shell is kept in this environment variable. If it is not set when the shell starts, Bash assigns to it the full pathname of the current user's login shell.

SHELLOPTS

A colon-separated list of enabled shell options. Each word in the list is a valid argument for set -o builtin. The options appearing in SHELLOPTS are those reported as enabled by set -o. If this variable is in the environment when Bash starts up, each shell option in the list will be enabled before reading any startup files. This variable is readonly.

SHLVL

Incremented by one each time a new instance of Bash is started. This is intended to be a count of how deeply your Bash shells are nested.

SIMPLE_BACKUP_SUFFIX

Some GNU programs (at least cp, install, ln, mv) can make backups of files before writing new versions. The option --suffix=SUFFIX specifies the SUFFIX to append to each backup file. If this option is not specified, the value of the SIMPLE_BACKUP_SUFFIX environment variable is used; if unset, the default is ~.

TEMP

Directory to store temporary files. See also TMP.

TERM

Specifies the terminal model or family. Probably the most common value is 'xterm-256color'. This value says that the terminal is xterm compatible and supports 256 colors. You can check the associated entry with infocmp $TERM, which contains the string colors#0x100 (0x100 is 256). There are actually numerous other entries with the 'xterm' prefix, like 'xterm-direct'. Doing infocmp xterm-direct shows colors#0x1000000 and pairs#0x10000, which implies true color support (24-bit color, 2⁸×2⁸×2⁸ = 256³ = 2²⁴ = 16,777,216); pairs is the max numbers of color-pairs that can be displayed simultaneously (65,536).

Terminfo describes terminals by giving a set of capabilities which they have, by specifying how to perform screen operations, and by specifying padding requirements and initialization sequences. It is primarily used by screen-oriented programs.

Setting this to an incompatible value may screw up different aspects (usually colors, but posibly other things too) of screen-programs.

This env var is related to the terminfo database of terminal escape codes.

A utility that wants to emit special escape codes needs to lookup a proper sequence the current terminal supports. The terminfo maintains a database of terminal escape codes arranged by terminal names. So utilities usually read the TERM to get the terminal name, then search the terminfo database by that name.

TERM_PROGRAM

Type of program used as a terminal. Similar to TERM.

TERMCAP

The termcap (terminal capability) is an older standard, succeeded by 'terminfo', that associates concrete terminals with their characteristics. An entry in the termcap database lists terminal properties like number of supported colors, including all supported capabilities and their sequences. TERMCAP env var points to a custom termcap configuration.

TERMINFO

Names a directory where an alternate terminfo database is stored. Use the TERMINFO variable in either the /etc/profile or /etc/.login file. For more information, see the terminfo(4) man page. When the TERMINFO environment variable is set, the system first checks the TERMINFO path defined by the user. If the system does not find a definition for a terminal in the TERMINFO directory defined by the user, it searches the default directory, /usr/share/lib/terminfo, for a definition. If the system does not find a definition in either location, the terminal is identified as "dumb".

TERMINFO_DIRS

Directories searched for terminfo entries.

TMP

Directory to store temporary files. Same as TEMP.

TMPDIR

influences the path prefix of names created by tempnam(3) and other routines, and the temporary directory used by sort(1) and other programs.

TIMEFORMAT

The value of this parameter is used as a format string specifying how the timing information for pipelines prefixed with the time reserved word should be displayed. The % character introduces an escape sequence that is expanded to a time value or other information. The escape sequences and their meanings are as follows; the braces denote optional portions.

%% = A literal '%'.
%[p][l]R = The elapsed time in seconds.
%[p][l]U = The number of CPU seconds spent in user mode.
%[p][l]S = The number of CPU seconds spent in system mode.
%P = The CPU percentage, computed as (%U + %S) / %R. 

The optional p is a digit specifying the precision, the number of fractional digits after a decimal point. A value of 0 causes no decimal point or fraction to be output. At most three places after the decimal point may be specified; values of p greater than 3 are changed to 3. If p is not specified, the value 3 is used. The optional l specifies a longer format, including minutes, of the form MMmSS.FFs. The value of p determines whether or not the fraction is included.If this variable is not set, Bash acts as if it had the value $'\nreal\t%3lR\nuser\t%3lU\nsys\t%3lS'. If the value is null, no timing information is displayed. A trailing newline is added when the format string is displayed.

TMOUT

If set to a value greater than zero, TMOUT is treated as the default timeout for the read builtin. The select command terminates if input does not arrive after TMOUT seconds when input is coming from a terminal. In an interactive shell, the value is interpreted as the number of seconds to wait for a line of input after issuing the primary prompt. Bash terminates after waiting for that number of seconds if a complete line of input does not arrive.

TMPDIR

If set, Bash uses its value as the name of a directory in which Bash creates temporary files for the shell's use.

TZ

Sets the time zone. The time zone is used to display dates, for example, in the ls -l command. If TZ is not set in the user's environment, the system setting is used. Otherwise, Greenwich Mean Time is used. Commands that print times (and dates) use this variable to determine the time zone. If the TZ variable is left undefined, the operating system's current time zone setting is used. See timezone for details. On Windows, the MKS Toolkit makes use of the built-in timezone support, and you should not set the TZ environment variable.

TZDIR

TZ and TZDIR give timezone information used by tzset(3) and through that by functions like ctime(3), localtime(3), mktime(3), strftime(3). See also tzselect(8).

UID

Contains the numeric real user id of the current user. Commonly used in scripts, [ $UID != 0 ] && echo "not root", to check whether the current script has been run as root user or regular user. This variable is readonly.
readonly, bash, zsh

USER

The name of the logged-in user (used by some BSD-derived programs).

VISUAL

Set name of default (full-screen) text editor.

VERSION_CONTROL

Some GNU programs (at least cp, install, ln, mv) can make backups of files before writing new versions. The option --backup[=METHOD] controls the type of backup to make. When this option is used but METHOD is not specified, the valujeof VERSION_CONTROL env var is used; if unset, the default backup type is 'existing'.

XDG_DATA_HOME

defines the base directory relative to which user specific data files should be stored. If $XDG_DATA_HOME is either not set or empty, a default equal to $HOME/.local/share should be used.

XDG_CONFIG_HOME

defines the base directory relative to which user specific configuration files should be stored. If $XDG_CONFIG_HOME is either not set or empty, a default equal to $HOME/.config should be used.

XDG_DATA_DIRS

defines the preference-ordered set of base directories to search for data files in addition to the $XDG_DATA_HOME base directory. The directories in $XDG_DATA_DIRS should be seperated with a colon ':'. If $XDG_DATA_DIRS is either not set or empty, a value equal to /usr/local/share/:/usr/share/ should be used.

XDG_CONFIG_DIRS

defines the preference-ordered set of base directories to search for configuration files in addition to the $XDG_CONFIG_HOME base directory. The directories in $XDG_CONFIG_DIRS should be seperated with a colon ':'. If $XDG_CONFIG_DIRS is either not set or empty, a value equal to /etc/xdg should be used. The order of base directories denotes their importance; the first directory listed is the most important. When the same information is defined in multiple places the information defined relative to the more important base directory takes precedent. The base directory defined by $XDG_DATA_HOME is considered more important than any of the base directories defined by $XDG_DATA_DIRS. The base directory defined by $XDG_CONFIG_HOME is considered more important than any of the base directories defined by $XDG_CONFIG_DIRS.

XDG_CACHE_HOME

defines the base directory relative to which user specific non-essential data files should be stored. If $XDG_CACHE_HOME is either not set or empty, a default equal to $HOME/.cache should be used.

XDG_RUNTIME_DIR

defines the base directory relative to which user-specific non-essential runtime files and other file objects (such as sockets, named pipes, ...) should be stored. The directory MUST be owned by the user, and he MUST be the only one having read and write access to it. Its Unix access mode MUST be 0700. The lifetime of the directory MUST be bound to the user being logged in. It MUST be created when the user first logs in and if the user fully logs out the directory MUST be removed. If the user logs in more than once he should get pointed to the same directory, and it is mandatory that the directory continues to exist from his first login to his last logout on the system, and not removed in between. Files in the directory MUST not survive reboot or a full logout/login cycle. The directory MUST be on a local file system and not shared with any other system. The directory MUST by fully-featured by the standards of the operating system. More specifically, on Unix-like operating systems AF_UNIX sockets, symbolic links, hard links, proper permissions, file locking, sparse files, memory mapping, file change notifications, a reliable hard link count must be supported, and no restrictions on the file name character set should be imposed. Files in this directory MAY be subjected to periodic clean-up. To ensure that your files are not removed, they should have their access time timestamp modified at least once every 6 hours of monotonic time or the 'sticky' bit should be set on the file. If $XDG_RUNTIME_DIR is not set applications should fall back to a replacement directory with similar capabilities and print a warning message. Applications should use this directory for communication and synchronization purposes and should not place larger files in it, since it might reside in runtime memory and cannot necessarily be swapped out to disk.

XENVIRONMENT

location of your personal settings for X behavior

XFILESEARCHPATH

paths to search for graphical libraries


special attribute means that if varible is unset, it loses its special properties, even if it is subsequently reset.

About

List of common environment variables in linux

Topics

Resources

Stars

Watchers

Forks

Languages