ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/rxvt-unicode/doc/rxvt.1.pod
Revision: 1.155
Committed: Mon Dec 17 23:52:44 2007 UTC (16 years, 6 months ago) by ayin
Branch: MAIN
CVS Tags: rel-8_9
Changes since 1.154: +0 -7 lines
Log Message:
Nuke unused 'selectstyle' resource.

File Contents

# User Rev Content
1 root 1.1 =head1 NAME
2    
3     rxvt-unicode (ouR XVT, unicode) - (a VT102 emulator for the X window system)
4    
5     =head1 SYNOPSIS
6    
7 root 1.2 B<@@RXVT_NAME@@> [options] [-e command [ args ]]
8 root 1.1
9     =head1 DESCRIPTION
10    
11 root 1.3 B<rxvt-unicode>, version B<@@RXVT_VERSION@@>, is a colour vt102 terminal
12 root 1.1 emulator intended as an I<xterm>(1) replacement for users who do not
13     require features such as Tektronix 4014 emulation and toolkit-style
14     configurability. As a result, B<rxvt-unicode> uses much less swap space --
15     a significant advantage on a machine serving many X sessions.
16    
17 root 1.153 This document is also available on the World-Wide-Web at
18     L<http://pod.tst.eu/http://cvs.schmorp.de/rxvt-unicode/doc/rxvt.1.pod>.
19    
20 root 1.30 =head1 FREQUENTLY ASKED QUESTIONS
21    
22 root 1.53 See @@RXVT_NAME@@(7) (try C<man 7 @@RXVT_NAME@@>) for a list of
23     frequently asked questions and answer to them and some common
24     problems. That document is also accessible on the World-Wide-Web at
25 root 1.152 L<http://pod.tst.eu/http://cvs.schmorp.de/rxvt-unicode/doc/rxvt.7.pod>.
26 root 1.30
27 root 1.5 =head1 RXVT-UNICODE VS. RXVT
28    
29     Unlike the original rxvt, B<rxvt-unicode> stores all text in Unicode
30     internally. That means it can store and display most scripts in the
31     world. Being a terminal emulator, however, some things are very difficult,
32     especially cursive scripts such as arabic, vertically written scripts
33     like mongolian or scripts requiring extremely complex combining rules,
34 root 1.136 like tibetan or devanagari. Don't expect pretty output when using these
35 root 1.5 scripts. Most other scripts, latin, cyrillic, kanji, thai etc. should work
36 root 1.115 fine, though. A somewhat difficult case are right-to-left scripts, such
37 root 1.5 as hebrew: B<rxvt-unicode> adopts the view that bidirectional algorithms
38 root 1.150 belong in the application, not the terminal emulator (too many things --
39 root 1.30 such as cursor-movement while editing -- break otherwise), but that might
40 root 1.12 change.
41 root 1.5
42 root 1.12 If you are looking for a terminal that supports more exotic scripts, let
43 root 1.118 me recommend C<mlterm>, which is a very user friendly, lean and clean
44 root 1.12 terminal emulator. In fact, the reason rxvt-unicode was born was solely
45     because the author couldn't get C<mlterm> to use one font for latin1 and
46     another for japanese.
47    
48     Therefore another design rationale was the use of multiple fonts to
49     display characters: The idea of a single unicode font which many other
50 root 1.114 programs force onto its users never made sense to me: You should be able
51 root 1.12 to choose any font for any script freely.
52 root 1.5
53     Apart from that, rxvt-unicode is also much better internationalised than
54 root 1.114 its predecessor, supports things such as XFT and ISO 14755 that are handy
55 root 1.116 in i18n-environments, is faster, and has a lot bugs less than the original
56 root 1.5 rxvt. This all in addition to dozens of other small improvements.
57    
58     It is still faithfully following the original rxvt idea of being lean
59     and nice on resources: for example, you can still configure rxvt-unicode
60 root 1.114 without most of its features to get a lean binary. It also comes with
61 root 1.5 a client/daemon pair that lets you open any number of terminal windows
62     from within a single process, which makes startup time very fast and
63     drastically reduces memory usage. See @@RXVT_NAME@@d(1) (daemon) and
64     @@RXVT_NAME@@c(1) (client).
65    
66     It also makes technical information about escape sequences (which have
67 root 1.116 been extended) more accessible: see @@RXVT_NAME@@(7) for technical
68 root 1.30 reference documentation (escape sequences etc.).
69 root 1.2
70 root 1.1 =head1 OPTIONS
71    
72 root 1.2 The B<@@RXVT_NAME@@> options (mostly a subset of I<xterm>'s) are listed
73 root 1.1 below. In keeping with the smaller-is-better philosophy, options may be
74     eliminated or default values chosen at compile-time, so options and
75     defaults listed may not accurately reflect the version installed on
76 root 1.3 your system. `@@RXVT_NAME@@ -h' gives a list of major compile-time options on
77 root 1.1 the I<Options> line. Option descriptions may be prefixed with which
78     compile option each is dependent upon. e.g. `Compile I<XIM>:' requires
79 root 1.3 I<XIM> on the I<Options> line. Note: `@@RXVT_NAME@@ -help' gives a list of all
80 root 1.1 command-line options compiled into your version.
81    
82 root 1.2 Note that B<@@RXVT_NAME@@> permits the resource name to be used as a
83 root 1.1 long-option (--/++ option) so the potential command-line options are
84 root 1.3 far greater than those listed. For example: `@@RXVT_NAME@@ --loginShell --color1
85 root 1.1 Orange'.
86    
87     The following options are available:
88    
89     =over 4
90    
91     =item B<-help>, B<--help>
92    
93     Print out a message describing available options.
94    
95     =item B<-display> I<displayname>
96    
97     Attempt to open a window on the named X display (B<-d> still
98     respected). In the absence of this option, the display specified by the
99     B<DISPLAY> environment variable is used.
100    
101 root 1.106 =item B<-depth> I<bitdepth>
102    
103 root 1.109 Compile I<xft>: Attempt to find a visual with the given bit depth;
104 root 1.106 resource B<depth>.
105    
106 root 1.1 =item B<-geometry> I<geom>
107    
108     Window geometry (B<-g> still respected); resource B<geometry>.
109    
110     =item B<-rv>|B<+rv>
111    
112     Turn on/off simulated reverse video; resource B<reverseVideo>.
113    
114     =item B<-j>|B<+j>
115    
116 root 1.132 Turn on/off jump scrolling (allow multiple lines per refresh); resource B<jumpScroll>.
117    
118     =item B<-ss>|B<+ss>
119    
120     Turn on/off skip scrolling (allow multiple screens per refresh); resource B<skipScroll>.
121 root 1.1
122 sasha 1.140 =item B<-tr>|B<+tr>
123 root 1.1
124 ayin 1.148 Turn on/off illusion of a transparent window background; resource B<transparent>.
125 sasha 1.140
126 ayin 1.148 B<-ip> is still accepted as an obsolete alias but will be removed in
127     future versions.
128 root 1.1
129 ayin 1.143 I<Please address all transparency related issues to Sasha Vasko at
130 sasha 1.138 sasha@aftercode.net. Read the FAQ (man 7 @@RXVT_NAME@@)!>
131 root 1.110
132 root 1.1 =item B<-fade> I<number>
133    
134 root 1.68 Fade the text by the given percentage when focus is lost. Small values
135     fade a little only, 100 completely replaces all colours by the fade
136     colour; resource B<fading>.
137    
138     =item B<-fadecolor> I<colour>
139    
140     Fade to this colour when fading is used (see B<-fade>). The default colour
141 root 1.110 is opaque black. resource B<fadeColor>.
142 root 1.1
143     =item B<-tint> I<colour>
144    
145     Tint the transparent background pixmap with the given colour when
146 sasha 1.140 transparency is enabled with B<-tr>. This only works for
147 root 1.70 non-tiled backgrounds, currently. See also the B<-sh> option that can be
148 sasha 1.134 used to brighten or darken the image in addition to tinting it.
149 ayin 1.135 Please note that certain tint colours can be applied on the server-side,
150     thus yielding performance gain of two orders of magnitude. These colours are:
151 ayin 1.143 blue, red, green, cyan, magenta, yellow, and those close to them. Also
152 ayin 1.142 pure black and pure white colors essentially mean no tinting; resource
153 root 1.70 I<tintColor>. Example:
154 root 1.69
155     @@RXVT_NAME@@ -tr -tint blue -sh 40
156 root 1.1
157 sasha 1.134 =item B<-sh> I<number>
158 root 1.1
159 sasha 1.141 Darken (0 .. 100) or lighten (100 .. 200) the transparent
160 sasha 1.134 background image in addition to (or instead of) tinting it;
161 sasha 1.130 resource I<shading>.
162    
163     =item B<-blt> I<string>
164    
165 sasha 1.134 Specify background blending type. If background pixmap is specified
166     at the same time as transparency - such pixmap will be blended over
167 sasha 1.130 transparency image, using method specified. Supported values are :
168 sasha 1.134 B<add>, B<alphablend>, B<allanon> - color values averaging, B<colorize>,
169     B<darken>, B<diff>, B<dissipate>, B<hue>, B<lighten>, B<overlay>,
170     B<saturate>, B<screen>, B<sub>, B<tint>, B<value>. The default is
171 sasha 1.140 alpha-blending. Compile I<afterimage>; resource I<blendType>.
172 sasha 1.130
173 sasha 1.134 =item B<-blr> I<HxV>
174 sasha 1.130
175 sasha 1.134 Apply Gaussian Blur with the specified radii to the transparent
176     background image. If single number is specified - both vertical and
177     horizontal radii are considered to be the same. Setting one of the
178     radii to 1 and another to a large number creates interesting effects
179 sasha 1.140 on some backgrounds. Maximum radius value is 128. Compile I<afterimage>;
180     resource I<blurRadius>.
181 root 1.1
182     =item B<-bg> I<colour>
183    
184     Window background colour; resource B<background>.
185    
186     =item B<-fg> I<colour>
187    
188     Window foreground colour; resource B<foreground>.
189    
190 sasha 1.144 =item B<-pixmap> I<file[;geom[:op1][:op2][...]]>
191 root 1.1
192 ayin 1.143 Compile I<afterimage>: Specify image file for the background and also
193 sasha 1.130 optionally specify its scaling with a geometry string. Note you may need to
194 root 1.43 add quotes to avoid special shell interpretation of the C<;> in the
195 sasha 1.130 command-line; for more details see resource B<backgroundPixmap>.
196 root 1.1
197     =item B<-cr> I<colour>
198    
199     The cursor colour; resource B<cursorColor>.
200    
201     =item B<-pr> I<colour>
202    
203     The mouse pointer foreground colour; resource B<pointerColor>.
204    
205     =item B<-pr2> I<colour>
206    
207     The mouse pointer background colour; resource B<pointerColor2>.
208    
209     =item B<-bd> I<colour>
210    
211 root 1.22 The colour of the border around the text area and between the scrollbar and the text;
212 root 1.1 resource B<borderColor>.
213    
214 root 1.22 =item B<-fn> I<fontlist>
215 root 1.1
216 root 1.22 Select the fonts to be used. This is a comma separated list of font names
217 root 1.96 that are checked in order when trying to find glyphs for characters. The
218 root 1.22 first font defines the cell size for characters; other fonts might be
219 root 1.34 smaller, but not (in general) larger. A (hopefully) reasonable default
220     font list is always appended to it. See resource B<font> for more details.
221    
222 root 1.114 In short, to specify an X11 core font, just specify its name or prefix it
223 root 1.34 with C<x:>. To specify an XFT-font, you need to prefix it with C<xft:>,
224     e.g.:
225    
226     @@RXVT_NAME@@ -fn "xft:Bitstream Vera Sans Mono:pixelsize=15"
227     @@RXVT_NAME@@ -fn "9x15bold,xft:Bitstream Vera Sans Mono"
228 root 1.1
229 root 1.5 See also the question "How does rxvt-unicode choose fonts?" in the FAQ
230 root 1.30 section of @@RXVT_NAME@@(7).
231 root 1.5
232 root 1.22 =item B<-fb> I<fontlist>
233    
234 root 1.85 Compile I<font-styles>: The bold font list to use when B<bold> characters
235     are to be printed. See resource B<boldFont> for details.
236 root 1.22
237     =item B<-fi> I<fontlist>
238    
239 root 1.85 Compile I<font-styles>: The italic font list to use when I<italic>
240     characters are to be printed. See resource B<italicFont> for details.
241 root 1.22
242     =item B<-fbi> I<fontlist>
243 root 1.1
244 root 1.85 Compile I<font-styles>: The bold italic font list to use when B<< I<bold
245 root 1.83 italic> >> characters are to be printed. See resource B<boldItalicFont>
246     for details.
247 root 1.1
248 root 1.76 =item B<-is>|B<+is>
249    
250 ayin 1.154 Compile I<font-styles>: Bold/Blink font styles imply high intensity
251 root 1.76 foreground/background (default). See resource B<intensityStyles> for
252     details.
253    
254 root 1.1 =item B<-name> I<name>
255    
256     Specify the application name under which resources are to be obtained,
257     rather than the default executable file name. Name should not contain
258     `.' or `*' characters. Also sets the icon and title name.
259    
260     =item B<-ls>|B<+ls>
261    
262     Start as a login-shell/sub-shell; resource B<loginShell>.
263    
264     =item B<-ut>|B<+ut>
265    
266     Compile I<utmp>: Inhibit/enable writing a utmp entry; resource
267     B<utmpInhibit>.
268    
269     =item B<-vb>|B<+vb>
270    
271     Turn on/off visual bell on receipt of a bell character; resource
272     B<visualBell>.
273    
274     =item B<-sb>|B<+sb>
275    
276     Turn on/off scrollbar; resource B<scrollBar>.
277    
278     =item B<-si>|B<+si>
279    
280     Turn on/off scroll-to-bottom on TTY output inhibit; resource
281     B<scrollTtyOutput> has opposite effect.
282    
283     =item B<-sk>|B<+sk>
284    
285     Turn on/off scroll-to-bottom on keypress; resource
286     B<scrollTtyKeypress>.
287    
288     =item B<-sw>|B<+sw>
289    
290     Turn on/off scrolling with the scrollback buffer as new lines appear.
291     This only takes effect if B<-si> is also given; resource
292     B<scrollWithBuffer>.
293    
294     =item B<-sr>|B<+sr>
295    
296     Put scrollbar on right/left; resource B<scrollBar_right>.
297    
298     =item B<-st>|B<+st>
299    
300 root 1.64 Display rxvt (non XTerm/NeXT) scrollbar without/with a trough;
301 root 1.1 resource B<scrollBar_floating>.
302    
303 root 1.34 =item B<-ptab>|B<+ptab>
304    
305     If enabled (default), "Horizontal Tab" characters are being stored as
306     actual wide characters in the screen buffer, which makes it possible to
307     select and paste them. Since a horizontal tab is a cursor movement and
308     not an actual glyph, this can sometimes be visually annoying as the cursor
309     on a tab character is displayed as a wide cursor; resource B<pastableTabs>.
310    
311 root 1.1 =item B<-bc>|B<+bc>
312    
313     Blink the cursor; resource B<cursorBlink>.
314    
315     =item B<-iconic>
316    
317     Start iconified, if the window manager supports that option.
318     Alternative form is B<-ic>.
319    
320     =item B<-sl> I<number>
321    
322     Save I<number> lines in the scrollback buffer. See resource entry for
323     limits; resource B<saveLines>.
324    
325     =item B<-b> I<number>
326    
327     Compile I<frills>: Internal border of I<number> pixels. See resource
328     entry for limits; resource B<internalBorder>.
329    
330     =item B<-w> I<number>
331    
332     Compile I<frills>: External border of I<number> pixels. Also, B<-bw>
333     and B<-borderwidth>. See resource entry for limits; resource
334     B<externalBorder>.
335    
336     =item B<-bl>
337    
338     Compile I<frills>: Set MWM hints to request a borderless window, i.e.
339 root 1.3 if honoured by the WM, the rxvt-unicode window will not have window
340 root 1.1 decorations; resource B<borderLess>.
341    
342 root 1.99 =item B<-override-redirect>
343    
344     Compile I<frills>: Sets override-redirect on the window; resource
345     B<override-redirect>.
346    
347 root 1.85 =item B<-sbg>
348    
349     Compile I<frills>: Disable the usage of the built-in block graphics/line
350     drawing characters and just rely on what the specified fonts provide. Use
351     this if you have a good font and want to use its block graphic glyphs;
352     resource B<skipBuiltinGlyphs>.
353    
354 root 1.1 =item B<-lsp> I<number>
355    
356 root 1.43 Compile I<frills>: Lines (pixel height) to insert between each row of
357     the display. Useful to work around font rendering problems; resource
358 root 1.137 B<lineSpace>.
359 root 1.1
360     =item B<-tn> I<termname>
361    
362     This option specifies the name of the terminal type to be set in the
363     B<TERM> environment variable. This terminal type must exist in the
364     I<termcap(5)> database and should have I<li#> and I<co#> entries;
365     resource B<termName>.
366    
367     =item B<-e> I<command [arguments]>
368    
369 root 1.2 Run the command with its command-line arguments in the B<@@RXVT_NAME@@>
370 root 1.1 window; also sets the window title and icon name to be the basename of
371     the program being executed if neither I<-title> (I<-T>) nor I<-n> are
372     given on the command line. If this option is used, it must be the last
373     on the command-line. If there is no B<-e> option then the default is to
374     run the program specified by the B<SHELL> environment variable or,
375     failing that, I<sh(1)>.
376    
377 root 1.74 Please note that you must specify a program with arguments. If you want to
378     run shell commands, you have to specify the shell, like this:
379    
380     @@RXVT_NAME@@ -e sh -c "shell commands"
381    
382 root 1.1 =item B<-title> I<text>
383    
384     Window title (B<-T> still respected); the default title is the basename
385     of the program specified after the B<-e> option, if any, otherwise the
386     application name; resource B<title>.
387    
388     =item B<-n> I<text>
389    
390     Icon name; the default name is the basename of the program specified
391     after the B<-e> option, if any, otherwise the application name;
392     resource B<iconName>.
393    
394     =item B<-C>
395    
396     Capture system console messages.
397    
398     =item B<-pt> I<style>
399    
400     Compile I<XIM>: input style for input method; B<OverTheSpot>,
401     B<OffTheSpot>, B<Root>; resource B<preeditType>.
402    
403     =item B<-im> I<text>
404    
405     Compile I<XIM>: input method name. resource B<inputMethod>.
406    
407     =item B<-imlocale> I<string>
408    
409 root 1.48 The locale to use for opening the IM. You can use an C<LC_CTYPE> of e.g.
410     C<de_DE.UTF-8> for normal text processing but C<ja_JP.EUC-JP> for the
411     input extension to be able to input japanese characters while staying in
412     another locale. resource B<imLocale>.
413    
414     =item B<-imfont> I<fontset>
415    
416     Set the font set to use for the X Input Method, see resource B<imFont>
417     for more info.
418    
419     =item B<-tcw>
420    
421     Change the meaning of triple-click selection with the left mouse
422 root 1.129 button. Only effective when the original (non-perl) selection code is
423 ayin 1.149 in-use. Instead of selecting a full line it will extend the selection to
424     the end of the logical line only. resource B<tripleclickwords>.
425 root 1.1
426     =item B<-insecure>
427    
428     Enable "insecure" mode, which currently enables most of the escape
429     sequences that echo strings. See the resource B<insecure> for more
430     info.
431    
432     =item B<-mod> I<modifier>
433    
434     Override detection of Meta modifier with specified key: B<alt>,
435     B<meta>, B<hyper>, B<super>, B<mod1>, B<mod2>, B<mod3>, B<mod4>,
436     B<mod5>; resource I<modifier>.
437    
438     =item B<-ssc>|B<+ssc>
439    
440     Turn on/off secondary screen (default enabled); resource
441     B<secondaryScreen>.
442    
443     =item B<-ssr>|B<+ssr>
444    
445     Turn on/off secondary screen scroll (default enabled); resource
446     B<secondaryScroll>.
447    
448 root 1.74 =item B<-hold>|B<+hold>
449    
450     Turn on/off hold window after exit support. If enabled, @@RXVT_NAME@@
451     will not immediately destroy its window when the program executed within
452     it exits. Instead, it will wait till it is being killed or closed by the
453     user; resource B<hold>.
454    
455 root 1.147 =item B<-xrm> I<string>
456    
457     Works like the X Toolkit option of the same name, by adding the I<string>
458     as if it were specified in a resource file. Resource values specified this
459     way take precedence over all other resource specifications.
460    
461     Note that you need to use the I<same> syntax as in the .Xdefaults file,
462     e.g. C<*.background: black>. Also note that all @@RXVT_NAME@@-specific
463     options can be specified as long-options on the commandline, so use
464     of B<-xrm> is mostly limited to cases where you want to specify other
465     resources (e.g. for input methods) or for compatibility with other
466     programs.
467    
468 root 1.59 =item B<-keysym.>I<sym> I<string>
469 root 1.53
470     Remap a key symbol. See resource B<keysym>.
471    
472 root 1.59 =item B<-embed> I<windowid>
473 root 1.1
474 root 1.114 Tells @@RXVT_NAME@@ to embed its windows into an already-existing window,
475 root 1.56 which enables applications to easily embed a terminal.
476    
477     Right now, @@RXVT_NAME@@ will first unmap/map the specified window, so it
478     shouldn't be a top-level window. @@RXVT_NAME@@ will also reconfigure it
479     quite a bit, so don't expect it to keep some specific state. It's best to
480     create an extra subwindow for @@RXVT_NAME@@ and leave it alone.
481    
482 root 1.57 The window will not be destroyed when @@RXVT_NAME@@ exits.
483    
484 root 1.56 It might be useful to know that @@RXVT_NAME@@ will not close file
485     descriptors passed to it (except for stdin/out/err, of course), so you
486     can use file descriptors to communicate with the programs within the
487 root 1.118 terminal. This works regardless of whether the C<-embed> option was used or
488 root 1.56 not.
489 root 1.1
490 root 1.59 Here is a short Gtk2-perl snippet that illustrates how this option can be
491     used (a longer example is in F<doc/embed>):
492    
493 root 1.61 my $rxvt = new Gtk2::Socket;
494     $rxvt->signal_connect_after (realize => sub {
495     my $xid = $_[0]->window->get_xid;
496     system "@@RXVT_NAME@@ -embed $xid &";
497     });
498 root 1.59
499 root 1.86 =item B<-pty-fd> I<file descriptor>
500 root 1.59
501     Tells @@RXVT_NAME@@ NOT to execute any commands or create a new pty/tty
502 root 1.119 pair but instead use the given file descriptor as the tty master. This is
503 root 1.59 useful if you want to drive @@RXVT_NAME@@ as a generic terminal emulator
504     without having to run a program within it.
505    
506     If this switch is given, @@RXVT_NAME@@ will not create any utmp/wtmp
507     entries and will not tinker with pty/tty permissions - you have to do that
508     yourself if you want that.
509    
510 root 1.86 As an extremely special case, specifying C<-1> will completely suppress
511 root 1.151 pty/tty operations, which is probably only useful in conjunction with some
512     perl extension that manages the terminal.
513 root 1.86
514 root 1.59 Here is a example in perl that illustrates how this option can be used (a
515     longer example is in F<doc/pty-fd>):
516    
517     use IO::Pty;
518     use Fcntl;
519    
520     my $pty = new IO::Pty;
521     fcntl $pty, F_SETFD, 0; # clear close-on-exec
522     system "@@RXVT_NAME@@ -pty-fd " . (fileno $pty) . "&";
523 root 1.60 close $pty;
524 root 1.59
525     # now communicate with rxvt
526     my $slave = $pty->slave;
527     while (<$slave>) { print $slave "got <$_>\n" }
528    
529 root 1.78 =item B<-pe> I<string>
530 root 1.77
531 root 1.88 Comma-separated list of perl extension scripts to use (or not to use) in
532     this terminal instance. See resource B<perl-ext> for details.
533 root 1.77
534 root 1.1 =back
535    
536 root 1.151 =head1 RESOURCES
537 root 1.1
538 root 1.2 Note: `@@RXVT_NAME@@ --help' gives a list of all resources (long
539 root 1.151 options) compiled into your version. All resources are also available as
540     long-options.
541 root 1.1
542 root 1.93 You can set and change the resources using X11 tools like B<xrdb>. Many
543     distribution do also load settings from the B<~/.Xresources> file when X
544     starts. @@RXVT_NAME@@ will consult the following files/resources in order,
545     with later settings overwriting earlier ones:
546 root 1.53
547     1. system-wide app-defaults file, either locale-dependent OR global
548     2. app-defaults file in $XAPPLRESDIR
549     3. RESOURCE_MANAGER property on root-window OR $HOME/.Xdefaults
550     4. SCREEN_RESOURCES for the current screen
551     5. $XENVIRONMENT file OR $HOME/.Xdefaults-<nodename>
552 root 1.147 6. resources specified via -xrm on the commandline
553 root 1.1
554 root 1.93 Note that when reading X resources, B<@@RXVT_NAME@@> recognizes two class
555     names: B<Rxvt> and B<URxvt>. The class name B<Rxvt> allows resources
556     common to both B<@@RXVT_NAME@@> and the original I<rxvt> to be easily
557     configured, while the class name B<URxvt> allows resources unique to
558     B<@@RXVT_NAME@@>, to be shared between different B<@@RXVT_NAME@@>
559     configurations. If no resources are specified, suitable defaults will
560     be used. Command-line arguments can be used to override resource
561     settings. The following resources are supported (you might want to
562     check the @@RXVT_NAME@@perl(3) manpage for additional settings by perl
563     extensions not documented here):
564 root 1.1
565     =over 4
566    
567 root 1.106 =item B<depth:> I<bitdepth>
568    
569 root 1.109 Compile I<xft>: Attempt to find a visual with the given bit depth;
570 root 1.106 option B<-depth>.
571    
572 root 1.1 =item B<geometry:> I<geom>
573    
574     Create the window with the specified X window geometry [default 80x24];
575     option B<-geometry>.
576    
577     =item B<background:> I<colour>
578    
579     Use the specified colour as the window's background colour [default
580     White]; option B<-bg>.
581    
582     =item B<foreground:> I<colour>
583    
584     Use the specified colour as the window's foreground colour [default
585     Black]; option B<-fg>.
586    
587     =item B<color>I<n>B<:> I<colour>
588    
589     Use the specified colour for the colour value I<n>, where 0-7
590     corresponds to low-intensity (normal) colours and 8-15 corresponds to
591     high-intensity (bold = bright foreground, blink = bright background)
592     colours. The canonical names are as follows: 0=black, 1=red, 2=green,
593     3=yellow, 4=blue, 5=magenta, 6=cyan, 7=white, but the actual colour
594     names used are listed in the B<COLORS AND GRAPHICS> section.
595    
596 root 1.22 Colours higher than 15 cannot be set using resources (yet), but can be
597     changed using an escape command (see @@RXVT_NAME@@(7)).
598    
599     Colours 16-79 form a standard 4x4x4 colour cube (the same as xterm with
600     88 colour support). Colours 80-87 are evenly spaces grey steps.
601    
602 root 1.1 =item B<colorBD:> I<colour>
603    
604 root 1.22 =item B<colorIT:> I<colour>
605    
606     Use the specified colour to display bold or italic characters when the
607     foreground colour is the default. If font styles are not available
608 root 1.43 (Compile I<styles>) and this option is unset, reverse video is used instead.
609 root 1.1
610     =item B<colorUL:> I<colour>
611    
612     Use the specified colour to display underlined characters when the
613     foreground colour is the default.
614    
615     =item B<colorRV:> I<colour>
616    
617 root 1.125 Use the specified colour as the background for reverse video characters
618     when OPTION_HC is disabled (--disable-frills).
619 root 1.1
620 root 1.35 =item B<underlineColor:> I<colour>
621    
622     If set, use the specified colour as the colour for the underline
623     itself. If unset, use the foreground colour.
624    
625 root 1.1 =item B<cursorColor:> I<colour>
626    
627     Use the specified colour for the cursor. The default is to use the
628     foreground colour; option B<-cr>.
629    
630     =item B<cursorColor2:> I<colour>
631    
632     Use the specified colour for the colour of the cursor text. For this to
633     take effect, B<cursorColor> must also be specified. The default is to
634     use the background colour.
635    
636     =item B<reverseVideo:> I<boolean>
637    
638     B<True>: simulate reverse video by foreground and background colours;
639     option B<-rv>. B<False>: regular screen colours [default]; option
640     B<+rv>. See note in B<COLORS AND GRAPHICS> section.
641    
642     =item B<jumpScroll:> I<boolean>
643    
644 root 1.132 B<True>: specify that jump scrolling should be used. When receiving lots
645     of lines, @@RXVT_NAME@@ will only scroll once a whole screen height of lines
646     has been read, resulting in fewer updates while still displaying every
647     received line; option B<-j>.
648    
649     B<False>: specify that smooth scrolling should be used. @@RXVT_NAME@@ will
650     force a screen refresh on each new line it received; option B<+j>.
651    
652     =item B<skipScroll:> I<boolean>
653    
654     B<True>: (the default) specify that skip scrolling should be used. When
655     receiving lots of lines, @@RXVT_NAME@@ will only scroll once in a while
656     (around 60 times per second), resulting in far fewer updates. This can
657     result in @@RXVT_NAME@@ not ever displaying some of the lines it receives;
658     option B<-ss>.
659    
660     B<False>: specify that everything is to be displayed, even
661     if the refresh is too fast for the human eye to read anything (or the
662     monitor to display anything); option B<+ss>.
663 root 1.1
664 ayin 1.148 =item B<transparent:> I<boolean>
665 root 1.1
666 ayin 1.148 Turn on/off illusion of a transparent window background.
667 root 1.1
668 ayin 1.148 B<inheritPixmap> is still accepted as an obsolete alias but will be removed in
669     future versions.
670    
671     I<Please address all transparency related issues to Sasha Vasko at
672     sasha@aftercode.net. Read the FAQ (man 7 @@RXVT_NAME@@)!>
673 root 1.110
674 root 1.1 =item B<fading:> I<number>
675    
676 root 1.68 Fade the text by the given percentage when focus is lost; option B<-fade>.
677    
678     =item B<fadeColor:> I<colour>
679    
680     Fade to this colour, when fading is used (see B<fading:>). The default
681     colour is black; option B<-fadecolor>.
682 root 1.1
683     =item B<tintColor:> I<colour>
684    
685 root 1.68 Tint the transparent background pixmap with the given colour; option
686     B<-tint>.
687 root 1.1
688     =item B<shading:> I<number>
689    
690 root 1.124 Darken (0 .. 100) or lighten (-1 .. -100) the transparent background image
691     in addition to tinting it; option B<-sh>.
692 root 1.1
693 sasha 1.130 =item B<blendType:> I<string>
694    
695     Specify background blending type; option B<-blt>.
696    
697     =item B<blurRadius:> I<number>
698    
699 ayin 1.143 Apply Gaussian Blurr with the specified radius to the transparent
700 sasha 1.130 background image; option B<-blr>.
701    
702 root 1.1 =item B<scrollColor:> I<colour>
703    
704     Use the specified colour for the scrollbar [default #B2B2B2].
705    
706     =item B<troughColor:> I<colour>
707    
708     Use the specified colour for the scrollbar's trough area [default
709 root 1.64 #969696]. Only relevant for rxvt (non XTerm/NeXT) scrollbar.
710 root 1.1
711 root 1.22 =item B<borderColor:> I<colour>
712    
713     The colour of the border around the text area and between the scrollbar
714     and the text.
715    
716 sasha 1.144 =item B<backgroundPixmap:> I<file[;geom[:op1][:op2][...]]>
717 root 1.1
718 root 1.145 Use the specified image file for the background and also
719     optionally specify its scaling with a geometry string B<WxH+X+Y>,
720     (default C<0x0+50+50>) in which B<"W" / "H"> specify the
721     horizontal/vertical scale (percent), and B<"X" / "Y"> locate the image
722     centre (percent). A scale of 0 displays the image with tiling. A scale
723     of 1 displays the image without any scaling. A scale of 2 to 9 specifies
724     an integer number of images in that direction. No image will be magnified
725     beyond 10 times its original size. The maximum permitted scale is 1000.
726     Additional operations can be specified after colon B<:op1:op2...>.
727     Supported operations are:
728    
729     tile force background image to be tiled and not scaled. Equivalent to 0x0,
730     propscale will scale image keeping proportions,
731     auto will scale image to match window size. Equivalent to 100x100;
732     hscale will scale image horizontally to the window size;
733     vscale will scale image vertically to the window size;
734     scale will scale image to match window size;
735     root will tile image as if it was a root window background, auto-adjusting
736     whenever terminal window moves.
737 sasha 1.144
738 root 1.145 If used in conjunction with B<-tr> option, the specified pixmap will be
739 ayin 1.143 blended over transparency image using either alpha-blending, or any
740 sasha 1.130 other blending type, specified with B<-blt "type"> option.
741 root 1.1
742     =item B<path:> I<path>
743    
744 sasha 1.138 Specify the colon-delimited search path for finding background image files.
745 root 1.1
746 root 1.22 =item B<font:> I<fontlist>
747 root 1.1
748 root 1.96 Select the fonts to be used. This is a comma separated list of font names
749     that are checked in order when trying to find glyphs for characters. The
750     first font defines the cell size for characters; other fonts might be
751     smaller, but not (in general) larger. A (hopefully) reasonable default
752     font list is always appended to it; option B<-fn>.
753 root 1.1
754 root 1.22 Each font can either be a standard X11 core font (XLFD) name, with
755 root 1.43 optional prefix C<x:> or a Xft font (Compile I<xft>), prefixed with C<xft:>.
756 root 1.22
757     In addition, each font can be prefixed with additional hints and
758     specifications enclosed in square brackets (C<[]>). The only available
759     hint currently is C<codeset=codeset-name>, and this is only used for Xft
760     fonts.
761    
762     For example, this font resource
763 root 1.1
764 root 1.97 URxvt.font: 9x15bold,\
765 root 1.22 -misc-fixed-bold-r-normal--15-140-75-75-c-90-iso10646-1,\
766     -misc-fixed-medium-r-normal--15-140-75-75-c-90-iso10646-1, \
767     [codeset=JISX0208]xft:Kochi Gothic:antialias=false, \
768     xft:Code2000:antialias=false
769    
770     specifies five fonts to be used. The first one is C<9x15bold> (actually
771     the iso8859-1 version of the second font), which is the base font (because
772     it is named first) and thus defines the character cell grid to be 9 pixels
773     wide and 15 pixels high.
774    
775 root 1.34 The second font is just used to add additional unicode characters not in
776 root 1.22 the base font, likewise the third, which is unfortunately non-bold, but
777     the bold version of the font does contain less characters, so this is a
778     useful supplement.
779    
780     The third font is an Xft font with aliasing turned off, and the characters
781     are limited to the B<JIS 0208> codeset (i.e. japanese kanji). The font
782     contains other characters, but we are not interested in them.
783    
784     The last font is a useful catch-all font that supplies most of the
785     remaining unicode characters.
786    
787     =item B<boldFont:> I<fontlist>
788    
789     =item B<italicFont:> I<fontlist>
790    
791     =item B<boldItalicFont:> I<fontlist>
792    
793     The font list to use for displaying B<bold>, I<italic> or B<< I<bold
794     italic> >> characters, respectively.
795    
796     If specified and non-empty, then the syntax is the same as for the
797     B<font>-resource, and the given font list will be used as is, which makes
798     it possible to substitute completely different font styles for bold and
799     italic.
800    
801     If unset (the default), a suitable font list will be synthesized by
802     "morphing" the normal text font list into the desired shape. If that is
803     not possible, replacement fonts of the desired shape will be tried.
804    
805     If set, but empty, then this specific style is disabled and the normal
806     text font will being used for the given style.
807 root 1.1
808 root 1.76 =item B<intensityStyles:> I<boolean>
809    
810     When font styles are not enabled, or this option is enabled (B<True>,
811 ayin 1.154 option B<-is>, the default), bold/blink font styles imply high
812 root 1.118 intensity foreground/background colours. Disabling this option (B<False>,
813 root 1.76 option B<+is>) disables this behaviour, the high intensity colours are not
814     reachable.
815    
816 root 1.1 =item B<scrollstyle:> I<mode>
817    
818 root 1.3 Set scrollbar style to B<rxvt>, B<plain>, B<next> or B<xterm>. B<plain> is
819 root 1.64 the author's favourite.
820 root 1.1
821     =item B<title:> I<string>
822    
823     Set window title string, the default title is the command-line
824     specified after the B<-e> option, if any, otherwise the application
825     name; option B<-title>.
826    
827     =item B<iconName:> I<string>
828    
829     Set the name used to label the window's icon or displayed in an icon
830     manager window, it also sets the window's title unless it is explicitly
831     set; option B<-n>.
832    
833     =item B<mapAlert:> I<boolean>
834    
835     B<True>: de-iconify (map) on receipt of a bell character. B<False>: no
836     de-iconify (map) on receipt of a bell character [default].
837    
838 ayin 1.127 =item B<urgentOnBell:> I<boolean>
839    
840     B<True>: set the urgency hint for the wm on receipt of a bell character.
841     B<False>: do not set the urgency hint [default].
842    
843 root 1.1 =item B<visualBell:> I<boolean>
844    
845     B<True>: use visual bell on receipt of a bell character; option B<-vb>.
846     B<False>: no visual bell [default]; option B<+vb>.
847    
848     =item B<loginShell:> I<boolean>
849    
850     B<True>: start as a login shell by prepending a `-' to B<argv[0]> of
851     the shell; option B<-ls>. B<False>: start as a normal sub-shell
852     [default]; option B<+ls>.
853    
854     =item B<utmpInhibit:> I<boolean>
855    
856     B<True>: inhibit writing record into the system log file B<utmp>;
857     option B<-ut>. B<False>: write record into the system log file B<utmp>
858     [default]; option B<+ut>.
859    
860     =item B<print-pipe:> I<string>
861    
862     Specify a command pipe for vt100 printer [default I<lpr(1)>]. Use
863     B<Print> to initiate a screen dump to the printer and B<Ctrl-Print> or
864     B<Shift-Print> to include the scrollback as well.
865    
866 root 1.65 The string will be interpreted as if typed into the shell as-is.
867    
868 root 1.66 Example:
869    
870 root 1.97 URxvt.print-pipe: cat > $(TMPDIR=$HOME mktemp urxvt.XXXXXX)
871 root 1.66
872     This creates a new file in your home directory with the screen contents
873 root 1.118 every time you hit C<Print>.
874 root 1.66
875 root 1.1 =item B<scrollBar:> I<boolean>
876    
877     B<True>: enable the scrollbar [default]; option B<-sb>. B<False>:
878     disable the scrollbar; option B<+sb>.
879    
880     =item B<scrollBar_right:> I<boolean>
881    
882     B<True>: place the scrollbar on the right of the window; option B<-sr>.
883     B<False>: place the scrollbar on the left of the window; option B<+sr>.
884    
885     =item B<scrollBar_floating:> I<boolean>
886    
887     B<True>: display an rxvt scrollbar without a trough; option B<-st>.
888     B<False>: display an rxvt scrollbar with a trough; option B<+st>.
889    
890     =item B<scrollBar_align:> I<mode>
891    
892     Align the B<top>, B<bottom> or B<centre> [default] of the scrollbar
893     thumb with the pointer on middle button press/drag.
894    
895     =item B<scrollTtyOutput:> I<boolean>
896    
897 root 1.4 B<True>: scroll to bottom when tty receives output; option B<-si>.
898 root 1.1 B<False>: do not scroll to bottom when tty receives output; option
899 root 1.4 B<+si>.
900 root 1.1
901     =item B<scrollWithBuffer:> I<boolean>
902    
903 root 1.30 B<True>: scroll with scrollback buffer when tty receives new lines (and
904 root 1.58 B<scrollTtyOutput> is False); option B<-sw>. B<False>: do not scroll
905 root 1.118 with scrollback buffer when tty receives new lines; option B<+sw>.
906 root 1.1
907     =item B<scrollTtyKeypress:> I<boolean>
908    
909 root 1.3 B<True>: scroll to bottom when a non-special key is pressed. Special keys
910     are those which are intercepted by rxvt-unicode for special handling and
911     are not passed onto the shell; option B<-sk>. B<False>: do not scroll to
912     bottom when a non-special key is pressed; option B<+sk>.
913 root 1.1
914     =item B<saveLines:> I<number>
915    
916     Save I<number> lines in the scrollback buffer [default 64]. This
917     resource is limited on most machines to 65535; option B<-sl>.
918    
919     =item B<internalBorder:> I<number>
920    
921     Internal border of I<number> pixels. This resource is limited to 100;
922     option B<-b>.
923    
924     =item B<externalBorder:> I<number>
925    
926     External border of I<number> pixels. This resource is limited to 100;
927     option B<-w>, B<-bw>, B<-borderwidth>.
928    
929     =item B<borderLess:> I<boolean>
930    
931     Set MWM hints to request a borderless window, i.e. if honoured by the
932 root 1.3 WM, the rxvt-unicode window will not have window decorations; option B<-bl>.
933 root 1.1
934 root 1.85 =item B<skipBuiltinGlyphs:> I<boolean>
935    
936     Compile I<frills>: Disable the usage of the built-in block graphics/line
937     drawing characters and just rely on what the specified fonts provide. Use
938     this if you have a good font and want to use its block graphic glyphs;
939     option B<-sbg>.
940    
941 root 1.1 =item B<termName:> I<termname>
942    
943     Specifies the terminal type name to be set in the B<TERM> environment
944     variable; option B<-tn>.
945    
946 root 1.137 =item B<lineSpace:> I<number>
947 root 1.1
948     Specifies number of lines (pixel height) to insert between each row of
949     the display [default 0]; option B<-lsp>.
950    
951     =item B<meta8:> I<boolean>
952    
953     B<True>: handle Meta (Alt) + keypress to set the 8th bit. B<False>:
954     handle Meta (Alt) + keypress as an escape prefix [default].
955    
956     =item B<mouseWheelScrollPage:> I<boolean>
957    
958     B<True>: the mouse wheel scrolls a page full. B<False>: the mouse wheel
959     scrolls five lines [default].
960    
961 root 1.34 =item B<pastableTabs:> I<boolean>
962    
963     B<True>: store tabs as wide characters. B<False>: interpret tabs as cursor
964     movement only; option C<-ptab>.
965    
966 root 1.1 =item B<cursorBlink:> I<boolean>
967    
968     B<True>: blink the cursor. B<False>: do not blink the cursor [default];
969     option B<-bc>.
970    
971     =item B<pointerBlank:> I<boolean>
972    
973     B<True>: blank the pointer when a key is pressed or after a set number
974     of seconds of inactivity. B<False>: the pointer is always visible
975     [default].
976    
977     =item B<pointerColor:> I<colour>
978    
979     Mouse pointer foreground colour.
980    
981     =item B<pointerColor2:> I<colour>
982    
983     Mouse pointer background colour.
984    
985     =item B<pointerBlankDelay:> I<number>
986    
987 root 1.62 Specifies number of seconds before blanking the pointer [default 2]. Use a
988     large number (e.g. C<987654321>) to effectively disable the timeout.
989 root 1.1
990     =item B<backspacekey:> I<string>
991    
992     The string to send when the backspace key is pressed. If set to B<DEC>
993     or unset it will send B<Delete> (code 127) or, if shifted, B<Backspace>
994     (code 8) - which can be reversed with the appropriate DEC private mode
995     escape sequence.
996    
997     =item B<deletekey:> I<string>
998    
999     The string to send when the delete key (not the keypad delete key) is
1000     pressed. If unset it will send the sequence traditionally associated
1001     with the B<Execute> key.
1002    
1003     =item B<cutchars:> I<string>
1004    
1005 root 1.105 The characters used as delimiters for double-click word selection
1006     (whitespace delimiting is added automatically if resource is given).
1007 root 1.104
1008 root 1.129 When the perl selection extension is in use (the default if compiled
1009     in, see the @@RXVT_NAME@@perl(3) manpage), a suitable regex using these
1010     characters will be created (if the resource exists, otherwise, no regex
1011     will be created). In this mode, characters outside ISO-8859-1 can be used.
1012 root 1.104
1013     When the selection extension is not used, only ISO-8859-1 characters can
1014     be used. If not specified, the built-in default is used:
1015 root 1.1
1016 ayin 1.146 B<< BACKSLASH `"'&()*,;<=>?@[]^{|} >>
1017 root 1.1
1018     =item B<preeditType:> I<style>
1019    
1020     B<OverTheSpot>, B<OffTheSpot>, B<Root>; option B<-pt>.
1021    
1022     =item B<inputMethod:> I<name>
1023    
1024     I<name> of inputMethod to use; option B<-im>.
1025    
1026     =item B<imLocale:> I<name>
1027    
1028 root 1.48 The locale to use for opening the IM. You can use an C<LC_CTYPE> of e.g.
1029     C<de_DE.UTF-8> for normal text processing but C<ja_JP.EUC-JP> for the
1030     input extension to be able to input japanese characters while staying in
1031 root 1.77 another locale; option B<-imlocale>.
1032 root 1.1
1033 root 1.48 =item B<imFont:> I<fontset>
1034    
1035     Specify the font-set used for XIM styles C<OverTheSpot> or
1036     C<OffTheSpot>. It must be a standard X font set (XLFD patterns separated
1037     by commas), i.e. it's not in the same format as the other font lists used
1038     in @@RXVT_NAME@@. The default will be set-up to chose *any* suitable found
1039     found, preferably one or two pixels differing in size to the base font.
1040     option B<-imfont>.
1041    
1042     =item B<tripleclickwords:> I<boolean>
1043    
1044     Change the meaning of triple-click selection with the left mouse
1045     button. Instead of selecting a full line it will extend the selection to
1046 root 1.77 the end of the logical line only; option B<-tcw>.
1047 root 1.48
1048 root 1.22 =item B<insecure:> I<boolean>
1049 root 1.1
1050     Enables "insecure" mode. Rxvt-unicode offers some escape sequences that
1051     echo arbitrary strings like the icon name or the locale. This could be
1052 root 1.30 abused if somebody gets 8-bit-clean access to your display, whether
1053 root 1.73 through a mail client displaying mail bodies unfiltered or through
1054     write(1) or any other means. Therefore, these sequences are disabled by
1055     default. (Note that many other terminals, including xterm, have these
1056     sequences enabled by default, which doesn't make it safer, though).
1057    
1058     You can enable them by setting this boolean resource or specifying
1059     B<-insecure> as an option. At the moment, this enables display-answer,
1060 root 1.97 locale, findfont, icon label and window title requests.
1061 root 1.1
1062     =item B<modifier:> I<modifier>
1063    
1064     Set the key to be interpreted as the Meta key to: B<alt>, B<meta>,
1065     B<hyper>, B<super>, B<mod1>, B<mod2>, B<mod3>, B<mod4>, B<mod5>; option
1066     B<-mod>.
1067    
1068     =item B<answerbackString:> I<string>
1069    
1070 root 1.3 Specify the reply rxvt-unicode sends to the shell when an ENQ (control-E)
1071 root 1.1 character is passed through. It may contain escape values as described
1072     in the entry on B<keysym> following.
1073    
1074 root 1.99 =item B<secondaryScreen:> I<boolean>
1075 root 1.1
1076     Turn on/off secondary screen (default enabled).
1077    
1078 root 1.99 =item B<secondaryScroll:> I<boolean>
1079 root 1.1
1080 ayin 1.126 Turn on/off secondary screen scroll (default enabled). If this
1081 root 1.1 option is enabled, scrolls on the secondary screen will change the
1082     scrollback buffer and switching to/from the secondary screen will
1083     instead scroll the screen up.
1084    
1085 root 1.99 =item B<hold>: I<boolean>
1086 root 1.74
1087     Turn on/off hold window after exit support. If enabled, @@RXVT_NAME@@
1088     will not immediately destroy its window when the program executed within
1089     it exits. Instead, it will wait till it is being killed or closed by the
1090     user.
1091    
1092 root 1.1 =item B<keysym.>I<sym>: I<string>
1093    
1094 root 1.43 Compile I<frills>: Associate I<string> with keysym I<sym>. The
1095     intervening resource name B<keysym.> cannot be omitted.
1096    
1097     The format of I<sym> is "I<(modifiers-)key>", where I<modifiers> can be
1098     any combination of B<ISOLevel3>, B<AppKeypad>, B<Control>, B<NumLock>,
1099     B<Shift>, B<Meta>, B<Lock>, B<Mod1>, B<Mod2>, B<Mod3>, B<Mod4>, B<Mod5>,
1100     and the abbreviated B<I>, B<K>, B<C>, B<N>, B<S>, B<M>, B<A>, B<L>, B<1>,
1101     B<2>, B<3>, B<4>, B<5>.
1102    
1103     The B<NumLock>, B<Meta> and B<ISOLevel3> modifiers are usually aliased to
1104     whatever modifier the NumLock key, Meta/Alt keys or ISO Level3 Shift/AltGr
1105 root 1.48 keys are being mapped. B<AppKeypad> is a synthetic modifier mapped to the
1106 root 1.43 current application keymap mode state.
1107    
1108     The spellings of I<key> can be obtained by using B<xev>(1) command or
1109     searching keysym macros from B</usr/X11R6/include/X11/keysymdef.h> and
1110     omitting the prefix B<XK_>. Alternatively you can specify I<key> by its hex
1111     keysym value (B<0x0000 - 0xFFFF>). Note that the lookup of I<sym>s is not
1112     performed in an exact manner; however, the closest match is assured.
1113    
1114 ayin 1.139 I<string> may contain escape values (C<\n>: newline, C<\000>: octal
1115     number), see RESOURCES in C<man 7 X> for futher details.
1116 root 1.48
1117 root 1.43 You can define a range of keysyms in one shot by providing a I<string>
1118 root 1.118 with pattern B<list/PREFIX/MIDDLE/SUFFIX>, where the delimiter `/'
1119 root 1.43 should be a character not used by the strings.
1120    
1121     Its usage can be demonstrated by an example:
1122    
1123 root 1.48 URxvt.keysym.M-C-0x61: list|\033<M-C-|abc|>
1124 root 1.43
1125     The above line is equivalent to the following three lines:
1126    
1127 root 1.48 URxvt.keysym.Meta-Control-0x61: \033<M-C-a>
1128     URxvt.keysym.Meta-Control-0x62: \033<M-C-b>
1129     URxvt.keysym.Meta-Control-0x63: \033<M-C-c>
1130    
1131     If I<string> takes the form of C<command:STRING>, the specified B<STRING>
1132     is interpreted and executed as @@RXVT_NAME@@'s control sequence. For
1133     example the following means "change the current locale to C<zh_CN.GBK>
1134     when Control-Meta-c is being pressed":
1135    
1136     URxvt.keysym.M-C-c: command:\033]701;zh_CN.GBK\007
1137    
1138 root 1.80 If I<string> takes the form C<perl:STRING>, then the specified B<STRING>
1139 root 1.81 is passed to the C<on_keyboard_command> perl handler. See the @@RXVT_NAME@@perl(3)
1140 root 1.80 manpage. For example, the F<selection> extension (activated via
1141     C<@@RXVT_NAME@@ -pe selection>) listens for C<selection:rot13> events:
1142    
1143     URxvt.keysym.M-C-c: perl:selection:rot13
1144    
1145 root 1.63 Due the the large number of modifier combinations, a defined key mapping
1146     will match if at I<at least> the specified identifiers are being set, and
1147     no other key mappings with those and more bits are being defined. That
1148     means that defining a key map for C<a> will automatically provide
1149     definitions for C<Meta-a>, C<Shift-a> and so on, unless some of those are defined
1150     mappings themselves.
1151    
1152     Unfortunately, this will override built-in key mappings. For example
1153     if you overwrite the C<Insert> key you will disable @@RXVT_NAME@@'s
1154     C<Shift-Insert> mapping. To re-enable that, you can poke "holes" into the
1155     user-defined keymap using the C<builtin:> replacement:
1156    
1157     URxvt.keysym.Insert: <my insert key sequence>
1158     URxvt.keysym.S-Insert: builtin:
1159    
1160     The first line defines a mapping for C<Insert> and I<any> combination
1161     of modifiers. The second line re-establishes the default mapping for
1162     C<Shift-Insert>.
1163    
1164 root 1.48 The following example will map Control-Meta-1 and Control-Meta-2 to
1165     the fonts C<suxuseuro> and C<9x15bold>, so you can have some limited
1166     font-switching at runtime:
1167    
1168     URxvt.keysym.M-C-1: command:\033]50;suxuseuro\007
1169     URxvt.keysym.M-C-2: command:\033]50;9x15bold\007
1170    
1171     Other things are possible, e.g. resizing (see @@RXVT_NAME@@(7) for more
1172     info):
1173    
1174     URxvt.keysym.M-C-3: command:\033[8;25;80t
1175     URxvt.keysym.M-C-4: command:\033[8;48;110t
1176 root 1.1
1177 root 1.84 =item B<perl-ext-common>: I<string>
1178    
1179 root 1.78 =item B<perl-ext>: I<string>
1180 root 1.77
1181 root 1.88 Comma-separated list(s) of perl extension scripts (default: C<default>) to
1182     use in this terminal instance; option B<-pe>.
1183    
1184     Extension names can be prefixed with a C<-> sign to prohibit using
1185 root 1.91 them. This can be useful to selectively disable some extensions loaded
1186 root 1.88 by default, or specified via the C<perl-ext-common> resource. For
1187     example, C<default,-selection> will use all the default extension except
1188     C<selection>.
1189    
1190 root 1.91 Extension names can also be followed by an argument in angle brackets
1191     (e.g. C<< searchable-scrollback<M-s> >>, which binds the hotkey for
1192 root 1.118 searchable scrollback to Alt/Meta-s). Mentioning the same extension
1193 root 1.91 multiple times with different arguments will pass multiple arguments to
1194     the extension.
1195    
1196 root 1.88 Each extension is looked up in the library directories, loaded if
1197     necessary, and bound to the current terminal instance.
1198    
1199     If both of these resources are the empty string, then the perl
1200     interpreter will not be initialized. The idea behind two options is that
1201     B<perl-ext-common> will be used for extensions that should be available to
1202     all instances, while B<perl-ext> is used for specific instances.
1203 root 1.77
1204     =item B<perl-eval>: I<string>
1205    
1206 root 1.89 Perl code to be evaluated when all extensions have been registered. See
1207     the @@RXVT_NAME@@perl(3) manpage. Due to security reasons, this resource
1208     will be ignored when running setuid/setgid.
1209 root 1.77
1210     =item B<perl-lib>: I<path>
1211    
1212 root 1.78 Colon-separated list of additional directories that hold extension
1213     scripts. When looking for extensions specified by the C<perl> resource,
1214     @@RXVT_NAME@@ will first look in these directories and then in
1215 root 1.89 F<@@RXVT_LIBDIR@@/urxvt/perl/>. Due to security reasons, this resource
1216     will be ignored when running setuid/setgid.
1217 root 1.77
1218 root 1.81 See the @@RXVT_NAME@@perl(3) manpage.
1219 root 1.77
1220 root 1.95 =item B<< selection.pattern-I<idx> >>: I<perl-regex>
1221    
1222     Additional selection patterns, see the @@RXVT_NAME@@perl(3) manpage for
1223     details.
1224    
1225     =item B<< selection-autotransform.I<idx> >>: I<perl-transform>
1226    
1227     Selection auto-transform patterns, see the @@RXVT_NAME@@perl(3) manpage
1228     for details.
1229    
1230 root 1.94 =item B<searchable-scrollback:> I<keysym>
1231    
1232     Sets the hotkey that starts the incremental scrollback buffer search
1233     (default: C<M-s>).
1234    
1235 root 1.92 =item B<urlLauncher>: I<string>
1236    
1237     Specifies the program to be started with a URL argument. Used by the
1238 root 1.122 C<selection-popup> and C<matcher> perl extensions.
1239 root 1.92
1240 root 1.90 =item B<transient-for>: I<windowid>
1241    
1242 root 1.99 Compile I<frills>: Sets the WM_TRANSIENT_FOR property to the given window id.
1243    
1244     =item B<override-redirect>: I<boolean>
1245    
1246     Compile I<frills>: Sets override-redirect for the terminal window, making
1247     it almost invisible to window managers; option B<-override-redirect>.
1248 root 1.90
1249 ayin 1.131 =item B<iso14755_52:> I<boolean>
1250    
1251     Turn on/off ISO 14755 5.2 mode (default enabled).
1252    
1253 root 1.1 =back
1254    
1255     =head1 THE SCROLLBAR
1256    
1257 root 1.2 Lines of text that scroll off the top of the B<@@RXVT_NAME@@> window
1258 root 1.1 (resource: B<saveLines>) and can be scrolled back using the scrollbar
1259 root 1.2 or by keystrokes. The normal B<@@RXVT_NAME@@> scrollbar has arrows and
1260 root 1.1 its behaviour is fairly intuitive. The B<xterm-scrollbar> is without
1261     arrows and its behaviour mimics that of I<xterm>
1262    
1263     Scroll down with B<Button1> (B<xterm-scrollbar>) or B<Shift-Next>.
1264     Scroll up with B<Button3> (B<xterm-scrollbar>) or B<Shift-Prior>.
1265     Continuous scroll with B<Button2>.
1266    
1267     =head1 MOUSE REPORTING
1268    
1269     To temporarily override mouse reporting, for either the scrollbar or
1270     the normal text selection/insertion, hold either the Shift or the Meta
1271     (Alt) key while performing the desired mouse action.
1272    
1273     If mouse reporting mode is active, the normal scrollbar actions are
1274     disabled -- on the assumption that we are using a fullscreen
1275 root 1.53 application. Instead, pressing Button1 and Button3 sends B<ESC [ 6 ~>
1276     (Next) and B<ESC [ 5 ~> (Prior), respectively. Similarly, clicking on the
1277     up and down arrows sends B<ESC [ A> (Up) and B<ESC [ B> (Down),
1278 root 1.1 respectively.
1279    
1280 root 1.128 =head1 THE SELECTION: SELECTING AND PASTING TEXT
1281 root 1.1
1282 root 1.128 The behaviour of text selection and insertion/pasting mechanism is similar
1283     to I<xterm>(1).
1284 root 1.1
1285     =over 4
1286    
1287 root 1.128 =item B<Selecting>:
1288 root 1.1
1289 root 1.48 Left click at the beginning of the region, drag to the end of the region
1290     and release; Right click to extend the marked region; Left double-click
1291     to select a word; Left triple-click to select the entire logical line
1292     (which can span multiple screen lines), unless modified by resource
1293     B<tripleclickwords>.
1294 root 1.1
1295 root 1.30 Starting a selection while pressing the B<Meta> key (or B<Meta+Ctrl> keys)
1296 root 1.75 (Compile: I<frills>) will create a rectangular selection instead of a
1297     normal one. In this mode, every selected row becomes its own line in the
1298     selection, and trailing whitespace is visually underlined and removed from
1299     the selection.
1300 root 1.30
1301 root 1.128 =item B<Pasting>:
1302 root 1.1
1303 root 1.103 Pressing and releasing the Middle mouse button in an B<@@RXVT_NAME@@>
1304     window causes the value of the PRIMARY selection (or CLIPBOARD with the
1305 root 1.128 B<Meta> modifier) to be inserted as if it had been typed on the keyboard.
1306 root 1.103
1307     Pressing B<Shift-Insert> causes the value of the PRIMARY selection to be
1308     inserted too.
1309 root 1.1
1310     =back
1311    
1312     =head1 CHANGING FONTS
1313    
1314 root 1.12 Changing fonts (or font sizes, respectively) via the keypad is not yet
1315     supported in rxvt-unicode. Bug me if you need this.
1316    
1317 root 1.97 You can, however, switch fonts at runtime using escape sequences, e.g.:
1318 root 1.12
1319 root 1.72 printf '\e]710;%s\007' "9x15bold,xft:Kochi Gothic"
1320 root 1.12
1321 root 1.97 You can use keyboard shortcuts, too:
1322    
1323     URxvt.keysym.M-C-1: command:\033]710;suxuseuro\007\033]711;suxuseuro\007
1324     URxvt.keysym.M-C-2: command:\033]710;9x15bold\007\033]711;9x15bold\007
1325    
1326 root 1.12 rxvt-unicode will automatically re-apply these fonts to the output so far.
1327 root 1.1
1328 root 1.2 =head1 ISO 14755 SUPPORT
1329    
1330 root 1.12 ISO 14755 is a standard for entering and viewing unicode characters
1331     and character codes using the keyboard. It consists of 4 parts. The
1332 ayin 1.133 first part is available if rxvt-unicode has been compiled with
1333 root 1.12 C<--enable-frills>, the rest is available when rxvt-unicode was compiled
1334     with C<--enable-iso14755>.
1335    
1336     =over 4
1337    
1338 root 1.48 =item * 5.1: Basic method
1339 root 1.12
1340     This allows you to enter unicode characters using their hexcode.
1341 root 1.2
1342 root 1.12 Start by pressing and holding both C<Control> and C<Shift>, then enter
1343     hex-digits (between one and six). Releasing C<Control> and C<Shift> will
1344     commit the character as if it were typed directly. While holding down
1345     C<Control> and C<Shift> you can also enter multiple characters by pressing
1346     C<Space>, which will commit the current character and lets you start a new
1347     one.
1348    
1349     As an example of use, imagine a business card with a japanese e-mail
1350     address, which you cannot type. Fortunately, the card has the e-mail
1351     address printed as hexcodes, e.g. C<671d 65e5>. You can enter this easily
1352     by pressing C<Control> and C<Shift>, followed by C<6-7-1-D-SPACE-6-5-E-5>,
1353     followed by releasing the modifier keys.
1354    
1355 root 1.48 =item * 5.2: Keyboard symbols entry method
1356 root 1.12
1357     This mode lets you input characters representing the keycap symbols of
1358     your keyboard, if representable in the current locale encoding.
1359    
1360     Start by pressing C<Control> and C<Shift> together, then releasing
1361     them. The next special key (cursor keys, home etc.) you enter will not
1362 root 1.114 invoke its usual function but instead will insert the corresponding
1363 root 1.12 keycap symbol. The symbol will only be entered when the key has been
1364     released, otherwise pressing e.g. C<Shift> would enter the symbol for
1365 root 1.30 C<ISO Level 2 Switch>, although your intention might have been to enter a
1366 root 1.12 reverse tab (Shift-Tab).
1367    
1368 root 1.48 =item * 5.3: Screen-selection entry method
1369 root 1.12
1370     While this is implemented already (it's basically the selection
1371     mechanism), it could be extended by displaying a unicode character map.
1372    
1373 root 1.48 =item * 5.4: Feedback method for identifying displayed characters for later input
1374 root 1.12
1375     This method lets you display the unicode character code associated with
1376     characters already displayed.
1377    
1378     You enter this mode by holding down C<Control> and C<Shift> together, then
1379     pressing and holding the left mouse button and moving around. The unicode
1380     hex code(s) (it might be a combining character) of the character under the
1381     pointer is displayed until you release C<Control> and C<Shift>.
1382    
1383 root 1.22 In addition to the hex codes it will display the font used to draw this
1384     character - due to implementation reasons, characters combined with
1385     combining characters, line drawing characters and unknown characters will
1386     always be drawn using the built-in support font.
1387    
1388 root 1.12 =back
1389    
1390     With respect to conformance, rxvt-unicode is supposed to be compliant to
1391     both scenario A and B of ISO 14755, including part 5.2.
1392 root 1.2
1393 root 1.1 =head1 LOGIN STAMP
1394    
1395 root 1.48 B<@@RXVT_NAME@@> tries to write an entry into the I<utmp>(5) file so that
1396     it can be seen via the I<who(1)> command, and can accept messages. To
1397     allow this feature, B<@@RXVT_NAME@@> may need to be installed setuid root
1398     on some systems or setgid to root or to some other group on others.
1399 root 1.1
1400     =head1 COLORS AND GRAPHICS
1401    
1402     In addition to the default foreground and background colours,
1403 root 1.2 B<@@RXVT_NAME@@> can display up to 16 colours (8 ANSI colours plus
1404 root 1.1 high-intensity bold/blink versions of the same). Here is a list of the
1405 root 1.107 colours with their names.
1406 root 1.1
1407     =begin table
1408    
1409     B<color0> (black) = Black
1410     B<color1> (red) = Red3
1411     B<color2> (green) = Green3
1412     B<color3> (yellow) = Yellow3
1413     B<color4> (blue) = Blue3
1414     B<color5> (magenta) = Magenta3
1415     B<color6> (cyan) = Cyan3
1416     B<color7> (white) = AntiqueWhite
1417     B<color8> (bright black) = Grey25
1418     B<color9> (bright red) = Red
1419     B<color10> (bright green) = Green
1420     B<color11> (bright yellow) = Yellow
1421     B<color12> (bright blue) = Blue
1422     B<color13> (bright magenta) = Magenta
1423     B<color14> (bright cyan) = Cyan
1424     B<color15> (bright white) = White
1425     B<foreground> = Black
1426     B<background> = White
1427    
1428     =end table
1429    
1430     It is also possible to specify the colour values of B<foreground>,
1431     B<background>, B<cursorColor>, B<cursorColor2>, B<colorBD>, B<colorUL> as
1432     a number 0-15, as a convenient shorthand to reference the colour name of
1433     color0-color15.
1434    
1435 root 1.112 In addition to the colours defined above, @@RXVT_NAME@@ offers an
1436     additional 72 colours. The first 64 of those (with indices 16 to 79)
1437     consist of a 4*4*4 RGB colour cube (i.e. I<index = r * 16 + g * 4 + b +
1438     16>), followed by 8 additional shades of gray (with indices 80 to 87).
1439    
1440     Together, all those colours implement the 88 colour xterm colours. Only
1441     the first 16 can be changed using resources currently, the rest can only
1442     be changed via command sequences ("escape codes").
1443    
1444 root 1.1 Note that B<-rv> (B<"reverseVideo: True">) simulates reverse video by
1445     always swapping the foreground/background colours. This is in contrast to
1446     I<xterm>(1) where the colours are only swapped if they have not otherwise
1447     been specified. For example,
1448    
1449     =over 4
1450    
1451 root 1.3 =item B<@@RXVT_NAME@@ -fg Black -bg White -rv>
1452 root 1.1
1453     would yield White on Black, while on I<xterm>(1) it would yield Black
1454     on White.
1455    
1456     =back
1457    
1458 root 1.111 =head2 ALPHA CHANNEL SUPPORT
1459    
1460     If Xft support has been compiled in and as long as Xft/Xrender/X don't get
1461     their act together, rxvt-unicode will support C<rgba:rrrr/gggg/bbbb/aaaa>
1462     (recommended, but B<MUST> have 4 digits/component) colour specifications,
1463     in addition to the ones provided by X, where the additional A component
1464     specifies opacity (alpha) values. The minimum value of C<0> is completely
1465 root 1.123 transparent). You can also prefix any color with C<[percent]>, where
1466     C<percent> is a decimal percentage (0-100) that specifies the opacity of
1467     the color, where C<0> is completely transparent and C<100> is completelxy
1468     opaque.
1469 root 1.111
1470     You probably need to specify B<"-depth 32">, too, and have the luck that
1471     your X-server uses ARGB pixel layout, as X is far from just supporting
1472     ARGB visuals out of the box, and rxvt-unicode just fudges around.
1473    
1474     For example, the following selects an almost completely transparent red
1475     background, and an almost opaque pink foreground:
1476    
1477 root 1.123 @@RXVT_NAME@@ -depth 32 -bg rgba:0000/0000/0000/aaaa -fg "[80]pink"
1478 root 1.111
1479     I<Please note that transparency of any kind if completely unsupported by
1480     the author. Don't bug him with installation questions!>
1481    
1482 root 1.5 =head1 ENVIRONMENT
1483    
1484 root 1.53 B<@@RXVT_NAME@@> sets and/or uses the following environment variables:
1485    
1486     =over 4
1487    
1488     =item B<TERM>
1489    
1490     Normally set to C<rxvt-unicode>, unless overwritten at configure time, via
1491 root 1.118 resources or on the command line.
1492 root 1.53
1493     =item B<COLORTERM>
1494    
1495 root 1.118 Either C<rxvt>, C<rxvt-xpm>, depending on whether @@RXVT_NAME@@ was
1496 ayin 1.143 compiled with background image support, and optionally with the added
1497     extension C<-mono> to indicate that rxvt-unicode runs on a monochrome
1498 sasha 1.138 screen.
1499 root 1.53
1500     =item B<COLORFGBG>
1501    
1502     Set to a string of the form C<fg;bg> or C<fg;xpm;bg>, where C<fg> is
1503     the colour code used as default foreground/text colour (or the string
1504     C<default> to indicate that the default-colour escape sequence is to be
1505     used), C<bg> is the colour code used as default background colour (or the
1506     string C<default>), and C<xpm> is the string C<default> if @@RXVT_NAME@@
1507 ayin 1.143 was compiled with background image support. Libraries like C<ncurses>
1508 sasha 1.138 and C<slang> can (and do) use this information to optimize screen output.
1509 root 1.53
1510     =item B<WINDOWID>
1511    
1512     Set to the (decimal) X Window ID of the @@RXVT_NAME@@ window (the toplevel
1513     window, which usually has subwindows for the scrollbar, the terminal
1514     window and so on).
1515    
1516     =item B<TERMINFO>
1517    
1518     Set to the terminfo directory iff @@RXVT_NAME@@ was configured with
1519     C<--with-terminfo=PATH>.
1520    
1521     =item B<DISPLAY>
1522    
1523     Used by @@RXVT_NAME@@ to connect to the display and set to the correct
1524 root 1.114 display in its child processes.
1525 root 1.53
1526     =item B<SHELL>
1527    
1528     The shell to be used for command execution, defaults to C</bin/sh>.
1529    
1530     =item B<RXVT_SOCKET>
1531    
1532     The unix domain socket path used by @@RXVT_NAME@@c(1) and
1533     @@RXVT_NAME@@d(1).
1534    
1535 root 1.67 Default F<<< $HOME/.rxvt-unicode-I<< <nodename >> >>>.
1536 root 1.53
1537     =item B<HOME>
1538    
1539     Used to locate the default directory for the unix domain socket for
1540     daemon communications and to locate various resource files (such as
1541     C<.Xdefaults>)
1542    
1543     =item B<XAPPLRESDIR>
1544    
1545     Directory where various X resource files are being located.
1546    
1547     =item B<XENVIRONMENT>
1548    
1549     If set and accessible, gives the name of a X resource file to be loaded by
1550     @@RXVT_NAME@@.
1551    
1552     =back
1553 root 1.5
1554     =head1 FILES
1555    
1556     =over 4
1557    
1558     =item B</usr/lib/X11/rgb.txt>
1559    
1560     Color names.
1561 root 1.3
1562     =back
1563    
1564     =head1 SEE ALSO
1565 root 1.1
1566 root 1.67 @@RXVT_NAME@@(7), @@RXVT_NAME@@c(1), @@RXVT_NAME@@d(1), xterm(1), sh(1), resize(1), X(1), pty(4), tty(4), utmp(5)
1567 root 1.1
1568     =head1 CURRENT PROJECT COORDINATOR
1569    
1570     =over 4
1571    
1572     =item Project Coordinator
1573    
1574 root 1.55 Marc A. Lehmann L<< <rxvt-unicode@schmorp.de> >>
1575 root 1.1
1576 root 1.113 L<http://software.schmorp.de/pkg/rxvt-unicode.html>
1577 root 1.1
1578     =back
1579    
1580     =head1 AUTHORS
1581    
1582     =over 4
1583    
1584     =item John Bovey
1585    
1586     University of Kent, 1992, wrote the original Xvt.
1587    
1588     =item Rob Nation L<< <nation@rocket.sanders.lockheed.com> >>
1589    
1590     very heavily modified Xvt and came up with Rxvt
1591    
1592     =item Angelo Haritsis L<< <ah@doc.ic.ac.uk> >>
1593    
1594     wrote the Greek Keyboard Input (no longer in code)
1595    
1596     =item mj olesen L<< <olesen@me.QueensU.CA> >>
1597    
1598     Wrote the menu system.
1599    
1600     Project Coordinator (changes.txt 2.11 to 2.21)
1601    
1602     =item Oezguer Kesim L<< <kesim@math.fu-berlin.de> >>
1603    
1604     Project Coordinator (changes.txt 2.21a to 2.4.5)
1605    
1606     =item Geoff Wing L<< <gcw@pobox.com> >>
1607    
1608 root 1.100 Rewrote screen display and text selection routines.
1609 ayin 1.143
1610 root 1.100 Project Coordinator (changes.txt 2.4.6 - rxvt-unicode)
1611 root 1.1
1612 root 1.55 =item Marc Alexander Lehmann L<< <rxvt-unicode@schmorp.de> >>
1613 root 1.1
1614 root 1.100 Forked rxvt-unicode, unicode support, rewrote almost all the code, perl
1615     extension, random hacks, numerous bugfixes and extensions.
1616 root 1.1
1617     Project Coordinator (Changes 1.0 -)
1618    
1619 root 1.100 =item Emanuele Giaquinta L<< <e.giaquinta@glauco.it> >>
1620    
1621 ayin 1.101 Pty/tty/utmp/wtmp rewrite, lots of random hacking and bugfixing.
1622 root 1.100
1623 root 1.1 =back
1624