Tip
You can read this website in a terminal by installing and running Lynx.
Configuring XTerm
Almost all of XTerm's configuration is described in terms of X resources (see archlinux.org and stuff.mit.edu). For desktop users, X resources are typically stored in the ~/.Xresources
dotfile. (For additional details, see the section ~/.Xresources for advanced use cases further below.)
The X resources that you can configure for XTerm are listed in the XTerm manpage, which is available as $ man xterm
or online.
To configure XTerm on a system, simply download or create and edit your ~/.Xresources
dotfile, and then run the xrdb
command to load the X resources from your ~/.Xresources
dotfile. See the next sections for step-by-step instructions.
Checking for the ~/.Xresources dotfile
Before doing anything regarding the ~/.Xresources
dotfile, first check if you already have it in the system's user home directory. Because ~/.Xdefaults
and ~/.Xdefaults-*
are other dotfiles where X resources might be stored, you can check for their presence too. Read the output of the command to find out:
$ ls -a ~/.Xresources ~/.Xdefaults ~/.Xdefaults-*
Tip
The easiest way to start with a ~/.Xresources
dotfile is to download and use the sample file (see instructions inside that file). Alternatively, you can run $ touch ~/.Xresources
to create a blank one where you can add XTerm configuration lines.
Checking the loaded X resources
Run $ xrdb -query
to view the loaded X resources.
Tip
This command might be useful after editing the ~/.Xresources
dotfile.
Loading the X resources from the ~/.Xresources dotfile
Run $ xrdb -merge ~/.Xresources
.
Updating the ~/.Xresources dotfile
1. Edit your ~/.Xresources
dotfile, adding or removing XTerm parameters or changing their values.
2. Run $ xrdb -merge ~/.Xresources
to load the updated X resources. (If you get any error messages in the output, edit the ~/.Xresources
file to resolve the errors.)
3. Open a new XTerm window by running $ xterm &
to visually verify the changes in the window.
~/.Xresources for advanced use cases
Referencing another file in ~/.Xresources
You can reference another file in the ~/.Xresources
dotfile with an absolute path, for example /home/<user>/...
, not using the tilde ~
. This means you can load XTerm's X resources from another file by adding the following statement on a line in ~/.Xresources
:
#include "/<absolute_path_to_file>/<file_with_x_resources_for_xterm>"
Differences between .Xresources
and .Xdefaults
.Xresources
are loaded into the X server, so are linked to a particular display environment.
"For most desktop environments, ~/.Xresources
should be loaded at login. Note that if you make changes, you will need to run xrdb
to pick them up. In my case, typically I care more about the server than the client for things like font size: for example, when using my laptop the resources are configured to suit a 14" screen at a particular resolution, and those same settings are used when I run xvile
either locally, or remotely on my workstation over ssh
. When sitting at my workstation which has a somewhat larger screen, I want different settings configured in the X server. By using .Xresources
rather than .Xdefaults
the same invocation of xvile
behaves appropriately depending on where it is being displayed, rather than where was invoked from." Source ".Xresources
works using ssh -x
. I thought that my window manager would automatically load .Xresources
, but it doesn't do so. Modifying my .xinitrc
fixes the problem." Source
.Xdefaults
are set based on the client.
.Xdefaults-host and XENVIRONMENT
"On POSIX-based systems, the user's environment resource file name is specified by the value of the XENVIRONMENT
Environment Variable. If this environment variable does not exist, the user's home directory is searched for a file named .Xdefaults-<host>
, where <host>
is the host name of the machine on which the application is running." Source
XAPPLRESDIR
Another in-depth alternative is to set XAPPLRESDIR
, which lets one set up a directory where X will search for an .Xresources
dotfile:
application-specific files
Directories named by the environment variable XUSERFILESEARCH‐
PATH or the environment variable XAPPLRESDIR (which names a
single directory and should end with a '/' on POSIX systems),
plus directories in a standard place (usually under
/usr/share/X11/, but this can be overridden with the XFILE‐
SEARCHPATH environment variable) are searched for for applica‐
tion-specific resources. For example, application default
resources are usually kept in /usr/share/X11/app-defaults/.
See the X Toolkit Intrinsics - C Language Interface manual for
details.
X Toolkit Intrinsics - C Language Interface discusses this as well.
Additional resources
Run $ xrdb -help
or see the xrdb manpage for more xrdb
options.
Warning
Running some of the xrdb
options interferes with dynamic loading of X resources by applications.
Warning
If you decide to use $ xrdb -remove
, be aware that it clears (!) all previously loaded X resources, including the X resources that were loaded at login.