X-Git-Url: https://git.distorted.org.uk/u/mdw/putty/blobdiff_plain/f67b4e855de19ce0468b8679566ffe14cf3f29a4..c9def1b8e8960113ab4fd91d0b69d5b422cf339f:/putty.h diff --git a/putty.h b/putty.h index 0ca50aa5..3b2257a0 100644 --- a/putty.h +++ b/putty.h @@ -14,11 +14,19 @@ #define GLOBAL extern #endif +GLOBAL HINSTANCE putty_inst; + #define ATTR_ACTCURS 0x80000000UL /* active cursor (block) */ #define ATTR_PASCURS 0x40000000UL /* passive cursor (box) */ #define ATTR_INVALID 0x20000000UL #define ATTR_WRAPPED 0x10000000UL +#define LATTR_NORM 0x00000000UL +#define LATTR_WIDE 0x01000000UL +#define LATTR_TOP 0x02000000UL +#define LATTR_BOT 0x03000000UL +#define LATTR_MODE 0x03000000UL + #define ATTR_ASCII 0x00000000UL /* normal ASCII charset ESC ( B */ #define ATTR_GBCHR 0x00100000UL /* UK variant charset ESC ( A */ #define ATTR_LINEDRW 0x00200000UL /* line drawing charset ESC ( 0 */ @@ -26,6 +34,7 @@ #define ATTR_BOLD 0x00000100UL #define ATTR_UNDER 0x00000200UL #define ATTR_REVERSE 0x00000400UL +#define ATTR_BLINK 0x00000800UL #define ATTR_FGMASK 0x0000F000UL #define ATTR_BGMASK 0x000F0000UL #define ATTR_FGSHIFT 12 @@ -46,10 +55,11 @@ GLOBAL int rows, cols, savelines; GLOBAL int font_width, font_height; +#define c_write1(_C) do { if (inbuf_head >= INBUF_SIZE) term_out(); \ + inbuf[inbuf_head++] = (_C) ; } while(0) #define INBUF_SIZE 2048 -#define INBUF_MASK (INBUF_SIZE-1) GLOBAL unsigned char inbuf[INBUF_SIZE]; -GLOBAL int inbuf_head, inbuf_reap; +GLOBAL int inbuf_head; #define OUTBUF_SIZE 2048 #define OUTBUF_MASK (OUTBUF_SIZE-1) @@ -58,13 +68,27 @@ GLOBAL int outbuf_head, outbuf_reap; GLOBAL int has_focus; -GLOBAL int app_cursor_keys, app_keypad_keys; +GLOBAL int app_cursor_keys, app_keypad_keys, vt52_mode; +GLOBAL int repeat_off, cr_lf_return; + +GLOBAL int seen_key_event; +GLOBAL int seen_disp_event; + +GLOBAL int session_closed; + +GLOBAL char *logfile; -#define WM_NETEVENT (WM_USER + 1) +/* + * I've just looked in the windows standard headr files for WM_USER, there + * are hundreds of flags defined using the form WM_USER+123 so I've + * renumbered this NETEVENT value and the two in window.c + */ +#define WM_XUSER (WM_USER + 0x2000) +#define WM_NETEVENT (WM_XUSER + 5) typedef enum { TS_AYT, TS_BRK, TS_SYNCH, TS_EC, TS_EL, TS_GA, TS_NOP, TS_ABORT, - TS_AO, TS_IP, TS_SUSP, TS_EOR, TS_EOF + TS_AO, TS_IP, TS_SUSP, TS_EOR, TS_EOF, TS_LECHO, TS_RECHO } Telnet_Special; typedef enum { @@ -89,15 +113,29 @@ typedef struct { GLOBAL Backend *back; +extern struct backend_list { + int protocol; + char *name; + Backend *backend; +} backends[]; + +typedef struct { + void (*send) (char *buf, int len); +} Ldisc; + +GLOBAL Ldisc *ldisc; + typedef struct { /* Basic options */ char host[512]; int port; - enum { PROT_TELNET, PROT_SSH } protocol; + enum { PROT_RAW, PROT_TELNET, PROT_SSH } protocol; int close_on_exit; + int warn_on_close; /* SSH options */ int nopty; - enum { CIPHER_3DES, CIPHER_BLOWFISH } cipher; + enum { CIPHER_3DES, CIPHER_BLOWFISH, CIPHER_DES } cipher; + int try_tis_auth; /* Telnet options */ char termtype[32]; char termspeed[32]; @@ -107,20 +145,31 @@ typedef struct { /* Keyboard options */ int bksp_is_delete; int rxvt_homeend; - int linux_funkeys; + int funky_type; int app_cursor; int app_keypad; + int nethack_keypad; + int alt_f4; /* is it special? */ + int alt_space; /* is it special? */ + int ldisc_term; + int scroll_on_key; /* Terminal options */ int savelines; int dec_om; int wrap_mode; int lfhascr; + int blink_cur; + int beep; + int scrollbar; + int locksize; + int bce; + int blinktext; int win_name_always; int width, height; char font[64]; int fontisbold; int fontheight; - VT_Mode vtmode; + int fontcharset; /* Colour options */ int try_palette; int bold_colour; @@ -128,15 +177,35 @@ typedef struct { /* Selection options */ int mouse_is_xterm; short wordness[256]; + /* translations */ + VT_Mode vtmode; + int xlat_enablekoiwin; + int xlat_88592w1250; + int xlat_capslockcyr; } Config; +/* + * You can compile with -DSSH_DEFAULT to have ssh by default. + */ +#ifndef SSH_DEFAULT +#define DEFAULT_PROTOCOL PROT_TELNET +#define DEFAULT_PORT 23 +#else +#define DEFAULT_PROTOCOL PROT_SSH +#define DEFAULT_PORT 22 +#endif + GLOBAL Config cfg; +GLOBAL int default_protocol; +GLOBAL int default_port; + +struct RSAKey; /* be a little careful of scope */ /* * Exports from window.c. */ -void request_resize (int, int); -void do_text (Context, int, int, char *, int, unsigned long); +void request_resize (int, int, int); +void do_text (Context, int, int, char *, int, unsigned long, int); void set_title (char *); void set_icon (char *); void set_sbar (int, int, int); @@ -148,7 +217,7 @@ void write_clip (void *, int); void get_clip (void **, int *); void optimised_move (int, int, int); void fatalbox (char *, ...); -void beep (void); +void beep (int); #define OPTIMISE_IS_SCROLL 1 /* @@ -165,10 +234,14 @@ void random_save_seed(void); int do_config (void); int do_reconfig (HWND); void do_defaults (char *); -void lognegot (char *); -void shownegot (HWND); +void logevent (char *); +void showeventlog (HWND); void showabout (HWND); -void verify_ssh_host_key(char *host, struct RSAKey *key); +void verify_ssh_host_key(char *host, char *keystr); +void get_sesslist(int allocate); + +GLOBAL int nsessions; +GLOBAL char **sessions; /* * Exports from terminal.c. @@ -185,6 +258,15 @@ void term_mouse (Mouse_Button, Mouse_Action, int, int); void term_deselect (void); void term_update (void); void term_invalidate(void); +void term_blink(int set_cursor); +void term_paste(void); +void term_nopaste(void); + +/* + * Exports from raw.c. + */ + +extern Backend raw_backend; /* * Exports from telnet.c. @@ -199,6 +281,12 @@ extern Backend telnet_backend; extern Backend ssh_backend; /* + * Exports from ldisc.c. + */ + +extern Ldisc ldisc_term, ldisc_simple; + +/* * Exports from sshrand.c. */ @@ -233,6 +321,27 @@ void safefree(void *); extern char ver[]; /* + * Exports from sizetip.c. + */ +void UpdateSizeTip(HWND src, int cx, int cy); +void EnableSizeTip(int bEnable); + +/* + * Exports from xlat.c. + */ +unsigned char xlat_kbd2tty(unsigned char c); +unsigned char xlat_tty2scr(unsigned char c); +unsigned char xlat_latkbd2win(unsigned char c); + +/* + * Exports from mscrypto.c + */ +#ifdef MSCRYPTOAPI +int crypto_startup(); +void crypto_wrapup(); +#endif + +/* * A debug system. */ #ifdef DEBUG