Now that Buttress can spot duplicate section keywords, it turns out
[sgt/putty] / putty.h
CommitLineData
374330e2 1#ifndef PUTTY_PUTTY_H
2#define PUTTY_PUTTY_H
3
ca20bfcf 4#include <stdio.h> /* for FILENAME_MAX */
5
8df7a775 6#include "network.h"
7
374330e2 8#define PUTTY_REG_POS "Software\\SimonTatham\\PuTTY"
de3df031 9#define PUTTY_REG_PARENT "Software\\SimonTatham"
10#define PUTTY_REG_PARENT_CHILD "PuTTY"
11#define PUTTY_REG_GPARENT "Software"
12#define PUTTY_REG_GPARENT_CHILD "SimonTatham"
374330e2 13
14/*
15 * Global variables. Most modules declare these `extern', but
16 * window.c will do `#define PUTTY_DO_GLOBALS' before including this
17 * module, and so will get them properly defined.
18 */
19#ifdef PUTTY_DO_GLOBALS
20#define GLOBAL
21#else
22#define GLOBAL extern
23#endif
24
4eeb7d09 25/* Three attribute types:
26 * The ATTRs (normal attributes) are stored with the characters in the main
27 * display arrays
28 *
29 * The TATTRs (temporary attributes) are generated on the fly, they can overlap
30 * with characters but not with normal attributes.
31 *
32 * The LATTRs (line attributes) conflict with no others and only have one
33 * value per line. But on area clears the LATTR cells are set to the erase_char
34 * (or DEFAULT_ATTR + 'E')
35 *
36 * ATTR_INVALID is an illegal colour combination.
37 */
38
39#define TATTR_ACTCURS 0x4UL /* active cursor (block) */
40#define TATTR_PASCURS 0x2UL /* passive cursor (box) */
41#define TATTR_RIGHTCURS 0x1UL /* cursor-on-RHS */
374330e2 42
c9def1b8 43#define LATTR_NORM 0x00000000UL
44#define LATTR_WIDE 0x01000000UL
45#define LATTR_TOP 0x02000000UL
46#define LATTR_BOT 0x03000000UL
47#define LATTR_MODE 0x03000000UL
4eeb7d09 48#define LATTR_WRAPPED 0x10000000UL
49
50#define ATTR_INVALID 0x00FF0000UL
51
52/* Like Linux use the F000 page for direct to font. */
53#define ATTR_OEMCP 0x0000F000UL /* OEM Codepage DTF */
54#define ATTR_ACP 0x0000F100UL /* Ansi Codepage DTF */
55
56/* These are internal use overlapping with the UTF-16 surrogates */
57#define ATTR_ASCII 0x0000D800UL /* normal ASCII charset ESC ( B */
58#define ATTR_LINEDRW 0x0000D900UL /* line drawing charset ESC ( 0 */
d3cb5465 59#define ATTR_SCOACS 0x0000DA00UL /* SCO Alternate charset */
4eeb7d09 60#define ATTR_GBCHR 0x0000DB00UL /* UK variant charset ESC ( A */
61#define CSET_MASK 0x0000FF00UL /* Character set mask; MUST be 0xFF00 */
62
63#define DIRECT_CHAR(c) ((c&0xFC00)==0xD800)
64#define DIRECT_FONT(c) ((c&0xFE00)==0xF000)
65
66#define UCSERR (ATTR_LINEDRW|'a') /* UCS Format error character. */
67#define UCSWIDE 0x303F
68
5a73255e 69#define ATTR_NARROW 0x20000000UL
4eeb7d09 70#define ATTR_WIDE 0x10000000UL
71#define ATTR_BOLD 0x01000000UL
72#define ATTR_UNDER 0x02000000UL
73#define ATTR_REVERSE 0x04000000UL
74#define ATTR_BLINK 0x08000000UL
75#define ATTR_FGMASK 0x000F0000UL
76#define ATTR_BGMASK 0x00F00000UL
77#define ATTR_COLOURS 0x00FF0000UL
78#define ATTR_FGSHIFT 16
79#define ATTR_BGSHIFT 20
80
81#define ATTR_DEFAULT 0x00980000UL
82#define ATTR_DEFFG 0x00080000UL
83#define ATTR_DEFBG 0x00900000UL
8f22582c 84#define ERASE_CHAR (ATTR_DEFAULT | ATTR_ASCII | ' ')
374330e2 85#define ATTR_MASK 0xFFFFFF00UL
86#define CHAR_MASK 0x000000FFUL
4eeb7d09 87
88#define ATTR_CUR_AND (~(ATTR_BOLD|ATTR_REVERSE|ATTR_BLINK|ATTR_COLOURS))
89#define ATTR_CUR_XOR 0x00BA0000UL
374330e2 90
91typedef HDC Context;
92#define SEL_NL { 13, 10 }
93
94GLOBAL int rows, cols, savelines;
95
374330e2 96GLOBAL int has_focus;
97
156686ef 98GLOBAL int in_vbell;
286c6b86 99GLOBAL unsigned long vbell_startpoint;
156686ef 100
c9def1b8 101GLOBAL int app_cursor_keys, app_keypad_keys, vt52_mode;
102GLOBAL int repeat_off, cr_lf_return;
374330e2 103
cabfd08c 104GLOBAL int seen_key_event;
105GLOBAL int seen_disp_event;
5a73255e 106GLOBAL int alt_pressed;
cabfd08c 107
d85548fe 108GLOBAL int session_closed;
109
4eeb7d09 110GLOBAL int big_cursor;
111
70133c0e 112GLOBAL char *help_path;
113GLOBAL int help_has_contents;
114
4eeb7d09 115GLOBAL int utf;
116GLOBAL int dbcs_screenfont;
117GLOBAL int font_codepage;
118GLOBAL int kbd_codepage;
119GLOBAL int line_codepage;
d3cb5465 120GLOBAL WCHAR unitab_scoacs[256];
4eeb7d09 121GLOBAL WCHAR unitab_line[256];
122GLOBAL WCHAR unitab_font[256];
123GLOBAL WCHAR unitab_xterm[256];
124GLOBAL WCHAR unitab_oemcp[256];
125GLOBAL unsigned char unitab_ctrl[256];
8f22582c 126#define in_utf (utf || line_codepage==CP_UTF8)
4eeb7d09 127
32874aea 128#define LGXF_OVR 1 /* existing logfile overwrite */
129#define LGXF_APN 0 /* existing logfile append */
130#define LGXF_ASK -1 /* existing logfile ask */
131#define LGTYP_NONE 0 /* logmode: no logging */
132#define LGTYP_ASCII 1 /* logmode: pure ascii */
133#define LGTYP_DEBUG 2 /* logmode: all chars of taffic */
5fd04f07 134GLOBAL char *logfile;
135
e14a5a13 136/*
475eebf9 137 * Window handles for the dialog boxes that can be running during a
138 * PuTTY session.
139 */
140GLOBAL HWND logbox;
141
142/*
e14a5a13 143 * I've just looked in the windows standard headr files for WM_USER, there
144 * are hundreds of flags defined using the form WM_USER+123 so I've
145 * renumbered this NETEVENT value and the two in window.c
146 */
147#define WM_XUSER (WM_USER + 0x2000)
148#define WM_NETEVENT (WM_XUSER + 5)
374330e2 149
150typedef enum {
151 TS_AYT, TS_BRK, TS_SYNCH, TS_EC, TS_EL, TS_GA, TS_NOP, TS_ABORT,
a5f3e637 152 TS_AO, TS_IP, TS_SUSP, TS_EOR, TS_EOF, TS_LECHO, TS_RECHO, TS_PING,
153 TS_EOL
374330e2 154} Telnet_Special;
155
156typedef enum {
01c034ad 157 MBT_NOTHING,
158 MBT_LEFT, MBT_MIDDLE, MBT_RIGHT, /* `raw' button designations */
159 MBT_SELECT, MBT_EXTEND, MBT_PASTE, /* `cooked' button designations */
160 MBT_WHEEL_UP, MBT_WHEEL_DOWN /* mouse wheel */
374330e2 161} Mouse_Button;
162
163typedef enum {
164 MA_NOTHING, MA_CLICK, MA_2CLK, MA_3CLK, MA_DRAG, MA_RELEASE
165} Mouse_Action;
166
167typedef enum {
4eeb7d09 168 VT_XWINDOWS, VT_OEMANSI, VT_OEMONLY, VT_POORMAN, VT_UNICODE
374330e2 169} VT_Mode;
170
0965bee0 171enum {
172 /*
ca20bfcf 173 * SSH ciphers (both SSH1 and SSH2)
174 */
175 CIPHER_WARN, /* pseudo 'cipher' */
176 CIPHER_3DES,
177 CIPHER_BLOWFISH,
178 CIPHER_AES, /* (SSH 2 only) */
7f1ae1d2 179 CIPHER_DES,
ca20bfcf 180 CIPHER_MAX /* no. ciphers (inc warn) */
181};
182
183enum {
184 /*
0965bee0 185 * Line discipline option states: off, on, up to the backend.
186 */
187 LD_YES, LD_NO, LD_BACKEND
188};
189
190enum {
191 /*
192 * Line discipline options which the backend might try to control.
193 */
32874aea 194 LD_EDIT, /* local line editing */
195 LD_ECHO /* local echo */
0965bee0 196};
197
b41069ff 198enum {
199 /*
200 * Close On Exit behaviours. (cfg.close_on_exit)
201 */
32874aea 202 COE_NEVER, /* Never close the window */
203 COE_NORMAL, /* Close window on "normal" (non-error) exits only */
204 COE_ALWAYS /* Always close the window */
b41069ff 205};
206
374330e2 207typedef struct {
2184a5d9 208 char *(*init) (char *host, int port, char **realhost, int nodelay);
5471d09a 209 /* back->send() returns the current amount of buffered data. */
210 int (*send) (char *buf, int len);
211 /* back->sendbuffer() does the same thing but without attempting a send */
212 int (*sendbuffer) (void);
374330e2 213 void (*size) (void);
214 void (*special) (Telnet_Special code);
5471d09a 215 Socket(*socket) (void);
8ccc75b0 216 int (*sendok) (void);
0965bee0 217 int (*ldisc) (int);
5471d09a 218 /*
219 * back->unthrottle() tells the back end that the front end
220 * buffer is clearing.
221 */
222 void (*unthrottle) (int);
97db3be4 223 int default_port;
374330e2 224} Backend;
225
226GLOBAL Backend *back;
227
297d398b 228extern struct backend_list {
89ee5268 229 int protocol;
230 char *name;
231 Backend *backend;
232} backends[];
233
374330e2 234typedef struct {
235 /* Basic options */
236 char host[512];
237 int port;
c91409da 238 enum { PROT_RAW, PROT_TELNET, PROT_RLOGIN, PROT_SSH } protocol;
374330e2 239 int close_on_exit;
9ef49106 240 int warn_on_close;
32874aea 241 int ping_interval; /* in seconds */
2184a5d9 242 int tcp_nodelay;
fef97f43 243 /* SSH options */
6abbf9e3 244 char remote_cmd[512];
fd5e5847 245 char remote_cmd2[512]; /* fallback if the first fails
246 * (used internally for scp) */
32874aea 247 char *remote_cmd_ptr; /* might point to a larger command
248 * but never for loading/saving */
fd5e5847 249 char *remote_cmd_ptr2; /* might point to a larger command
250 * but never for loading/saving */
fef97f43 251 int nopty;
4ba9b64b 252 int compression;
979310f1 253 int agentfwd;
5bb641e1 254 int change_username; /* allow username switching in SSH2 */
ca20bfcf 255 int ssh_cipherlist[CIPHER_MAX];
7cca0d81 256 char keyfile[FILENAME_MAX];
32874aea 257 int sshprot; /* use v1 or v2 when both available */
258 int buggymac; /* MAC bug commmercial <=v2.3.x SSH2 */
cb4d4768 259 int ssh2_des_cbc; /* "des-cbc" nonstandard SSH2 cipher */
ccbfb941 260 int try_tis_auth;
f091e308 261 int try_ki_auth;
4a8fc3c4 262 int ssh_subsys; /* run a subsystem rather than a command */
fd5e5847 263 int ssh_subsys2; /* fallback to go with remote_cmd2 */
374330e2 264 /* Telnet options */
265 char termtype[32];
266 char termspeed[32];
32874aea 267 char environmt[1024]; /* VAR\tvalue\0VAR\tvalue\0\0 */
374330e2 268 char username[32];
c91409da 269 char localusername[32];
374330e2 270 int rfc_environ;
8faa456c 271 int passive_telnet;
374330e2 272 /* Keyboard options */
273 int bksp_is_delete;
274 int rxvt_homeend;
c9def1b8 275 int funky_type;
32874aea 276 int no_applic_c; /* totally disable app cursor keys */
277 int no_applic_k; /* totally disable app keypad */
374330e2 278 int app_cursor;
279 int app_keypad;
c5e9c988 280 int nethack_keypad;
a5f3e637 281 int telnet_keyboard;
c5e9c988 282 int alt_f4; /* is it special? */
283 int alt_space; /* is it special? */
a094ae43 284 int alt_only; /* is it special? */
0965bee0 285 int localecho;
286 int localedit;
e95edc00 287 int alwaysontop;
8f57d753 288 int fullscreenonaltenter;
c9def1b8 289 int scroll_on_key;
a094ae43 290 int scroll_on_disp;
291 int compose_key;
95bbe1ae 292 int ctrlaltkeys;
32874aea 293 char wintitle[256]; /* initial window title */
374330e2 294 /* Terminal options */
295 int savelines;
296 int dec_om;
297 int wrap_mode;
fef97f43 298 int lfhascr;
4e30ff69 299 int cursor_type; /* 0=block 1=underline 2=vertical */
c9def1b8 300 int blink_cur;
03169ad0 301 enum {
302 BELL_DISABLED, BELL_DEFAULT, BELL_VISUAL, BELL_WAVEFILE
303 } beep;
f8a28d1f 304 enum {
305 B_IND_DISABLED, B_IND_FLASH, B_IND_STEADY
306 } beep_ind;
156686ef 307 int bellovl; /* bell overload protection active? */
308 int bellovl_n; /* number of bells to cause overload */
309 int bellovl_t; /* time interval for overload (seconds) */
310 int bellovl_s; /* period of silence to re-enable bell (s) */
03169ad0 311 char bell_wavefile[FILENAME_MAX];
c9def1b8 312 int scrollbar;
a401e5f3 313 int scrollbar_in_fullscreen;
0ed2f48e 314 enum { RESIZE_TERM, RESIZE_DISABLED, RESIZE_FONT, RESIZE_EITHER } resize_action;
c9def1b8 315 int bce;
316 int blinktext;
374330e2 317 int win_name_always;
318 int width, height;
319 char font[64];
320 int fontisbold;
321 int fontheight;
14963b8f 322 int fontcharset;
e1c8e0ed 323 char logfilename[FILENAME_MAX];
324 int logtype;
9f89f96e 325 int logxfovr;
554c540d 326 int hide_mouseptr;
57d08f2f 327 int sunken_edge;
5a73255e 328 int window_border;
e7fbcdd8 329 char answerback[256];
374330e2 330 /* Colour options */
331 int try_palette;
332 int bold_colour;
333 unsigned char colours[22][3];
334 /* Selection options */
335 int mouse_is_xterm;
6908fed7 336 int rect_select;
d3a22f79 337 int rawcnp;
a7419ea4 338 int rtf_paste;
b90840c3 339 int mouse_override;
374330e2 340 short wordness[256];
c9def1b8 341 /* translations */
342 VT_Mode vtmode;
8bb92a1c 343 char line_codepage[128];
a9c02454 344 int xlat_capslockcyr;
9c964e85 345 /* X11 forwarding */
346 int x11_forward;
347 char x11_display[128];
d74d141c 348 /* port forwarding */
349 int lport_acceptall; /* accepts connection from hosts other than localhost */
350 char portfwd[1024]; /* [LR]localport\thost:port\000[LR]localport\thost:port\000\000 */
374330e2 351} Config;
352
e277c42d 353/*
354 * You can compile with -DSSH_DEFAULT to have ssh by default.
355 */
356#ifndef SSH_DEFAULT
357#define DEFAULT_PROTOCOL PROT_TELNET
358#define DEFAULT_PORT 23
359#else
360#define DEFAULT_PROTOCOL PROT_SSH
361#define DEFAULT_PORT 22
362#endif
363
4017be6d 364/*
365 * Some global flags denoting the type of application.
67779be7 366 *
367 * FLAG_VERBOSE is set when the user requests verbose details.
368 *
369 * FLAG_STDERR is set in command-line applications (which have a
370 * functioning stderr that it makes sense to write to) and not in
371 * GUI applications (which don't).
372 *
373 * FLAG_INTERACTIVE is set when a full interactive shell session is
374 * being run, _either_ because no remote command has been provided
375 * _or_ because the application is GUI and can't run non-
376 * interactively.
4017be6d 377 */
67779be7 378#define FLAG_VERBOSE 0x0001
379#define FLAG_STDERR 0x0002
380#define FLAG_INTERACTIVE 0x0004
4017be6d 381GLOBAL int flags;
382
374330e2 383GLOBAL Config cfg;
e277c42d 384GLOBAL int default_protocol;
385GLOBAL int default_port;
374330e2 386
4e23b276 387struct RSAKey; /* be a little careful of scope */
388
374330e2 389/*
390 * Exports from window.c.
391 */
5a73255e 392void request_resize(int, int);
32874aea 393void do_text(Context, int, int, char *, int, unsigned long, int);
4eeb7d09 394void do_cursor(Context, int, int, char *, int, unsigned long, int);
5a73255e 395int CharWidth(Context ctx, int uc);
32874aea 396void set_title(char *);
397void set_icon(char *);
398void set_sbar(int, int, int);
f67b4e85 399Context get_ctx(void);
32874aea 400void free_ctx(Context);
401void palette_set(int, int, int, int);
402void palette_reset(void);
4eeb7d09 403void write_aclip(char *, int, int);
404void write_clip(wchar_t *, int, int);
405void get_clip(wchar_t **, int *);
32874aea 406void optimised_move(int, int, int);
01c034ad 407void set_raw_mouse_mode(int);
408Mouse_Button translate_button(Mouse_Button b);
8d5de777 409void connection_fatal(char *, ...);
32874aea 410void fatalbox(char *, ...);
411void beep(int);
6f34e365 412void begin_session(void);
ec8679e9 413void sys_cursor(int x, int y);
374330e2 414#define OPTIMISE_IS_SCROLL 1
415
68f9b3d9 416void set_iconic(int iconic);
417void move_window(int x, int y);
418void set_zorder(int top);
419void refresh_window(void);
420void set_zoomed(int zoomed);
421int is_iconic(void);
422void get_window_pos(int *x, int *y);
423void get_window_pixels(int *x, int *y);
424char *get_window_title(int icon);
425
374330e2 426/*
427 * Exports from noise.c.
428 */
32874aea 429void noise_get_heavy(void (*func) (void *, int));
430void noise_get_light(void (*func) (void *, int));
7d6ee6ff 431void noise_regular(void);
374330e2 432void noise_ultralight(DWORD data);
433void random_save_seed(void);
de3df031 434void random_destroy_seed(void);
374330e2 435
436/*
437 * Exports from windlg.c.
438 */
8c3cd914 439void defuse_showwindow(void);
32874aea 440int do_config(void);
441int do_reconfig(HWND);
442void do_defaults(char *, Config *);
443void logevent(char *);
444void showeventlog(HWND);
445void showabout(HWND);
d4857987 446void verify_ssh_host_key(char *host, int port, char *keytype,
32874aea 447 char *keystr, char *fingerprint);
ca20bfcf 448void askcipher(char *ciphername, int cs);
e1c8e0ed 449int askappend(char *filename);
de3df031 450void registry_cleanup(void);
3da0b1d2 451void force_normal(HWND hwnd);
0a4aa984 452
7393a137 453GLOBAL int nsessions;
454GLOBAL char **sessions;
374330e2 455
456/*
a9422f39 457 * Exports from settings.c.
458 */
32874aea 459void save_settings(char *section, int do_host, Config * cfg);
460void load_settings(char *section, int do_host, Config * cfg);
a9422f39 461void get_sesslist(int allocate);
462
463/*
374330e2 464 * Exports from terminal.c.
465 */
466
32874aea 467void term_init(void);
468void term_size(int, int, int);
469void term_out(void);
470void term_paint(Context, int, int, int, int);
471void term_scroll(int, int);
472void term_pwron(void);
473void term_clrsb(void);
6908fed7 474void term_mouse(Mouse_Button, Mouse_Action, int, int, int, int, int);
32874aea 475void term_deselect(void);
476void term_update(void);
374330e2 477void term_invalidate(void);
e14a5a13 478void term_blink(int set_cursor);
568dd02f 479void term_do_paste(void);
c9def1b8 480void term_paste(void);
481void term_nopaste(void);
feb7fdfe 482int term_ldisc(int option);
5471d09a 483int from_backend(int is_stderr, char *data, int len);
32874aea 484void logfopen(void);
485void logfclose(void);
bc1235d4 486void term_copyall(void);
374330e2 487
488/*
5e1a8e27 489 * Exports from raw.c.
490 */
491
3d9a14c9 492extern Backend raw_backend;
5e1a8e27 493
494/*
c91409da 495 * Exports from rlogin.c.
496 */
497
498extern Backend rlogin_backend;
499
500/*
374330e2 501 * Exports from telnet.c.
502 */
503
c14776e8 504extern Backend telnet_backend;
374330e2 505
506/*
507 * Exports from ssh.c.
508 */
509
32874aea 510extern int (*ssh_get_line) (const char *prompt, char *str, int maxlen,
511 int is_pw);
c14776e8 512extern Backend ssh_backend;
374330e2 513
514/*
5bc238bb 515 * Exports from ldisc.c.
516 */
517
760e88b2 518extern void ldisc_send(char *buf, int len, int interactive);
5bc238bb 519
520/*
374330e2 521 * Exports from sshrand.c.
522 */
523
524void random_add_noise(void *noise, int length);
525void random_init(void);
526int random_byte(void);
527void random_get_savedata(void **data, int *len);
528
529/*
530 * Exports from misc.c.
531 */
532
db9c0f86 533#include "misc.h"
374330e2 534
535/*
067a15ea 536 * Exports from version.c.
537 */
538extern char ver[];
539
540/*
b73fd1b1 541 * Exports from sizetip.c.
542 */
543void UpdateSizeTip(HWND src, int cx, int cy);
544void EnableSizeTip(int bEnable);
545
546/*
4eeb7d09 547 * Exports from unicode.c.
14963b8f 548 */
4eeb7d09 549#ifndef CP_UTF8
550#define CP_UTF8 65001
551#endif
552void init_ucs_tables(void);
760e88b2 553void lpage_send(int codepage, char *buf, int len, int interactive);
554void luni_send(wchar_t * widebuf, int len, int interactive);
a9c02454 555wchar_t xlat_uskbd2cyrllic(int ch);
4eeb7d09 556int check_compose(int first, int second);
557int decode_codepage(char *cp_name);
875b193f 558char *cp_enumerate (int index);
4eeb7d09 559char *cp_name(int codepage);
a7419ea4 560void get_unitab(int codepage, wchar_t * unitab, int ftype);
14963b8f 561
562/*
8f203108 563 * Exports from mscrypto.c
564 */
565#ifdef MSCRYPTOAPI
566int crypto_startup();
567void crypto_wrapup();
568#endif
569
570/*
5c58ad2d 571 * Exports from pageantc.c
572 */
573void agent_query(void *in, int inlen, void **out, int *outlen);
574int agent_exists(void);
575
4eb24e3a 576/*
577 * Exports from wildcard.c
578 */
579const char *wc_error(int value);
580int wc_match(const char *wildcard, const char *target);
581int wc_unescape(char *output, const char *wildcard);
374330e2 582
583#endif