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