mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-10 01:48:00 +00:00
Add UTF-8 flag to the Windows message_box() wrapper.
message_box() previously differed from the real MessageBox API function in that it permitted the user to provide a help context to be used for a Help button in the dialog box. Now it adds a second unusual ability: you can specify that the text and caption strings are in UTF-8 rather than the system code page.
This commit is contained in:
parent
d22ccbac6f
commit
5f43d11f83
@ -531,7 +531,7 @@ static void win_add_keyfile(Filename *filename, bool encrypted)
|
|||||||
}
|
}
|
||||||
|
|
||||||
error:
|
error:
|
||||||
message_box(traywindow, err, APPNAME, MB_OK | MB_ICONERROR,
|
message_box(traywindow, err, APPNAME, MB_OK | MB_ICONERROR, false,
|
||||||
HELPCTXID(errors_cantloadkey));
|
HELPCTXID(errors_cantloadkey));
|
||||||
done:
|
done:
|
||||||
sfree(err);
|
sfree(err);
|
||||||
|
@ -398,8 +398,8 @@ bool request_file(filereq *state, OPENFILENAME *of, bool preserve, bool save);
|
|||||||
filereq *filereq_new(void);
|
filereq *filereq_new(void);
|
||||||
void filereq_free(filereq *state);
|
void filereq_free(filereq *state);
|
||||||
void pgp_fingerprints_msgbox(HWND owner);
|
void pgp_fingerprints_msgbox(HWND owner);
|
||||||
int message_box(HWND owner, LPCTSTR text, LPCTSTR caption,
|
int message_box(HWND owner, LPCTSTR text, LPCTSTR caption, DWORD style,
|
||||||
DWORD style, DWORD helpctxid);
|
bool utf8, DWORD helpctxid);
|
||||||
void MakeDlgItemBorderless(HWND parent, int id);
|
void MakeDlgItemBorderless(HWND parent, int id);
|
||||||
char *GetDlgItemText_alloc(HWND hwnd, int id);
|
char *GetDlgItemText_alloc(HWND hwnd, int id);
|
||||||
void split_into_argv(char *, bool includes_program_name,
|
void split_into_argv(char *, bool includes_program_name,
|
||||||
|
@ -83,7 +83,7 @@ void gui_term_process_cmdline(Conf *conf, char *cmdline)
|
|||||||
s2 = dupprintf("%s Warning", appname);
|
s2 = dupprintf("%s Warning", appname);
|
||||||
if (message_box(NULL, s1, s2,
|
if (message_box(NULL, s1, s2,
|
||||||
MB_YESNO | MB_ICONWARNING | MB_DEFBUTTON2,
|
MB_YESNO | MB_ICONWARNING | MB_DEFBUTTON2,
|
||||||
HELPCTXID(option_cleanup)) == IDYES) {
|
false, HELPCTXID(option_cleanup)) == IDYES) {
|
||||||
cleanup_all();
|
cleanup_all();
|
||||||
}
|
}
|
||||||
sfree(s1);
|
sfree(s1);
|
||||||
|
@ -1139,7 +1139,7 @@ void load_key_file(HWND hwnd, struct MainDlgState *state,
|
|||||||
char *msg = dupprintf("Couldn't load private key (%s)",
|
char *msg = dupprintf("Couldn't load private key (%s)",
|
||||||
key_type_to_str(type));
|
key_type_to_str(type));
|
||||||
message_box(hwnd, msg, "PuTTYgen Error", MB_OK | MB_ICONERROR,
|
message_box(hwnd, msg, "PuTTYgen Error", MB_OK | MB_ICONERROR,
|
||||||
HELPCTXID(errors_cantloadkey));
|
false, HELPCTXID(errors_cantloadkey));
|
||||||
sfree(msg);
|
sfree(msg);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -1202,7 +1202,7 @@ void load_key_file(HWND hwnd, struct MainDlgState *state,
|
|||||||
if (ret == 0) {
|
if (ret == 0) {
|
||||||
char *msg = dupprintf("Couldn't load private key (%s)", errmsg);
|
char *msg = dupprintf("Couldn't load private key (%s)", errmsg);
|
||||||
message_box(hwnd, msg, "PuTTYgen Error", MB_OK | MB_ICONERROR,
|
message_box(hwnd, msg, "PuTTYgen Error", MB_OK | MB_ICONERROR,
|
||||||
HELPCTXID(errors_cantloadkey));
|
false, HELPCTXID(errors_cantloadkey));
|
||||||
sfree(msg);
|
sfree(msg);
|
||||||
} else if (ret == 1) {
|
} else if (ret == 1) {
|
||||||
/*
|
/*
|
||||||
@ -1241,7 +1241,7 @@ void add_certificate(HWND hwnd, struct MainDlgState *state,
|
|||||||
char *msg = dupprintf("Couldn't load certificate (%s)",
|
char *msg = dupprintf("Couldn't load certificate (%s)",
|
||||||
key_type_to_str(type));
|
key_type_to_str(type));
|
||||||
message_box(hwnd, msg, "PuTTYgen Error", MB_OK | MB_ICONERROR,
|
message_box(hwnd, msg, "PuTTYgen Error", MB_OK | MB_ICONERROR,
|
||||||
HELPCTXID(errors_cantloadkey));
|
false, HELPCTXID(errors_cantloadkey));
|
||||||
sfree(msg);
|
sfree(msg);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -1254,7 +1254,7 @@ void add_certificate(HWND hwnd, struct MainDlgState *state,
|
|||||||
&error)) {
|
&error)) {
|
||||||
char *msg = dupprintf("Couldn't load certificate (%s)", error);
|
char *msg = dupprintf("Couldn't load certificate (%s)", error);
|
||||||
message_box(hwnd, msg, "PuTTYgen Error", MB_OK | MB_ICONERROR,
|
message_box(hwnd, msg, "PuTTYgen Error", MB_OK | MB_ICONERROR,
|
||||||
HELPCTXID(errors_cantloadkey));
|
false, HELPCTXID(errors_cantloadkey));
|
||||||
sfree(msg);
|
sfree(msg);
|
||||||
strbuf_free(pub);
|
strbuf_free(pub);
|
||||||
return;
|
return;
|
||||||
@ -1267,7 +1267,7 @@ void add_certificate(HWND hwnd, struct MainDlgState *state,
|
|||||||
char *msg = dupprintf("Couldn't load certificate (unsupported "
|
char *msg = dupprintf("Couldn't load certificate (unsupported "
|
||||||
"algorithm name '%s')", algname);
|
"algorithm name '%s')", algname);
|
||||||
message_box(hwnd, msg, "PuTTYgen Error", MB_OK | MB_ICONERROR,
|
message_box(hwnd, msg, "PuTTYgen Error", MB_OK | MB_ICONERROR,
|
||||||
HELPCTXID(errors_cantloadkey));
|
false, HELPCTXID(errors_cantloadkey));
|
||||||
sfree(msg);
|
sfree(msg);
|
||||||
sfree(algname);
|
sfree(algname);
|
||||||
strbuf_free(pub);
|
strbuf_free(pub);
|
||||||
@ -1295,7 +1295,7 @@ void add_certificate(HWND hwnd, struct MainDlgState *state,
|
|||||||
if (!match) {
|
if (!match) {
|
||||||
char *msg = dupprintf("Certificate is for a different public key");
|
char *msg = dupprintf("Certificate is for a different public key");
|
||||||
message_box(hwnd, msg, "PuTTYgen Error", MB_OK | MB_ICONERROR,
|
message_box(hwnd, msg, "PuTTYgen Error", MB_OK | MB_ICONERROR,
|
||||||
HELPCTXID(errors_cantloadkey));
|
false, HELPCTXID(errors_cantloadkey));
|
||||||
sfree(msg);
|
sfree(msg);
|
||||||
strbuf_free(pub);
|
strbuf_free(pub);
|
||||||
return;
|
return;
|
||||||
@ -1311,7 +1311,7 @@ void add_certificate(HWND hwnd, struct MainDlgState *state,
|
|||||||
if (!newkey) {
|
if (!newkey) {
|
||||||
char *msg = dupprintf("Couldn't combine certificate with key");
|
char *msg = dupprintf("Couldn't combine certificate with key");
|
||||||
message_box(hwnd, msg, "PuTTYgen Error", MB_OK | MB_ICONERROR,
|
message_box(hwnd, msg, "PuTTYgen Error", MB_OK | MB_ICONERROR,
|
||||||
HELPCTXID(errors_cantloadkey));
|
false, HELPCTXID(errors_cantloadkey));
|
||||||
sfree(msg);
|
sfree(msg);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,9 @@
|
|||||||
/*
|
/*
|
||||||
* Message box with optional context help.
|
* Enhanced version of the MessageBox API function. Permits enabling a
|
||||||
|
* Help button by setting helpctxid to a context id in the help file
|
||||||
|
* relevant to this dialog box. Also permits setting the 'utf8' flag
|
||||||
|
* to indicate that the char strings given as 'text' and 'caption' are
|
||||||
|
* encoded in UTF-8 rather than the system code page.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "putty.h"
|
#include "putty.h"
|
||||||
@ -25,10 +29,10 @@ static VOID CALLBACK message_box_help_callback(LPHELPINFO lpHelpInfo)
|
|||||||
launch_help(message_box_owner, context);
|
launch_help(message_box_owner, context);
|
||||||
}
|
}
|
||||||
|
|
||||||
int message_box(HWND owner, LPCTSTR text, LPCTSTR caption,
|
int message_box(HWND owner, LPCTSTR text, LPCTSTR caption, DWORD style,
|
||||||
DWORD style, DWORD helpctxid)
|
bool utf8, DWORD helpctxid)
|
||||||
{
|
{
|
||||||
MSGBOXPARAMS mbox;
|
MSGBOXPARAMSW mbox;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* We use MessageBoxIndirect() because it allows us to specify a
|
* We use MessageBoxIndirect() because it allows us to specify a
|
||||||
@ -37,13 +41,31 @@ int message_box(HWND owner, LPCTSTR text, LPCTSTR caption,
|
|||||||
mbox.cbSize = sizeof(mbox);
|
mbox.cbSize = sizeof(mbox);
|
||||||
/* Assumes the globals `hinst' and `hwnd' have sensible values. */
|
/* Assumes the globals `hinst' and `hwnd' have sensible values. */
|
||||||
mbox.hInstance = hinst;
|
mbox.hInstance = hinst;
|
||||||
mbox.hwndOwner = message_box_owner = owner;
|
|
||||||
mbox.lpfnMsgBoxCallback = &message_box_help_callback;
|
|
||||||
mbox.dwLanguageId = LANG_NEUTRAL;
|
mbox.dwLanguageId = LANG_NEUTRAL;
|
||||||
mbox.lpszText = text;
|
|
||||||
mbox.lpszCaption = caption;
|
mbox.hwndOwner = message_box_owner = owner;
|
||||||
mbox.dwContextHelpId = helpctxid;
|
|
||||||
|
wchar_t *wtext, *wcaption;
|
||||||
|
if (utf8) {
|
||||||
|
wtext = decode_utf8_to_wide_string(text);
|
||||||
|
wcaption = decode_utf8_to_wide_string(caption);
|
||||||
|
} else {
|
||||||
|
wtext = dup_mb_to_wc(DEFAULT_CODEPAGE, 0, text);
|
||||||
|
wcaption = dup_mb_to_wc(DEFAULT_CODEPAGE, 0, caption);
|
||||||
|
}
|
||||||
|
mbox.lpszText = wtext;
|
||||||
|
mbox.lpszCaption = wcaption;
|
||||||
|
|
||||||
mbox.dwStyle = style;
|
mbox.dwStyle = style;
|
||||||
|
|
||||||
|
mbox.dwContextHelpId = helpctxid;
|
||||||
if (helpctxid != 0 && has_help()) mbox.dwStyle |= MB_HELP;
|
if (helpctxid != 0 && has_help()) mbox.dwStyle |= MB_HELP;
|
||||||
return MessageBoxIndirect(&mbox);
|
mbox.lpfnMsgBoxCallback = &message_box_help_callback;
|
||||||
|
|
||||||
|
int toret = MessageBoxIndirectW(&mbox);
|
||||||
|
|
||||||
|
sfree(wtext);
|
||||||
|
sfree(wcaption);
|
||||||
|
|
||||||
|
return toret;
|
||||||
}
|
}
|
||||||
|
@ -21,5 +21,5 @@ void pgp_fingerprints_msgbox(HWND owner)
|
|||||||
", " PGP_PREV_MASTER_KEY_DETAILS "):\n"
|
", " PGP_PREV_MASTER_KEY_DETAILS "):\n"
|
||||||
" " PGP_PREV_MASTER_KEY_FP,
|
" " PGP_PREV_MASTER_KEY_FP,
|
||||||
"PGP fingerprints", MB_ICONINFORMATION | MB_OK,
|
"PGP fingerprints", MB_ICONINFORMATION | MB_OK,
|
||||||
HELPCTXID(pgp_fingerprints));
|
false, HELPCTXID(pgp_fingerprints));
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user