Tip
The X resources mentioned on this page are included in both the template .Xresouces
file and the sample .Xresources
file.
Note
You can also use XTerm's command-line options as an alternative to the .Xresources file when needed.
XTerm window properties
You can configure the following aspects of XTerm windows:
- Window border theme
- Inner border width
- Default window size
Window border theme
The border theme of XTerm windows depends on the window manager or more broadly the desktop environment used. So to customize the border of XTerm windows, you need to research the available themes for your window manager and how to install a theme of your choice. For example: Openbox Theme Collections or xfce-look.org.
Configuring the window internal border width
For XTerm, you can configure the thickness of the window internal border, which is the width of window between the window border (set by the window manager) and the outermost (leftmost and rightmost) columns and (top and bottom) lines of text within the XTerm window. You can set the XTerm window internal border thickness in pixels as an X resource:
xterm*internalBorder: 20
- The implicit default for the
xterm*internalBorder
Xresource is2
pixels.
You can also color the window internal border:
xterm*colorInnerBorder: true
xterm*borderColor: green
- The implicit default for the
xterm*colorInnerBorder
Xresource isfalse
, which means the color of the window internal border is the window background color. - The
xterm*borderColor:
Xresource requires thecolorInnerBorder
Xresource to be explicitly set totrue
.
Note
On some window managers, the window internal border might appear thicker in pixels when set to the default (2
pixels) or minimal (1
pixel) width values. XTerm sets window-manager hints such as to tell the window manager to do resizing in units that correspond to the font size or that the minimal window size is equal to the inner border (2
when the border is set to 1
), but the hints and negotiation might not be correctly implemented in some window managers.
Configuring the default window size
You can set the default window size as an X resource that is used when you open a new XTerm window:
- Maximized windows
- Fullscreen windows
- Custom-size windows
- Custom-size windows with an offset window position
Configuring the maximized window size
You can configure XTerm to open maximized windows by default by setting the maximized:
Xresource to true
. The implicit default is false
.
Configuring the fullscreen window size
You can use the fullscreen:
Xresource with one of the following values to configure whether the window manager opens fullscreen XTerm windows by default:
false
or0
(implicit default)true
or1
always
or2
never
or3
Configuring a custom default window size
The Xresource that configures a custom default size for XTerm windows uses numbers of text columns and text lines as values:
xterm*geometry: <number_of_text_columns_you_want_in_xterm_windows>x<number_of_text_lines_you_want_in_xterm_windows>
The screen resolution, display size, and UI elements of the window manager or desktop environment such as menu or system bars affect the desired size of XTerm windows, which is something worth remembering when using two or more monitors.
So the best way to set the desired values for the xterm*geometry
X resource is by testing it manually.
Here are some examples for 15-inch laptops, depending on the display size and UI elements in the used window manager:
xterm*geometry: 106x54
xterm*geometry: 96x59
xterm*geometry: 94x48
Because the default XTerm window size is specified in the .Xresources
file in the units of columns and lines, the default XTerm window size is tied to the font size. In other words, if you change the xterm*faceSize
font size in the .Xresources
file, then the next time you open a new XTerm window, it will appear out of its intended proportions on the screen. So if you change the xterm*faceSize
font size in the .Xresources
file, you must also update the xterm*geometry
Xresource, which sets the XTerm window geometry default, if you have set any, in your .Xresources
file. For example, if you wish to increase XTerm's font size from 14
to 16
, you must update both lines as follows:
xterm*faceSize: 14
xterm*geometry: 96x59
xterm*faceSize: 16
xterm*geometry: 90x50
To conveniently determine your desired terminal window size for XTerm startup, you can drag and resize an XTerm window to the desired size and then run the resize
script, which is included with XTerm.
The resize
script prints your adjusted XTerm window size to standard output so that you can then copy and paste these values into the xterm*geometry
line in the .Xresources
file. Here is an example of this script's output:
$ resize
COLUMNS=110;
LINES=48;
Adding window position offsets
Where an application window such as an XTerm window appears on the screen might depend on the window manager or desktop environment, its features, settings, and UI elements such as menu or system bars. You can have XTerm windows open at an offset position as follows, measured in pixels from the top left corner of the display area set for application windows:
xterm*geometry: <number_of_text_columns_you_want_in_xterm_windows>x<number_of_text_lines_you_want_in_xterm_windows>+<number_of_pixels_to_move_window_right>+<number_of_pixels_to_move_window_down>
To have an idea of the pixel ranges involved in effectively offseting new XTerm windows, you can print the screen resolution to standard output by running the xrandr
command:
$ xrandr | grep \*
If you are using two or more monitors, different monitor resolution will cause different window position offsets.