Fixes for (Backend)->size() changes -- internal declarations didn't include
[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
86f2f4f8 87\fI-sb-\fP. This is the default option: you will probably only need
d08e9679 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.
2cb50250 221
222Bell overload mode is always deactivated by any keypress in the
223terminal. This means it can respond to large unexpected streams of
224data, but does not interfere with ordinary command-line activities
225that generate beeps (such as filename completion).
d08e9679 226.IP "\fBpterm.BellOverloadN\fP"
227This option counts the number of bell characters which will activate
228bell overload if they are received within a length of time T. The
229default is 5.
230.IP "\fBpterm.BellOverloadT\fP"
231This option specifies the time period in which receiving N or more
232bells will activate bell overload mode. It is measured in
233microseconds, so (for example) set it to 1000000 for one second. The
234default is 2000000 (two seconds).
235.IP "\fBpterm.BellOverloadS\fP"
236This option specifies the time period of silence required to turn
237off bell overload mode. It is measured in microseconds, so (for
238example) set it to 1000000 for one second. The default is 5000000
239(five seconds of silence).
240.IP "\fBpterm.ScrollbackLines\fP"
241This option specifies how many lines of scrollback to save above the
242visible terminal screen. The default is 200. This resource is
243equivalent to the \fI-sl\fP command-line option.
244.IP "\fBpterm.DECOriginMode\fP"
245This option should be set to either 0 or 1; the default is 0. It
246specifies the default state of DEC Origin Mode. (If you don't know
247what that means, you probably don't need to mess with it.)
248.IP "\fBpterm.AutoWrapMode\fP"
249This option should be set to either 0 or 1; the default is 1. It
250specifies the default state of auto wrap mode. When set to 1, very
251long lines will wrap over to the next line on the terminal; when set
252to 0, long lines will be squashed against the right-hand edge of the
253screen.
254.IP "\fBpterm.LFImpliesCR\fP"
255This option should be set to either 0 or 1; the default is 0. When
256set to 1, the terminal will return the cursor to the left side of
257the screen when it receives a line feed character.
258.IP "\fBpterm.WinTitle\fP"
259This resource is the same as the \fI-T\fP command-line option: it
260controls the initial title of the window. The default is "pterm".
261.IP "\fBpterm.TermWidth\fP"
262This resource is the same as the width part of the \fI-geometry\fP
263command-line option: it controls the number of columns of text in
264the window. The default is 80.
265.IP "\fBpterm.TermHeight\fP"
266This resource is the same as the width part of the \fI-geometry\fP
267command-line option: it controls the number of columns of text in
268the window. The defaults is 24.
269.IP "\fBpterm.Font\fP"
270This resource is the same as the \fI-fn\fP command-line option: it
271controls the font used to display normal text. The default is
272"fixed".
273.IP "\fBpterm.BoldFont\fP"
274This resource is the same as the \fI-fb\fP command-line option: it
275controls the font used to display bold text when \fIBoldAsColour\fP
276is turned off. The default is unset (the font will be bolded by
277printing it twice at a one-pixel offset).
12994a99 278.IP "\fBpterm.ShadowBoldOffset\fP"
279This resource can be set to an integer; the default is -1. It
280specifies the offset at which text is overprinted when using "shadow
281bold" mode. The default (-1) means that the text will be printed in
282the normal place, and also one character to the left; this seems to
283work well for most X bitmap fonts, which have a blank line of pixels
284down the left-hand side. For some fonts, you may need to set this to
285+1, so that the text is overprinted one pixel to the right; for
286really large fonts, you may want to set it even higher.
d08e9679 287.IP "\fBpterm.BoldAsColour\fP"
288This option should be set to either 0 or 1; the default is 1. It
289specifies the default state of auto wrap mode. When set to 1, bold
290text is shown by displaying it in a brighter colour; when set to 0,
291bold text is shown by displaying it in a heavier font.
292.IP "\fBpterm.Colour0\fP, \fBpterm.Colour1\fP, ..., \fBpterm.Colour21\fP"
293These options control the various colours used to display text in
294the \fIpterm\fP window. Each one should be specified as a triple of
295decimal numbers giving red, green and blue values: so that black is
296"0,0,0", white is "255,255,255", red is "255,0,0" and so on.
297
298Colours 0 and 1 specify the foreground colour and its bold
299equivalent (the \fI-fg\fP and \fI-bfg\fP command-line options).
300Colours 2 and 3 specify the background colour and its bold
301equivalent (the \fI-bg\fP and \fI-bbg\fP command-line options).
302Colours 4 and 5 specify the text and block colours used for the
303cursor (the \fI-cfg\fP and \fI-cbg\fP command-line options). Each
304even number from 6 to 20 inclusive specifies the colour to be used
305for one of the ANSI primary colour specifications (black, red,
306green, yellow, blue, magenta, cyan, white, in that order); the odd
307numbers from 7 to 21 inclusive specify the bold version of each
308colour, in the same order. The defaults are:
309
310.nf
311pterm.Colour0: 187,187,187
312pterm.Colour1: 255,255,255
313pterm.Colour2: 0,0,0
314pterm.Colour3: 85,85,85
315pterm.Colour4: 0,0,0
316pterm.Colour5: 0,255,0
317pterm.Colour6: 0,0,0
318pterm.Colour7: 85,85,85
319pterm.Colour8: 187,0,0
320pterm.Colour9: 255,85,85
321pterm.Colour10: 0,187,0
322pterm.Colour11: 85,255,85
323pterm.Colour12: 187,187,0
324pterm.Colour13: 255,255,85
325pterm.Colour14: 0,0,187
326pterm.Colour15: 85,85,255
327pterm.Colour16: 187,0,187
328pterm.Colour17: 255,85,255
329pterm.Colour18: 0,187,187
330pterm.Colour19: 85,255,255
331pterm.Colour20: 187,187,187
332pterm.Colour21: 255,255,255
333.fi
334.IP "\fBpterm.RectSelect\fP"
335This option should be set to either 0 or 1; the default is 0. When
336set to 0, dragging the mouse over several lines selects to the end
337of each line and from the beginning of the next; when set to 1,
338dragging the mouse over several lines selects a rectangular region.
339In each case, holding down Alt while dragging gives the other
340behaviour.
341.IP "\fBpterm.MouseOverride\fP"
342This option should be set to either 0 or 1; the default is 1. When
343set to 1, if the application requests mouse tracking (so that mouse
344clicks are sent to it instead of doing selection), holding down
345Shift will revert the mouse to normal selection. When set to 0,
346mouse tracking completely disables selection.
347.IP "\fBpterm.Printer\fP"
348This option is unset by default. If you set it, then
349server-controlled printing is enabled: the server can send control
350sequences to request data to be sent to a printer. That data will be
351piped into the command you specify here; so you might want to set it
352to "lpr", for example, or "lpr -Pmyprinter".
353.IP "\fBpterm.ScrollBar\fP"
354This option should be set to either 0 or 1; the default is 1. When
355set to 0, the scrollbar is hidden (although Shift-PageUp and
356Shift-PageDown still work). This is the same as the \fI-sb\fP
357command-line option.
358.IP "\fBpterm.ScrollbarOnLeft\fP"
359This option should be set to either 0 or 1; the default is 0. When
360set to 1, the scrollbar will be displayed on the left of the
361terminal instead of on the right.
362.IP "\fBpterm.ScrollOnKey\fP"
363This option should be set to either 0 or 1; the default is 0. When
364set to 1, any keypress causes the position of the scrollback to be
365reset to the very bottom.
366.IP "\fBpterm.ScrollOnDisp\fP"
367This option should be set to either 0 or 1; the default is 1. When
368set to 1, any activity in the display causes the position of the
369scrollback to be reset to the very bottom.
370.IP "\fBpterm.BCE\fP"
371This option should be set to either 0 or 1; the default is 1. When
372set to 1, the various control sequences that erase parts of the
373terminal display will erase in whatever the current background
374colour is; when set to 0, they will erase in black always.
375.IP "\fBpterm.BlinkText\fP"
376This option should be set to either 0 or 1; the default is 0. When
377set to 1, text specified as blinking by the server will actually
378blink on and off; when set to 0, \fIpterm\fP will use the less
379distracting approach of making the text's background colour bold.
380.IP "\fBpterm.StampUtmp\fP"
381This option should be set to either 0 or 1; the default is 1. When
382set to 1, \fIpterm\fP will log the login in the various system log
383files. This resource is equivalent to the \fI-ut\fP command-line
384option.
385.IP "\fBpterm.LoginShell\fP"
386This option should be set to either 0 or 1; the default is 1. When
387set to 1, \fIpterm\fP will execute your shell as a login shell. This
388resource is equivalent to the \fI-ls\fP command-line option.
389.SH BUGS
390Most of the X resources have silly names. (Historical reasons from
391PuTTY, mostly.)
392
393Character-set switching and Unicode are not yet supported.