1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-25 01:02:24 +00:00

Christopher Allene's patch for going full-screen on Alt-Enter.

[originally from svn r1267]
This commit is contained in:
Simon Tatham 2001-09-13 18:24:51 +00:00
parent 6403725639
commit fe43458dad
4 changed files with 48 additions and 5 deletions

View File

@ -287,6 +287,7 @@ typedef struct {
int localecho; int localecho;
int localedit; int localedit;
int alwaysontop; int alwaysontop;
int fullscreenonaltenter;
int scroll_on_key; int scroll_on_key;
int scroll_on_disp; int scroll_on_disp;
int compose_key; int compose_key;

View File

@ -198,6 +198,7 @@ void save_settings(char *section, int do_host, Config * cfg)
write_setting_i(sesskey, "LocalEdit", cfg->localedit); write_setting_i(sesskey, "LocalEdit", cfg->localedit);
write_setting_s(sesskey, "Answerback", cfg->answerback); write_setting_s(sesskey, "Answerback", cfg->answerback);
write_setting_i(sesskey, "AlwaysOnTop", cfg->alwaysontop); write_setting_i(sesskey, "AlwaysOnTop", cfg->alwaysontop);
write_setting_i(sesskey, "FullScreenOnAltEnter", cfg->fullscreenonaltenter);
write_setting_i(sesskey, "HideMousePtr", cfg->hide_mouseptr); write_setting_i(sesskey, "HideMousePtr", cfg->hide_mouseptr);
write_setting_i(sesskey, "SunkenEdge", cfg->sunken_edge); write_setting_i(sesskey, "SunkenEdge", cfg->sunken_edge);
write_setting_i(sesskey, "CurType", cfg->cursor_type); write_setting_i(sesskey, "CurType", cfg->cursor_type);
@ -374,6 +375,7 @@ void load_settings(char *section, int do_host, Config * cfg)
gpps(sesskey, "Answerback", "PuTTY", cfg->answerback, gpps(sesskey, "Answerback", "PuTTY", cfg->answerback,
sizeof(cfg->answerback)); sizeof(cfg->answerback));
gppi(sesskey, "AlwaysOnTop", 0, &cfg->alwaysontop); gppi(sesskey, "AlwaysOnTop", 0, &cfg->alwaysontop);
gppi(sesskey, "FullScreenOnAltEnter", 0, &cfg->fullscreenonaltenter);
gppi(sesskey, "HideMousePtr", 0, &cfg->hide_mouseptr); gppi(sesskey, "HideMousePtr", 0, &cfg->hide_mouseptr);
gppi(sesskey, "SunkenEdge", 0, &cfg->sunken_edge); gppi(sesskey, "SunkenEdge", 0, &cfg->sunken_edge);
gppi(sesskey, "CurType", 0, &cfg->cursor_type); gppi(sesskey, "CurType", 0, &cfg->cursor_type);

View File

@ -365,6 +365,7 @@ enum { IDCX_ABOUT =
IDC_SCROLLKEY, IDC_SCROLLKEY,
IDC_SCROLLDISP, IDC_SCROLLDISP,
IDC_ALWAYSONTOP, IDC_ALWAYSONTOP,
IDC_FULLSCREENONALTENTER,
windowpanelend, windowpanelend,
appearancepanelstart, appearancepanelstart,
@ -625,6 +626,7 @@ static void init_dlg_ctrls(HWND hwnd, int keepsess)
cfg.localedit == LD_YES ? IDC_EDITYES : IDC_EDITNO); cfg.localedit == LD_YES ? IDC_EDITYES : IDC_EDITNO);
SetDlgItemText(hwnd, IDC_ANSWEREDIT, cfg.answerback); SetDlgItemText(hwnd, IDC_ANSWEREDIT, cfg.answerback);
CheckDlgButton(hwnd, IDC_ALWAYSONTOP, cfg.alwaysontop); CheckDlgButton(hwnd, IDC_ALWAYSONTOP, cfg.alwaysontop);
CheckDlgButton(hwnd, IDC_FULLSCREENONALTENTER, cfg.fullscreenonaltenter);
CheckDlgButton(hwnd, IDC_SCROLLKEY, cfg.scroll_on_key); CheckDlgButton(hwnd, IDC_SCROLLKEY, cfg.scroll_on_key);
CheckDlgButton(hwnd, IDC_SCROLLDISP, cfg.scroll_on_disp); CheckDlgButton(hwnd, IDC_SCROLLDISP, cfg.scroll_on_disp);
@ -1026,7 +1028,7 @@ static void create_controls(HWND hwnd, int dlgtype, int panel)
} }
if (panel == windowpanelstart) { if (panel == windowpanelstart) {
/* The Window panel. Accelerators used: [acgo] rmz sdkp w4ylt */ /* The Window panel. Accelerators used: [acgo] rmz sdkp w4ylt f */
struct ctlpos cp; struct ctlpos cp;
ctlposinit(&cp, hwnd, 80, 3, 13); ctlposinit(&cp, hwnd, 80, 3, 13);
bartitle(&cp, "Options controlling PuTTY's window", bartitle(&cp, "Options controlling PuTTY's window",
@ -1052,6 +1054,7 @@ static void create_controls(HWND hwnd, int dlgtype, int panel)
checkbox(&cp, "S&ystem menu appears on ALT-Space", IDC_ALTSPACE); checkbox(&cp, "S&ystem menu appears on ALT-Space", IDC_ALTSPACE);
checkbox(&cp, "System menu appears on A&LT alone", IDC_ALTONLY); checkbox(&cp, "System menu appears on A&LT alone", IDC_ALTONLY);
checkbox(&cp, "Ensure window is always on &top", IDC_ALWAYSONTOP); checkbox(&cp, "Ensure window is always on &top", IDC_ALWAYSONTOP);
checkbox(&cp, "&Full screen on Alt-Enter", IDC_FULLSCREENONALTENTER);
endbox(&cp); endbox(&cp);
} }
@ -1090,14 +1093,14 @@ static void create_controls(HWND hwnd, int dlgtype, int panel)
} }
if (panel == translationpanelstart) { if (panel == translationpanelstart) {
/* The Translation panel. Accelerators used: [acgo] xbep t s */ /* The Translation panel. Accelerators used: [acgo] rxbepu */
struct ctlpos cp; struct ctlpos cp;
ctlposinit(&cp, hwnd, 80, 3, 13); ctlposinit(&cp, hwnd, 80, 3, 13);
bartitle(&cp, "Options controlling character set translation", bartitle(&cp, "Options controlling character set translation",
IDC_TITLE_TRANSLATION); IDC_TITLE_TRANSLATION);
beginbox(&cp, "Character set translation on received data", beginbox(&cp, "Character set translation on received data",
IDC_BOX_TRANSLATION2); IDC_BOX_TRANSLATION2);
combobox(&cp, "Received data assumed to be in which character set:", combobox(&cp, "&Received data assumed to be in which character set:",
IDC_CODEPAGESTATIC, IDC_CODEPAGE); IDC_CODEPAGESTATIC, IDC_CODEPAGE);
endbox(&cp); endbox(&cp);
beginbox(&cp, "Adjust how PuTTY displays line drawing characters", beginbox(&cp, "Adjust how PuTTY displays line drawing characters",
@ -1237,7 +1240,7 @@ static void create_controls(HWND hwnd, int dlgtype, int panel)
} }
if (panel == sshpanelstart) { if (panel == sshpanelstart) {
/* The SSH panel. Accelerators used: [acgo] r pe12i sud */ /* The SSH panel. Accelerators used: [acgo] r pe12i s */
struct ctlpos cp; struct ctlpos cp;
ctlposinit(&cp, hwnd, 80, 3, 13); ctlposinit(&cp, hwnd, 80, 3, 13);
if (dlgtype == 0) { if (dlgtype == 0) {
@ -1846,6 +1849,12 @@ static int GenericMainDlgProc(HWND hwnd, UINT msg,
cfg.alwaysontop = cfg.alwaysontop =
IsDlgButtonChecked(hwnd, IDC_ALWAYSONTOP); IsDlgButtonChecked(hwnd, IDC_ALWAYSONTOP);
break; break;
case IDC_FULLSCREENONALTENTER:
if (HIWORD(wParam) == BN_CLICKED ||
HIWORD(wParam) == BN_DOUBLECLICKED)
cfg.fullscreenonaltenter =
IsDlgButtonChecked(hwnd, IDC_FULLSCREENONALTENTER);
break;
case IDC_SCROLLKEY: case IDC_SCROLLKEY:
if (HIWORD(wParam) == BN_CLICKED || if (HIWORD(wParam) == BN_CLICKED ||
HIWORD(wParam) == BN_DOUBLECLICKED) HIWORD(wParam) == BN_DOUBLECLICKED)

View File

@ -71,13 +71,16 @@ static void init_fonts(int);
static void another_font(int); static void another_font(int);
static void deinit_fonts(void); static void deinit_fonts(void);
static int extra_width, extra_height; static int full_screen = 0, extra_width, extra_height;
static LONG old_wind_style;
static WINDOWPLACEMENT old_wind_placement;
static int pending_netevent = 0; static int pending_netevent = 0;
static WPARAM pend_netevent_wParam = 0; static WPARAM pend_netevent_wParam = 0;
static LPARAM pend_netevent_lParam = 0; static LPARAM pend_netevent_lParam = 0;
static void enact_pending_netevent(void); static void enact_pending_netevent(void);
static void flash_window(int mode); static void flash_window(int mode);
static void flip_full_screen(void);
static time_t last_movement = 0; static time_t last_movement = 0;
@ -2552,6 +2555,10 @@ static int TranslateKey(UINT message, WPARAM wParam, LPARAM lParam,
SendMessage(hwnd, WM_SYSCOMMAND, SC_KEYMENU, 0); SendMessage(hwnd, WM_SYSCOMMAND, SC_KEYMENU, 0);
return -1; return -1;
} }
if (left_alt && wParam == VK_RETURN && cfg.fullscreenonaltenter) {
flip_full_screen();
return -1;
}
/* Control-Numlock for app-keypad mode switch */ /* Control-Numlock for app-keypad mode switch */
if (wParam == VK_PAUSE && shift_state == 2) { if (wParam == VK_PAUSE && shift_state == 2) {
app_keypad_keys ^= 1; app_keypad_keys ^= 1;
@ -3415,3 +3422,27 @@ void beep(int mode)
flash_window(2); /* start */ flash_window(2); /* start */
} }
} }
/*
* Toggle full screen mode. Thanks to cwis@nerim.fr for the
* implementation.
*/
static void flip_full_screen(void)
{
if (!full_screen) {
int cx, cy;
cx = GetSystemMetrics(SM_CXSCREEN);
cy = GetSystemMetrics(SM_CYSCREEN);
GetWindowPlacement(hwnd, &old_wind_placement);
old_wind_style = GetWindowLong(hwnd, GWL_STYLE);
SetWindowLong(hwnd, GWL_STYLE,
old_wind_style & ~(WS_CAPTION | WS_BORDER | WS_THICKFRAME));
SetWindowPos(hwnd, HWND_TOP, 0, 0, cx, cy, SWP_SHOWWINDOW);
full_screen = 1;
} else {
SetWindowLong(hwnd, GWL_STYLE, old_wind_style);
SetWindowPlacement(hwnd,&old_wind_placement);
full_screen = 0;
}
}