From: Simon Tatham Date: Wed, 9 May 2001 13:03:16 +0000 (+0000) Subject: RDB's alternative way to interpret the window size in Change X-Git-Tag: 0.52~311 X-Git-Url: https://asedeno.scripts.mit.edu/gitweb/?a=commitdiff_plain;h=bc1a43efe86aa18962c93000b7f9e41992c03bd9;p=PuTTY.git RDB's alternative way to interpret the window size in Change Settings: it describes the size of the _unmaximised_ window. Maximisedness is a separate property which Change Settings doesn't affect. So if you change the font while the window is maximised, the terminal size adjusts accordingly. The downside is that you can't read the width and height of a maximised window out of Change Settings. Suggestions that restore this property are welcome. [originally from svn r1102] --- diff --git a/window.c b/window.c index 6eeac941..3618d14b 100644 --- a/window.c +++ b/window.c @@ -1133,6 +1133,7 @@ static LRESULT CALLBACK WndProc(HWND hwnd, UINT message, static int just_reconfigged = FALSE; static int resizing = FALSE; static int need_backend_resize = FALSE; + static int defered_resize = FALSE; switch (message) { case WM_TIMER: @@ -1251,8 +1252,6 @@ static LRESULT CALLBACK WndProc(HWND hwnd, UINT message, strcpy(oldlogfile, cfg.logfilename); oldlogtype = cfg.logtype; - cfg.width = cols; - cfg.height = rows; old_fwidth = font_width; old_fheight = font_height; GetWindowText(hwnd, cfg.wintitle, sizeof(cfg.wintitle)); @@ -1343,6 +1342,7 @@ static LRESULT CALLBACK WndProc(HWND hwnd, UINT message, wr.right - wr.left - cr.right + cr.left; extra_height = wr.bottom - wr.top - cr.bottom + cr.top; + need_setwpos = TRUE; } } @@ -1353,16 +1353,41 @@ static LRESULT CALLBACK WndProc(HWND hwnd, UINT message, cfg.savelines != savelines || cfg.sunken_edge != prev_sunken_edge) need_setwpos = TRUE; - term_size(cfg.height, cfg.width, cfg.savelines); - InvalidateRect(hwnd, NULL, TRUE); - if (need_setwpos) { - force_normal(hwnd); - SetWindowPos(hwnd, NULL, 0, 0, - extra_width + font_width * cfg.width, - extra_height + font_height * cfg.height, - SWP_NOACTIVATE | SWP_NOCOPYBITS | - SWP_NOMOVE | SWP_NOZORDER); + + if (IsZoomed(hwnd)) { + int w, h; + RECT cr; + if (need_setwpos) + defered_resize = TRUE; + + GetClientRect(hwnd, &cr); + w = cr.right - cr.left; + h = cr.bottom - cr.top; + w = w / font_width; + if (w < 1) + w = 1; + h = h / font_height; + if (h < 1) + h = 1; + + term_size(h, w, cfg.savelines); + InvalidateRect(hwnd, NULL, TRUE); + back->size(); + } else { + term_size(cfg.height, cfg.width, cfg.savelines); + InvalidateRect(hwnd, NULL, TRUE); + if (need_setwpos) { + SetWindowPos(hwnd, NULL, 0, 0, + extra_width + font_width * cfg.width, + extra_height + + font_height * cfg.height, + SWP_NOACTIVATE | SWP_NOCOPYBITS | + SWP_NOMOVE | SWP_NOZORDER); + } } + /* Oops */ + if (cfg.locksize && IsZoomed(hwnd)) + force_normal(hwnd); set_title(cfg.wintitle); if (IsIconic(hwnd)) { SetWindowText(hwnd, @@ -1693,11 +1718,22 @@ static LRESULT CALLBACK WndProc(HWND hwnd, UINT message, */ if (!resizing) back->size(); - else + else { need_backend_resize = TRUE; + cfg.height = h; + cfg.width = w; + } just_reconfigged = FALSE; } } + if (wParam == SIZE_RESTORED && defered_resize) { + defered_resize = FALSE; + SetWindowPos(hwnd, NULL, 0, 0, + extra_width + font_width * cfg.width, + extra_height + font_height * cfg.height, + SWP_NOACTIVATE | SWP_NOCOPYBITS | + SWP_NOMOVE | SWP_NOZORDER); + } ignore_size = FALSE; return 0; case WM_VSCROLL: