Make the shadow bold offset configurable, after discovering that
[u/mdw/putty] / unix / pterm.1
CommitLineData
d08e9679 1.TH pterm 1
2.UC
3.SH NAME
4pterm \- yet another X terminal emulator
5.SH SYNOPSIS
6\fBpterm\fP [ \fIoptions\fP ]
7.SH DESCRIPTION
8\fIpterm\fP is a terminal emulator for X. It is based on a port of
9the terminal emulation engine in the Windows SSH client PuTTY.
10.SH OPTIONS
11The command-line options supported by \fIpterm\fP are:
12.IP "\fB-e\fP \fIcommand\fP [ \fIarguments\fP ]"
13Specify a command to be executed in the new terminal. Everything on
14the command line after this option will be passed straight to the
15\fIexecvp\fP system call; so if you need the command to redirect its
16input or output, you will have to use \fIsh\fP:
17
18pterm -e sh -c 'mycommand < inputfile'
19.IP "\fB--display\fP \fIdisplay-name\fP"
20Specify the X display on which to open \fIpterm\fP. (Note this
21option has a double minus sign, even though none of the others do.
22This is because this option is supplied automatically by GTK.
23Sorry.)
24.IP "\fB-name\fP \fIfont-name\fP"
25Specify the name under which \fIpterm\fP looks up X resources.
26Normally it will look them up as (for example) \fBpterm.Font\fP. If
27you specify "-name xyz", it will look them up as \fBxyz.Font\fP
28instead. This allows you to set up several different sets of
29defaults and choose between them.
30.IP "\fB-fn\fP \fIfont-name\fP"
31Specify the font to use for normal text displayed in the terminal.
32.IP "\fB-fb\fP \fIfont-name\fP"
33Specify the font to use for bold text displayed in the terminal. If
34the \fIBoldAsColour\fP resource is set to 1 (the default), bold text
35will be displayed in different colours instead of a different font,
36so this option will be ignored. If \fIBoldAsColour\fP is set to 0
37and you do not specify a bold font, \fIpterm\fP will overprint the
38normal font to make it look bolder.
39.IP "\fB-geometry\fP \fIwidth\fPx\fIheight\fP"
40Specify the size of the terminal, in rows and columns of text.
41Unfortunately \fIpterm\fP does not currently support specifying the
42initial position of the window.
43.IP "\fB-sl\fP \fIlines\fP"
44Specify the number of lines of scrollback to save off the top of the
45terminal.
46.IP "\fB-fg\fP \fIcolour\fP"
47Specify the foreground colour to use for normal text.
48.IP "\fB-bg\fP \fIcolour\fP"
49Specify the background colour to use for normal text.
50.IP "\fB-bfg\fP \fIcolour\fP"
51Specify the foreground colour to use for bold text, if the
52\fIBoldAsColour\fP resource is set to 1 (the default).
53.IP "\fB-bbg\fP \fIcolour\fP"
54Specify the foreground colour to use for bold reverse-video text, if
55the \fIBoldAsColour\fP resource is set to 1 (the default). (This
56colour is best thought of as the bold version of the background
57colour; so it only appears when text is displayed \fIin\fP the
58background colour.)
59.IP "\fB-cfg\fP \fIcolour\fP"
60Specify the foreground colour to use for text covered by the cursor.
61.IP "\fB-cbg\fP \fIcolour\fP"
62Specify the background colour to use for text covered by the cursor.
63In other words, this is the main colour of the cursor.
64.IP "\fB-T\fP \fItitle\fP"
65Specify the initial title of the terminal window. (This can be
66changed under control of the server.)
67.IP "\fB-ut-\fP or \fB+ut\fP"
68Tells \fIpterm\fP not to record your login in the \fIutmp\fP,
69\fIwtmp\fP and \fIlastlog\fP system log files; so you will not show
70up on \fIfinger\fP or \fIwho\fP listings, for example.
71.IP "\fB-ut\fP"
72Tells \fIpterm\fP to record your login in \fIutmp\fP, \fIwtmp\fP and
73\fIlastlog\fP: this is the opposite of \fI-ut-\fP. This is the
74default option: you will probably only need to specify it explicitly
75if you have changed the default using the \fIStampUtmp\fP resource.
76.IP "\fB-ls-\fP or \fB+ls\fP"
77Tells \fIpterm\fP not to execute your shell as a login shell.
78.IP "\fB-ls\fP"
79Tells \fIpterm\fP to execute your shell as a login shell: this is
80the opposite of \fI-ls-\fP. This is the default option: you will
81probably only need to specify it explicitly if you have changed the
82default using the \fILoginShell\fP resource.
83.IP "\fB-sb-\fP or \fB+sb\fP"
84Tells \fIpterm\fP not to display a scroll bar.
85.IP "\fB-sb\fP"
86Tells \fIpterm\fP to display a scroll bar: this is the opposite of
87\fI-ls-\fP. This is the default option: you will probably only need
88to specify it explicitly if you have changed the default using the
89\fIScrollBar\fP resource.
90.IP "\fB-log\fP \fIfilename\fP"
91This option makes \fIpterm\fP log all the terminal output to a file
92as well as displaying it in the terminal.
93.IP "\fB-nethack\fP"
94Tells \fIpterm\fP to enable NetHack keypad mode, in which the
95numeric keypad generates the NetHack "hjklyubn" direction keys. This
96enables you to play NetHack with the numeric keypad without having
97to use the NetHack "number_pad" option (which requires you to press
98"n" before any repeat count). So you can move with the numeric
99keypad, and enter repeat counts with the normal number keys.
0ac15bdc 100.IP "\fB-xrm\fP \fIresource-string\fP"
101This option specifies an X resource string. Useful for setting
102resources which do not have their own command-line options. For
103example:
104
105pterm -xrm 'ScrollbarOnLeft: 1'
d08e9679 106.SH X RESOURCES
107\fIpterm\fP can be more completely configured by means of X
108resources. All of these resources are of the form \fIpterm.FOO\fP
109for some FOO; you can make \fIpterm\fP look them up under another
110name, such as \fIxyz.FOO\fP, by specifying the command-line option
111"-name xyz".
112.IP "\fBpterm.TerminalType\fP"
113This controls the value set in the TERM environment variable inside
114the new terminal. The default is "xterm".
115.IP "\fBpterm.BackspaceIsDelete\fP"
116This option should be set to either 0 or 1; the default is 1. When
117set to 0, the ordinary Backspace key generates the Backspace
118character (^H); when set to 1, it generates the Delete character
119(^?). Whichever one you set, the terminal device inside \fIpterm\fP
120will be set up to expect it.
121.IP "\fBpterm.RXVTHomeEnd\fP"
122This option should be set to either 0 or 1; the default is 0. When
123it is set to 1, the Home and End keys generate the control sequences
124they would generate in the \fIrxvt\fP terminal emulator, instead of
125the more usual ones generated by other emulators.
126.IP "\fBpterm.LinuxFunctionKeys\fP"
127This option can be set to any number between 0 and 5 inclusive; the
128default is 0. The modes vary the control sequences sent by the
129function keys; for more complete documentation, it is probably
130simplest to try each option in "pterm -e cat", and press the keys to
131see what they generate.
132.IP "\fBpterm.NoApplicationKeys\fP"
133This option should be set to either 0 or 1; the default is 0. When
134set to 1, it stops the server from ever switching the numeric keypad
135into application mode (where the keys send function-key-like
136sequences instead of numbers or arrow keys). You probably only need
137this if some application is making a nuisance of itself.
138.IP "\fBpterm.NoApplicationCursors\fP"
139This option should be set to either 0 or 1; the default is 0. When
140set to 1, it stops the server from ever switching the cursor keys
141into application mode (where the keys send slightly different
142sequences). You probably only need this if some application is
143making a nuisance of itself.
144.IP "\fBpterm.NoMouseReporting\fP"
145This option should be set to either 0 or 1; the default is 0. When
146set to 1, it stops the server from ever enabling mouse reporting
147mode (where mouse clicks are sent to the application instead of
148controlling cut and paste).
149.IP "\fBpterm.NoRemoteResize\fP"
150This option should be set to either 0 or 1; the default is 0. When
151set to 1, it stops the server from being able to remotely control
152the size of the \fIpterm\fP window.
153.IP "\fBpterm.NoAltScreen\fP"
154This option should be set to either 0 or 1; the default is 0. When
155set to 1, it stops the server from using the "alternate screen"
156terminal feature, which lets full-screen applications leave the
157screen exactly the way they found it.
158.IP "\fBpterm.NoRemoteWinTitle\fP"
159This option should be set to either 0 or 1; the default is 0. When
160set to 1, it stops the server from remotely controlling the title of
161the \fIpterm\fP window.
162.IP "\fBpterm.NoDBackspace\fP"
163This option should be set to either 0 or 1; the default is 0. When
164set to 1, it disables the normal action of the Delete (^?) character
165when sent from the server to the terminal, which is to move the
166cursor left by one space and erase the character now under it.
167.IP "\fBpterm.ApplicationCursorKeys\fP"
168This option should be set to either 0 or 1; the default is 0. When
169set to 1, the default initial state of the cursor keys are
170application mode (where the keys send function-key-like sequences
171instead of numbers or arrow keys). When set to 0, the default state
172is the normal one.
173.IP "\fBpterm.ApplicationKeypad\fP"
174This option should be set to either 0 or 1; the default is 0. When
175set to 1, the default initial state of the numeric keypad is
176application mode (where the keys send function-key-like sequences
177instead of numbers or arrow keys). When set to 0, the default state
178is the normal one.
179.IP "\fBpterm.NetHackKeypad\fP"
180This option should be set to either 0 or 1; the default is 0. When
181set to 1, the numeric keypad operates in NetHack mode. This is
182equivalent to the \fI-nethack\fP command-line option.
183.IP "\fBpterm.Answerback\fP"
184This option controls the string which the terminal sends in response
185to receiving the ^E character ("tell me about yourself"). By default
186this string is "PuTTY".
187.IP "\fBpterm.HideMousePtr\fP"
188This option should be set to either 0 or 1; the default is 0. When
189it is set to 1, the mouse pointer will disappear if it is over the
190\fIpterm\fP window and you press a key. It will reappear as soon as
191you move it.
192.IP "\fBpterm.WindowBorder\fP"
193This option controls the number of pixels of space between the text
194in the \fIpterm\fP window and the window frame. The default is 1.
195You can increase this value, but decreasing it to 0 is not
196recommended because it can cause the window manager's size hints to
197work incorrectly.
198.IP "\fBpterm.CurType\fP"
199This option should be set to either 0, 1 or 2; the default is 0.
200When set to 0, the text cursor displayed in the window is a
201rectangular block. When set to 1, the cursor is an underline; when
202set to 2, it is a vertical line.
203.IP "\fBpterm.BlinkCur\fP"
204This option should be set to either 0 or 1; the default is 0. When
205it is set to 1, the text cursor will blink when the window is active.
206.IP "\fBpterm.Beep\fP"
207This option should be set to either 0 or 2 (yes, 2); the default is
2080. When it is set to 2, \fIpterm\fP will respond to a bell character
209(^G) by flashing the window instead of beeping.
210.IP "\fBpterm.BellOverload\fP"
211This option should be set to either 0 or 1; the default is 0. When
212it is set to 1, \fIpterm\fP will watch out for large numbers of
213bells arriving in a short time and will temporarily disable the bell
214until they stop. The idea is that if you \fIcat\fP a binary file,
215the frantic beeping will mostly be silenced by this feature and will
216not drive you crazy.
217
218The bell overload mode is activated by receiving N bells in time T;
219after a further time S without any bells, overload mode will turn
220itself off again.
221.IP "\fBpterm.BellOverloadN\fP"
222This option counts the number of bell characters which will activate
223bell overload if they are received within a length of time T. The
224default is 5.
225.IP "\fBpterm.BellOverloadT\fP"
226This option specifies the time period in which receiving N or more
227bells will activate bell overload mode. It is measured in
228microseconds, so (for example) set it to 1000000 for one second. The
229default is 2000000 (two seconds).
230.IP "\fBpterm.BellOverloadS\fP"
231This option specifies the time period of silence required to turn
232off bell overload mode. It is measured in microseconds, so (for
233example) set it to 1000000 for one second. The default is 5000000
234(five seconds of silence).
235.IP "\fBpterm.ScrollbackLines\fP"
236This option specifies how many lines of scrollback to save above the
237visible terminal screen. The default is 200. This resource is
238equivalent to the \fI-sl\fP command-line option.
239.IP "\fBpterm.DECOriginMode\fP"
240This option should be set to either 0 or 1; the default is 0. It
241specifies the default state of DEC Origin Mode. (If you don't know
242what that means, you probably don't need to mess with it.)
243.IP "\fBpterm.AutoWrapMode\fP"
244This option should be set to either 0 or 1; the default is 1. It
245specifies the default state of auto wrap mode. When set to 1, very
246long lines will wrap over to the next line on the terminal; when set
247to 0, long lines will be squashed against the right-hand edge of the
248screen.
249.IP "\fBpterm.LFImpliesCR\fP"
250This option should be set to either 0 or 1; the default is 0. When
251set to 1, the terminal will return the cursor to the left side of
252the screen when it receives a line feed character.
253.IP "\fBpterm.WinTitle\fP"
254This resource is the same as the \fI-T\fP command-line option: it
255controls the initial title of the window. The default is "pterm".
256.IP "\fBpterm.TermWidth\fP"
257This resource is the same as the width part of the \fI-geometry\fP
258command-line option: it controls the number of columns of text in
259the window. The default is 80.
260.IP "\fBpterm.TermHeight\fP"
261This resource is the same as the width part of the \fI-geometry\fP
262command-line option: it controls the number of columns of text in
263the window. The defaults is 24.
264.IP "\fBpterm.Font\fP"
265This resource is the same as the \fI-fn\fP command-line option: it
266controls the font used to display normal text. The default is
267"fixed".
268.IP "\fBpterm.BoldFont\fP"
269This resource is the same as the \fI-fb\fP command-line option: it
270controls the font used to display bold text when \fIBoldAsColour\fP
271is turned off. The default is unset (the font will be bolded by
272printing it twice at a one-pixel offset).
12994a99 273.IP "\fBpterm.ShadowBoldOffset\fP"
274This resource can be set to an integer; the default is -1. It
275specifies the offset at which text is overprinted when using "shadow
276bold" mode. The default (-1) means that the text will be printed in
277the normal place, and also one character to the left; this seems to
278work well for most X bitmap fonts, which have a blank line of pixels
279down the left-hand side. For some fonts, you may need to set this to
280+1, so that the text is overprinted one pixel to the right; for
281really large fonts, you may want to set it even higher.
d08e9679 282.IP "\fBpterm.BoldAsColour\fP"
283This option should be set to either 0 or 1; the default is 1. It
284specifies the default state of auto wrap mode. When set to 1, bold
285text is shown by displaying it in a brighter colour; when set to 0,
286bold text is shown by displaying it in a heavier font.
287.IP "\fBpterm.Colour0\fP, \fBpterm.Colour1\fP, ..., \fBpterm.Colour21\fP"
288These options control the various colours used to display text in
289the \fIpterm\fP window. Each one should be specified as a triple of
290decimal numbers giving red, green and blue values: so that black is
291"0,0,0", white is "255,255,255", red is "255,0,0" and so on.
292
293Colours 0 and 1 specify the foreground colour and its bold
294equivalent (the \fI-fg\fP and \fI-bfg\fP command-line options).
295Colours 2 and 3 specify the background colour and its bold
296equivalent (the \fI-bg\fP and \fI-bbg\fP command-line options).
297Colours 4 and 5 specify the text and block colours used for the
298cursor (the \fI-cfg\fP and \fI-cbg\fP command-line options). Each
299even number from 6 to 20 inclusive specifies the colour to be used
300for one of the ANSI primary colour specifications (black, red,
301green, yellow, blue, magenta, cyan, white, in that order); the odd
302numbers from 7 to 21 inclusive specify the bold version of each
303colour, in the same order. The defaults are:
304
305.nf
306pterm.Colour0: 187,187,187
307pterm.Colour1: 255,255,255
308pterm.Colour2: 0,0,0
309pterm.Colour3: 85,85,85
310pterm.Colour4: 0,0,0
311pterm.Colour5: 0,255,0
312pterm.Colour6: 0,0,0
313pterm.Colour7: 85,85,85
314pterm.Colour8: 187,0,0
315pterm.Colour9: 255,85,85
316pterm.Colour10: 0,187,0
317pterm.Colour11: 85,255,85
318pterm.Colour12: 187,187,0
319pterm.Colour13: 255,255,85
320pterm.Colour14: 0,0,187
321pterm.Colour15: 85,85,255
322pterm.Colour16: 187,0,187
323pterm.Colour17: 255,85,255
324pterm.Colour18: 0,187,187
325pterm.Colour19: 85,255,255
326pterm.Colour20: 187,187,187
327pterm.Colour21: 255,255,255
328.fi
329.IP "\fBpterm.RectSelect\fP"
330This option should be set to either 0 or 1; the default is 0. When
331set to 0, dragging the mouse over several lines selects to the end
332of each line and from the beginning of the next; when set to 1,
333dragging the mouse over several lines selects a rectangular region.
334In each case, holding down Alt while dragging gives the other
335behaviour.
336.IP "\fBpterm.MouseOverride\fP"
337This option should be set to either 0 or 1; the default is 1. When
338set to 1, if the application requests mouse tracking (so that mouse
339clicks are sent to it instead of doing selection), holding down
340Shift will revert the mouse to normal selection. When set to 0,
341mouse tracking completely disables selection.
342.IP "\fBpterm.Printer\fP"
343This option is unset by default. If you set it, then
344server-controlled printing is enabled: the server can send control
345sequences to request data to be sent to a printer. That data will be
346piped into the command you specify here; so you might want to set it
347to "lpr", for example, or "lpr -Pmyprinter".
348.IP "\fBpterm.ScrollBar\fP"
349This option should be set to either 0 or 1; the default is 1. When
350set to 0, the scrollbar is hidden (although Shift-PageUp and
351Shift-PageDown still work). This is the same as the \fI-sb\fP
352command-line option.
353.IP "\fBpterm.ScrollbarOnLeft\fP"
354This option should be set to either 0 or 1; the default is 0. When
355set to 1, the scrollbar will be displayed on the left of the
356terminal instead of on the right.
357.IP "\fBpterm.ScrollOnKey\fP"
358This option should be set to either 0 or 1; the default is 0. When
359set to 1, any keypress causes the position of the scrollback to be
360reset to the very bottom.
361.IP "\fBpterm.ScrollOnDisp\fP"
362This option should be set to either 0 or 1; the default is 1. When
363set to 1, any activity in the display causes the position of the
364scrollback to be reset to the very bottom.
365.IP "\fBpterm.BCE\fP"
366This option should be set to either 0 or 1; the default is 1. When
367set to 1, the various control sequences that erase parts of the
368terminal display will erase in whatever the current background
369colour is; when set to 0, they will erase in black always.
370.IP "\fBpterm.BlinkText\fP"
371This option should be set to either 0 or 1; the default is 0. When
372set to 1, text specified as blinking by the server will actually
373blink on and off; when set to 0, \fIpterm\fP will use the less
374distracting approach of making the text's background colour bold.
375.IP "\fBpterm.StampUtmp\fP"
376This option should be set to either 0 or 1; the default is 1. When
377set to 1, \fIpterm\fP will log the login in the various system log
378files. This resource is equivalent to the \fI-ut\fP command-line
379option.
380.IP "\fBpterm.LoginShell\fP"
381This option should be set to either 0 or 1; the default is 1. When
382set to 1, \fIpterm\fP will execute your shell as a login shell. This
383resource is equivalent to the \fI-ls\fP command-line option.
384.SH BUGS
385Most of the X resources have silly names. (Historical reasons from
386PuTTY, mostly.)
387
388Character-set switching and Unicode are not yet supported.