projects
/
u
/
mdw
/
putty
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Localise control IDs in each dialog procedure, for maintainability
[u/mdw/putty]
/
window.c
diff --git
a/window.c
b/window.c
index
4c83e9b
..
fe9d2e9
100644
(file)
--- a/
window.c
+++ b/
window.c
@@
-83,6
+83,8
@@
static RGBTRIPLE defpal[NCOLOURS];
static HWND hwnd;
static HWND hwnd;
+static HBITMAP caretbm;
+
static int dbltime, lasttime, lastact;
static Mouse_Button lastbtn;
static int dbltime, lasttime, lastact;
static Mouse_Button lastbtn;
@@
-383,6
+385,17
@@
int WINAPI WinMain(HINSTANCE inst, HINSTANCE prev, LPSTR cmdline, int show) {
SWP_NOMOVE | SWP_NOREDRAW | SWP_NOZORDER);
/*
SWP_NOMOVE | SWP_NOREDRAW | SWP_NOZORDER);
/*
+ * Set up a caret bitmap, with no content.
+ */
+ {
+ char *bits;
+ int size = (font_width+15)/16 * 2 * font_height;
+ bits = calloc(size, 1);
+ caretbm = CreateBitmap(font_width, font_height, 1, 1, bits);
+ free(bits);
+ }
+
+ /*
* Initialise the scroll bar.
*/
{
* Initialise the scroll bar.
*/
{
@@
-402,7
+415,7
@@
int WINAPI WinMain(HINSTANCE inst, HINSTANCE prev, LPSTR cmdline, int show) {
*/
{
char *error;
*/
{
char *error;
- char msg[1024];
+ char msg[1024]
, *title
;
char *realhost;
error = back->init (hwnd, cfg.host, cfg.port, &realhost);
char *realhost;
error = back->init (hwnd, cfg.host, cfg.port, &realhost);
@@
-412,9
+425,14
@@
int WINAPI WinMain(HINSTANCE inst, HINSTANCE prev, LPSTR cmdline, int show) {
return 0;
}
window_name = icon_name = NULL;
return 0;
}
window_name = icon_name = NULL;
- sprintf(msg, "%s - PuTTY", realhost);
- set_title (msg);
- set_icon (msg);
+ if (*cfg.wintitle) {
+ title = cfg.wintitle;
+ } else {
+ sprintf(msg, "%s - PuTTY", realhost);
+ title = msg;
+ }
+ set_title (title);
+ set_icon (title);
}
session_closed = FALSE;
}
session_closed = FALSE;
@@
-536,9
+554,11
@@
int WINAPI WinMain(HINSTANCE inst, HINSTANCE prev, LPSTR cmdline, int show) {
KillTimer(hwnd, timer_id);
timer_id = 0;
}
KillTimer(hwnd, timer_id);
timer_id = 0;
}
+ HideCaret(hwnd);
if (inbuf_head)
term_out();
term_update();
if (inbuf_head)
term_out();
term_update();
+ ShowCaret(hwnd);
if (!has_focus)
timer_id = SetTimer(hwnd, 1, 2000, NULL);
else if (cfg.blinktext)
if (!has_focus)
timer_id = SetTimer(hwnd, 1, 2000, NULL);
else if (cfg.blinktext)
@@
-990,7
+1010,9
@@
static LRESULT CALLBACK WndProc (HWND hwnd, UINT message,
enact_pending_netevent();
if (inbuf_head)
term_out();
enact_pending_netevent();
if (inbuf_head)
term_out();
+ HideCaret(hwnd);
term_update();
term_update();
+ ShowCaret(hwnd);
return 0;
case WM_CREATE:
break;
return 0;
case WM_CREATE:
break;
@@
-1243,6
+1265,7
@@
static LRESULT CALLBACK WndProc (HWND hwnd, UINT message,
case WM_PAINT:
{
PAINTSTRUCT p;
case WM_PAINT:
{
PAINTSTRUCT p;
+ HideCaret(hwnd);
hdc = BeginPaint (hwnd, &p);
if (pal) {
SelectPalette (hdc, pal, TRUE);
hdc = BeginPaint (hwnd, &p);
if (pal) {
SelectPalette (hdc, pal, TRUE);
@@
-1253,6
+1276,7
@@
static LRESULT CALLBACK WndProc (HWND hwnd, UINT message,
SelectObject (hdc, GetStockObject(SYSTEM_FONT));
SelectObject (hdc, GetStockObject(WHITE_PEN));
EndPaint (hwnd, &p);
SelectObject (hdc, GetStockObject(SYSTEM_FONT));
SelectObject (hdc, GetStockObject(WHITE_PEN));
EndPaint (hwnd, &p);
+ ShowCaret(hwnd);
}
return 0;
case WM_NETEVENT:
}
return 0;
case WM_NETEVENT:
@@
-1269,7
+1293,8
@@
static LRESULT CALLBACK WndProc (HWND hwnd, UINT message,
return 0;
case WM_SETFOCUS:
has_focus = TRUE;
return 0;
case WM_SETFOCUS:
has_focus = TRUE;
- CreateCaret(hwnd, NULL, font_width, font_height);
+ CreateCaret(hwnd, caretbm, 0, 0);
+ ShowCaret(hwnd);
term_out();
term_update();
break;
term_out();
term_update();
break;