mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 01:02:24 +00:00
pageant.rc: make a header file of dialog/control ids.
I'm tired of remembering all those fiddly magic numbers and copying them back and forth between the .rc file and the source code. I'm even more tired of having to remember that in the long string of numbers after a dialog item definition, the first one of them _isn't_ one of the position and size coordinates. I've given them all symbolic names, like they should have had all along. I think I originally didn't bother because this was such a small GUI compared to the much larger one in PuTTY proper. But it's growing!
This commit is contained in:
parent
44c084f33f
commit
0f61291f80
31
windows/pageant-rc.h
Executable file
31
windows/pageant-rc.h
Executable file
@ -0,0 +1,31 @@
|
|||||||
|
/*
|
||||||
|
* Constant definitions for the Pageant resource file.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#define IDI_MAINICON 200
|
||||||
|
#define IDI_TRAYICON 201
|
||||||
|
|
||||||
|
#define IDD_KEYLIST 211
|
||||||
|
#define IDD_LOAD_PASSPHRASE 210
|
||||||
|
#define IDD_ONDEMAND_PASSPHRASE 212
|
||||||
|
#define IDD_ABOUT 213
|
||||||
|
#define IDD_LICENCE 214
|
||||||
|
|
||||||
|
#define IDC_PASSPHRASE_STATIC1 100
|
||||||
|
#define IDC_PASSPHRASE_FINGERPRINT 101
|
||||||
|
#define IDC_PASSPHRASE_STATIC2 102
|
||||||
|
#define IDC_PASSPHRASE_EDITBOX 103
|
||||||
|
|
||||||
|
#define IDC_KEYLIST_LISTBOX 100
|
||||||
|
#define IDC_KEYLIST_ADDKEY 101
|
||||||
|
#define IDC_KEYLIST_ADDKEY_ENC 110
|
||||||
|
#define IDC_KEYLIST_REMOVE 102
|
||||||
|
#define IDC_KEYLIST_HELP 103
|
||||||
|
#define IDC_KEYLIST_FPTYPE_STATIC 104
|
||||||
|
#define IDC_KEYLIST_FPTYPE 105
|
||||||
|
|
||||||
|
#define IDC_ABOUT_LICENCE 101
|
||||||
|
#define IDC_ABOUT_WEBSITE 102
|
||||||
|
#define IDC_ABOUT_TEXTBOX 1000
|
||||||
|
|
||||||
|
#define IDC_LICENCE_TEXTBOX 1000
|
@ -7,73 +7,81 @@
|
|||||||
#define APPNAME "Pageant"
|
#define APPNAME "Pageant"
|
||||||
#define APPDESC "PuTTY SSH authentication agent"
|
#define APPDESC "PuTTY SSH authentication agent"
|
||||||
|
|
||||||
|
#include "pageant-rc.h"
|
||||||
|
|
||||||
#include "winhelp.rc2"
|
#include "winhelp.rc2"
|
||||||
|
|
||||||
200 ICON "pageant.ico"
|
IDI_MAINICON ICON "pageant.ico"
|
||||||
201 ICON "pageants.ico"
|
IDI_TRAYICON ICON "pageants.ico"
|
||||||
|
|
||||||
210 DIALOG DISCARDABLE 0, 0, 140, 60
|
IDD_LOAD_PASSPHRASE DIALOG DISCARDABLE 0, 0, 140, 60
|
||||||
STYLE DS_MODALFRAME | WS_POPUP | WS_CAPTION | WS_SYSMENU
|
STYLE DS_MODALFRAME | WS_POPUP | WS_CAPTION | WS_SYSMENU
|
||||||
CAPTION "Pageant: Loading Encrypted Key"
|
CAPTION "Pageant: Loading Encrypted Key"
|
||||||
FONT 8, "MS Shell Dlg"
|
FONT 8, "MS Shell Dlg"
|
||||||
BEGIN
|
BEGIN
|
||||||
CTEXT "Enter passphrase to load key", 100, 10, 6, 120, 8
|
CTEXT "Enter passphrase to load key", IDC_PASSPHRASE_STATIC1, 10, 6, 120, 8
|
||||||
CTEXT "", 101, 10, 16, 120, 8
|
CTEXT "", IDC_PASSPHRASE_FINGERPRINT, 10, 16, 120, 8
|
||||||
EDITTEXT 102, 10, 26, 120, 12, ES_PASSWORD | ES_AUTOHSCROLL
|
EDITTEXT IDC_PASSPHRASE_EDITBOX, 10, 26, 120, 12,
|
||||||
|
ES_PASSWORD | ES_AUTOHSCROLL
|
||||||
DEFPUSHBUTTON "O&K", IDOK, 20, 42, 40, 14
|
DEFPUSHBUTTON "O&K", IDOK, 20, 42, 40, 14
|
||||||
PUSHBUTTON "&Cancel", IDCANCEL, 80, 42, 40, 14
|
PUSHBUTTON "&Cancel", IDCANCEL, 80, 42, 40, 14
|
||||||
END
|
END
|
||||||
|
|
||||||
212 DIALOG DISCARDABLE 0, 0, 250, 70
|
IDD_ONDEMAND_PASSPHRASE DIALOG DISCARDABLE 0, 0, 250, 70
|
||||||
STYLE DS_MODALFRAME | WS_POPUP | WS_CAPTION | WS_SYSMENU
|
STYLE DS_MODALFRAME | WS_POPUP | WS_CAPTION | WS_SYSMENU
|
||||||
CAPTION "Pageant: Decrypting Stored Key"
|
CAPTION "Pageant: Decrypting Stored Key"
|
||||||
FONT 8, "MS Shell Dlg"
|
FONT 8, "MS Shell Dlg"
|
||||||
BEGIN
|
BEGIN
|
||||||
CTEXT "A client of Pageant wants to use the following encrypted key:", 100, 10, 6, 230, 8
|
CTEXT "A client of Pageant wants to use the following encrypted key:",
|
||||||
CTEXT "", 101, 10, 16, 230, 8
|
IDC_PASSPHRASE_STATIC1, 10, 6, 230, 8
|
||||||
CTEXT "If you intended this, enter the passphrase to decrypt the key.", 101, 10, 26, 230, 8
|
CTEXT "", IDC_PASSPHRASE_FINGERPRINT, 10, 16, 230, 8
|
||||||
EDITTEXT 102, 10, 36, 230, 12, ES_PASSWORD | ES_AUTOHSCROLL
|
CTEXT "If you intended this, enter the passphrase to decrypt the key.",
|
||||||
|
IDC_PASSPHRASE_STATIC2, 10, 26, 230, 8
|
||||||
|
EDITTEXT IDC_PASSPHRASE_EDITBOX, 10, 36, 230, 12,
|
||||||
|
ES_PASSWORD | ES_AUTOHSCROLL
|
||||||
DEFPUSHBUTTON "O&K", IDOK, 75, 52, 40, 14
|
DEFPUSHBUTTON "O&K", IDOK, 75, 52, 40, 14
|
||||||
PUSHBUTTON "&Cancel", IDCANCEL, 135, 52, 40, 14
|
PUSHBUTTON "&Cancel", IDCANCEL, 135, 52, 40, 14
|
||||||
END
|
END
|
||||||
|
|
||||||
211 DIALOG DISCARDABLE 0, 0, 450, 211
|
IDD_KEYLIST DIALOG DISCARDABLE 0, 0, 450, 211
|
||||||
STYLE DS_MODALFRAME | WS_POPUP | WS_CAPTION | WS_SYSMENU
|
STYLE DS_MODALFRAME | WS_POPUP | WS_CAPTION | WS_SYSMENU
|
||||||
CAPTION "Pageant Key List"
|
CAPTION "Pageant Key List"
|
||||||
FONT 8, "MS Shell Dlg"
|
FONT 8, "MS Shell Dlg"
|
||||||
BEGIN
|
BEGIN
|
||||||
LISTBOX 100, 10, 10, 420, 155,
|
LISTBOX 100, 10, 10, 420, 155,
|
||||||
LBS_EXTENDEDSEL | LBS_HASSTRINGS | LBS_USETABSTOPS | WS_VSCROLL | WS_TABSTOP
|
LBS_EXTENDEDSEL | LBS_HASSTRINGS | LBS_USETABSTOPS | WS_VSCROLL | WS_TABSTOP
|
||||||
PUSHBUTTON "&Add Key", 101, 75, 187, 60, 14
|
PUSHBUTTON "&Add Key", IDC_KEYLIST_ADDKEY, 75, 187, 60, 14
|
||||||
PUSHBUTTON "Add Key (&encrypted)", 110, 150, 187, 100, 14
|
PUSHBUTTON "Add Key (&encrypted)", IDC_KEYLIST_ADDKEY_ENC, 150, 187, 100, 14
|
||||||
PUSHBUTTON "&Remove Key", 102, 315, 187, 60, 14
|
PUSHBUTTON "&Remove Key", IDC_KEYLIST_REMOVE, 315, 187, 60, 14
|
||||||
PUSHBUTTON "&Help", 103, 10, 187, 50, 14
|
PUSHBUTTON "&Help", IDC_KEYLIST_HELP, 10, 187, 50, 14
|
||||||
DEFPUSHBUTTON "&Close", IDOK, 390, 187, 50, 14
|
DEFPUSHBUTTON "&Close", IDOK, 390, 187, 50, 14
|
||||||
LTEXT "&Fingerprint type:", 104, 10, 172, 60, 8
|
LTEXT "&Fingerprint type:", IDC_KEYLIST_FPTYPE_STATIC, 10, 172, 60, 8
|
||||||
COMBOBOX 105, 70, 170, 60, 12, CBS_DROPDOWNLIST
|
COMBOBOX IDC_KEYLIST_FPTYPE, 70, 170, 60, 12, CBS_DROPDOWNLIST
|
||||||
END
|
END
|
||||||
|
|
||||||
/* Accelerators used: cl */
|
/* Accelerators used: cl */
|
||||||
213 DIALOG DISCARDABLE 140, 40, 270, 136
|
IDD_ABOUT DIALOG DISCARDABLE 140, 40, 270, 136
|
||||||
STYLE DS_MODALFRAME | WS_POPUP | WS_CAPTION | WS_SYSMENU
|
STYLE DS_MODALFRAME | WS_POPUP | WS_CAPTION | WS_SYSMENU
|
||||||
CAPTION "About Pageant"
|
CAPTION "About Pageant"
|
||||||
FONT 8, "MS Shell Dlg"
|
FONT 8, "MS Shell Dlg"
|
||||||
BEGIN
|
BEGIN
|
||||||
DEFPUSHBUTTON "&Close", IDOK, 216, 118, 48, 14
|
DEFPUSHBUTTON "&Close", IDOK, 216, 118, 48, 14
|
||||||
PUSHBUTTON "View &Licence", 101, 6, 118, 70, 14
|
PUSHBUTTON "View &Licence", IDC_ABOUT_LICENCE, 6, 118, 70, 14
|
||||||
PUSHBUTTON "Visit &Web Site", 102, 140, 118, 70, 14
|
PUSHBUTTON "Visit &Web Site", IDC_ABOUT_WEBSITE, 140, 118, 70, 14
|
||||||
EDITTEXT 1000, 10, 6, 250, 110, ES_READONLY | ES_MULTILINE | ES_CENTER, WS_EX_STATICEDGE
|
EDITTEXT IDC_ABOUT_TEXTBOX, 10, 6, 250, 110,
|
||||||
|
ES_READONLY | ES_MULTILINE | ES_CENTER, WS_EX_STATICEDGE
|
||||||
END
|
END
|
||||||
|
|
||||||
/* No accelerators used */
|
/* No accelerators used */
|
||||||
214 DIALOG DISCARDABLE 50, 50, 326, 239
|
IDD_LICENCE DIALOG DISCARDABLE 50, 50, 326, 239
|
||||||
STYLE DS_MODALFRAME | WS_POPUP | WS_CAPTION | WS_SYSMENU
|
STYLE DS_MODALFRAME | WS_POPUP | WS_CAPTION | WS_SYSMENU
|
||||||
CAPTION "PuTTY Licence"
|
CAPTION "PuTTY Licence"
|
||||||
FONT 8, "MS Shell Dlg"
|
FONT 8, "MS Shell Dlg"
|
||||||
BEGIN
|
BEGIN
|
||||||
DEFPUSHBUTTON "OK", IDOK, 148, 219, 44, 14
|
DEFPUSHBUTTON "OK", IDOK, 148, 219, 44, 14
|
||||||
|
|
||||||
EDITTEXT 1000, 10, 10, 306, 200, ES_READONLY | ES_MULTILINE | ES_LEFT, WS_EX_STATICEDGE
|
EDITTEXT IDC_LICENCE_TEXTBOX, 10, 10, 306, 200,
|
||||||
|
ES_READONLY | ES_MULTILINE | ES_LEFT, WS_EX_STATICEDGE
|
||||||
END
|
END
|
||||||
|
|
||||||
#include "version.rc2"
|
#include "version.rc2"
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
#include "wincapi.h"
|
#include "wincapi.h"
|
||||||
#include "pageant.h"
|
#include "pageant.h"
|
||||||
#include "licence.h"
|
#include "licence.h"
|
||||||
|
#include "pageant-rc.h"
|
||||||
|
|
||||||
#include <shellapi.h>
|
#include <shellapi.h>
|
||||||
|
|
||||||
@ -28,9 +29,6 @@
|
|||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define IDI_MAINICON 200
|
|
||||||
#define IDI_TRAYICON 201
|
|
||||||
|
|
||||||
#define WM_SYSTRAY (WM_APP + 6)
|
#define WM_SYSTRAY (WM_APP + 6)
|
||||||
#define WM_SYSTRAY2 (WM_APP + 7)
|
#define WM_SYSTRAY2 (WM_APP + 7)
|
||||||
|
|
||||||
@ -113,7 +111,7 @@ static INT_PTR CALLBACK LicenceProc(HWND hwnd, UINT msg,
|
|||||||
{
|
{
|
||||||
switch (msg) {
|
switch (msg) {
|
||||||
case WM_INITDIALOG:
|
case WM_INITDIALOG:
|
||||||
SetDlgItemText(hwnd, 1000, LICENCE_TEXT("\r\n\r\n"));
|
SetDlgItemText(hwnd, IDC_LICENCE_TEXTBOX, LICENCE_TEXT("\r\n\r\n"));
|
||||||
return 1;
|
return 1;
|
||||||
case WM_COMMAND:
|
case WM_COMMAND:
|
||||||
switch (LOWORD(wParam)) {
|
switch (LOWORD(wParam)) {
|
||||||
@ -144,7 +142,7 @@ static INT_PTR CALLBACK AboutProc(HWND hwnd, UINT msg,
|
|||||||
ver, buildinfo_text,
|
ver, buildinfo_text,
|
||||||
"\251 " SHORT_COPYRIGHT_DETAILS ". All rights reserved.");
|
"\251 " SHORT_COPYRIGHT_DETAILS ". All rights reserved.");
|
||||||
sfree(buildinfo_text);
|
sfree(buildinfo_text);
|
||||||
SetDlgItemText(hwnd, 1000, text);
|
SetDlgItemText(hwnd, IDC_ABOUT_TEXTBOX, text);
|
||||||
sfree(text);
|
sfree(text);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
@ -155,13 +153,13 @@ static INT_PTR CALLBACK AboutProc(HWND hwnd, UINT msg,
|
|||||||
aboutbox = NULL;
|
aboutbox = NULL;
|
||||||
DestroyWindow(hwnd);
|
DestroyWindow(hwnd);
|
||||||
return 0;
|
return 0;
|
||||||
case 101:
|
case IDC_ABOUT_LICENCE:
|
||||||
EnableWindow(hwnd, 0);
|
EnableWindow(hwnd, 0);
|
||||||
DialogBox(hinst, MAKEINTRESOURCE(214), hwnd, LicenceProc);
|
DialogBox(hinst, MAKEINTRESOURCE(IDD_LICENCE), hwnd, LicenceProc);
|
||||||
EnableWindow(hwnd, 1);
|
EnableWindow(hwnd, 1);
|
||||||
SetActiveWindow(hwnd);
|
SetActiveWindow(hwnd);
|
||||||
return 0;
|
return 0;
|
||||||
case 102:
|
case IDC_ABOUT_WEBSITE:
|
||||||
/* Load web browser */
|
/* Load web browser */
|
||||||
ShellExecute(hwnd, "open",
|
ShellExecute(hwnd, "open",
|
||||||
"https://www.chiark.greenend.org.uk/~sgtatham/putty/",
|
"https://www.chiark.greenend.org.uk/~sgtatham/putty/",
|
||||||
@ -242,10 +240,10 @@ static INT_PTR CALLBACK PassphraseProc(HWND hwnd, UINT msg,
|
|||||||
if (!p->modal)
|
if (!p->modal)
|
||||||
SetActiveWindow(hwnd); /* this won't have happened automatically */
|
SetActiveWindow(hwnd); /* this won't have happened automatically */
|
||||||
if (p->comment)
|
if (p->comment)
|
||||||
SetDlgItemText(hwnd, 101, p->comment);
|
SetDlgItemText(hwnd, IDC_PASSPHRASE_FINGERPRINT, p->comment);
|
||||||
burnstr(p->passphrase);
|
burnstr(p->passphrase);
|
||||||
p->passphrase = dupstr("");
|
p->passphrase = dupstr("");
|
||||||
SetDlgItemText(hwnd, 102, p->passphrase);
|
SetDlgItemText(hwnd, IDC_PASSPHRASE_EDITBOX, p->passphrase);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
case WM_COMMAND:
|
case WM_COMMAND:
|
||||||
@ -259,10 +257,11 @@ static INT_PTR CALLBACK PassphraseProc(HWND hwnd, UINT msg,
|
|||||||
case IDCANCEL:
|
case IDCANCEL:
|
||||||
end_passphrase_dialog(hwnd, 0);
|
end_passphrase_dialog(hwnd, 0);
|
||||||
return 0;
|
return 0;
|
||||||
case 102: /* edit box */
|
case IDC_PASSPHRASE_EDITBOX:
|
||||||
if ((HIWORD(wParam) == EN_CHANGE) && p->passphrase) {
|
if ((HIWORD(wParam) == EN_CHANGE) && p->passphrase) {
|
||||||
burnstr(p->passphrase);
|
burnstr(p->passphrase);
|
||||||
p->passphrase = GetDlgItemText_alloc(hwnd, 102);
|
p->passphrase = GetDlgItemText_alloc(
|
||||||
|
hwnd, IDC_PASSPHRASE_EDITBOX);
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -369,7 +368,8 @@ static void keylist_update_callback(
|
|||||||
else if (ext_flags & LIST_EXTENDED_FLAG_HAS_ENCRYPTED_KEY_FILE)
|
else if (ext_flags & LIST_EXTENDED_FLAG_HAS_ENCRYPTED_KEY_FILE)
|
||||||
strbuf_catf(listentry, "\t(re-encryptable)");
|
strbuf_catf(listentry, "\t(re-encryptable)");
|
||||||
|
|
||||||
SendDlgItemMessage(keylist, 100, LB_ADDSTRING, 0, (LPARAM)listentry->s);
|
SendDlgItemMessage(keylist, IDC_KEYLIST_LISTBOX,
|
||||||
|
LB_ADDSTRING, 0, (LPARAM)listentry->s);
|
||||||
strbuf_free(listentry);
|
strbuf_free(listentry);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -379,14 +379,16 @@ static void keylist_update_callback(
|
|||||||
void keylist_update(void)
|
void keylist_update(void)
|
||||||
{
|
{
|
||||||
if (keylist) {
|
if (keylist) {
|
||||||
SendDlgItemMessage(keylist, 100, LB_RESETCONTENT, 0, 0);
|
SendDlgItemMessage(keylist, IDC_KEYLIST_LISTBOX,
|
||||||
|
LB_RESETCONTENT, 0, 0);
|
||||||
|
|
||||||
char *errmsg;
|
char *errmsg;
|
||||||
int status = pageant_enum_keys(keylist_update_callback, NULL, &errmsg);
|
int status = pageant_enum_keys(keylist_update_callback, NULL, &errmsg);
|
||||||
assert(status == PAGEANT_ACTION_OK);
|
assert(status == PAGEANT_ACTION_OK);
|
||||||
assert(!errmsg);
|
assert(!errmsg);
|
||||||
|
|
||||||
SendDlgItemMessage(keylist, 100, LB_SETCURSEL, (WPARAM) - 1, 0);
|
SendDlgItemMessage(keylist, IDC_KEYLIST_LISTBOX,
|
||||||
|
LB_SETCURSEL, (WPARAM) - 1, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -418,7 +420,8 @@ static void win_add_keyfile(Filename *filename, bool encrypted)
|
|||||||
pps.dlgid = NULL;
|
pps.dlgid = NULL;
|
||||||
pps.passphrase = NULL;
|
pps.passphrase = NULL;
|
||||||
pps.comment = err;
|
pps.comment = err;
|
||||||
dlgret = DialogBoxParam(hinst, MAKEINTRESOURCE(210),
|
dlgret = DialogBoxParam(
|
||||||
|
hinst, MAKEINTRESOURCE(IDD_LOAD_PASSPHRASE),
|
||||||
NULL, PassphraseProc, (LPARAM) &pps);
|
NULL, PassphraseProc, (LPARAM) &pps);
|
||||||
modal_passphrase_hwnd = NULL;
|
modal_passphrase_hwnd = NULL;
|
||||||
|
|
||||||
@ -533,7 +536,7 @@ static INT_PTR CALLBACK KeyListProc(HWND hwnd, UINT msg,
|
|||||||
GetWindowLongPtr(hwnd, GWL_EXSTYLE) |
|
GetWindowLongPtr(hwnd, GWL_EXSTYLE) |
|
||||||
WS_EX_CONTEXTHELP);
|
WS_EX_CONTEXTHELP);
|
||||||
else {
|
else {
|
||||||
HWND item = GetDlgItem(hwnd, 103); /* the Help button */
|
HWND item = GetDlgItem(hwnd, IDC_KEYLIST_HELP);
|
||||||
if (item)
|
if (item)
|
||||||
DestroyWindow(item);
|
DestroyWindow(item);
|
||||||
}
|
}
|
||||||
@ -541,19 +544,20 @@ static INT_PTR CALLBACK KeyListProc(HWND hwnd, UINT msg,
|
|||||||
keylist = hwnd;
|
keylist = hwnd;
|
||||||
{
|
{
|
||||||
static int tabs[] = { 35, 75, 300 };
|
static int tabs[] = { 35, 75, 300 };
|
||||||
SendDlgItemMessage(hwnd, 100, LB_SETTABSTOPS,
|
SendDlgItemMessage(hwnd, IDC_KEYLIST_LISTBOX, LB_SETTABSTOPS,
|
||||||
sizeof(tabs) / sizeof(*tabs),
|
sizeof(tabs) / sizeof(*tabs),
|
||||||
(LPARAM) tabs);
|
(LPARAM) tabs);
|
||||||
}
|
}
|
||||||
|
|
||||||
int selection = 0;
|
int selection = 0;
|
||||||
for (size_t i = 0; i < lenof(fptypes); i++) {
|
for (size_t i = 0; i < lenof(fptypes); i++) {
|
||||||
SendDlgItemMessage(hwnd, 105, CB_ADDSTRING,
|
SendDlgItemMessage(hwnd, IDC_KEYLIST_FPTYPE, CB_ADDSTRING,
|
||||||
0, (LPARAM)fptypes[i].name);
|
0, (LPARAM)fptypes[i].name);
|
||||||
if (fptype == fptypes[i].value)
|
if (fptype == fptypes[i].value)
|
||||||
selection = (int)i;
|
selection = (int)i;
|
||||||
}
|
}
|
||||||
SendDlgItemMessage(hwnd, 105, CB_SETCURSEL, 0, selection);
|
SendDlgItemMessage(hwnd, IDC_KEYLIST_FPTYPE,
|
||||||
|
CB_SETCURSEL, 0, selection);
|
||||||
|
|
||||||
keylist_update();
|
keylist_update();
|
||||||
return 0;
|
return 0;
|
||||||
@ -565,8 +569,8 @@ static INT_PTR CALLBACK KeyListProc(HWND hwnd, UINT msg,
|
|||||||
keylist = NULL;
|
keylist = NULL;
|
||||||
DestroyWindow(hwnd);
|
DestroyWindow(hwnd);
|
||||||
return 0;
|
return 0;
|
||||||
case 101: /* add key */
|
case IDC_KEYLIST_ADDKEY:
|
||||||
case 110: /* add key encrypted */
|
case IDC_KEYLIST_ADDKEY_ENC:
|
||||||
if (HIWORD(wParam) == BN_CLICKED ||
|
if (HIWORD(wParam) == BN_CLICKED ||
|
||||||
HIWORD(wParam) == BN_DOUBLECLICKED) {
|
HIWORD(wParam) == BN_DOUBLECLICKED) {
|
||||||
if (modal_passphrase_hwnd) {
|
if (modal_passphrase_hwnd) {
|
||||||
@ -574,10 +578,10 @@ static INT_PTR CALLBACK KeyListProc(HWND hwnd, UINT msg,
|
|||||||
SetForegroundWindow(modal_passphrase_hwnd);
|
SetForegroundWindow(modal_passphrase_hwnd);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
prompt_add_keyfile(LOWORD(wParam) == 110);
|
prompt_add_keyfile(LOWORD(wParam) == IDC_KEYLIST_ADDKEY_ENC);
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
case 102: /* remove key */
|
case IDC_KEYLIST_REMOVE:
|
||||||
if (HIWORD(wParam) == BN_CLICKED ||
|
if (HIWORD(wParam) == BN_CLICKED ||
|
||||||
HIWORD(wParam) == BN_DOUBLECLICKED) {
|
HIWORD(wParam) == BN_DOUBLECLICKED) {
|
||||||
int i;
|
int i;
|
||||||
@ -588,8 +592,8 @@ static INT_PTR CALLBACK KeyListProc(HWND hwnd, UINT msg,
|
|||||||
int itemNum;
|
int itemNum;
|
||||||
|
|
||||||
/* get the number of items selected in the list */
|
/* get the number of items selected in the list */
|
||||||
int numSelected =
|
int numSelected = SendDlgItemMessage(
|
||||||
SendDlgItemMessage(hwnd, 100, LB_GETSELCOUNT, 0, 0);
|
hwnd, IDC_KEYLIST_LISTBOX, LB_GETSELCOUNT, 0, 0);
|
||||||
|
|
||||||
/* none selected? that was silly */
|
/* none selected? that was silly */
|
||||||
if (numSelected == 0) {
|
if (numSelected == 0) {
|
||||||
@ -599,7 +603,7 @@ static INT_PTR CALLBACK KeyListProc(HWND hwnd, UINT msg,
|
|||||||
|
|
||||||
/* get item indices in an array */
|
/* get item indices in an array */
|
||||||
selectedArray = snewn(numSelected, int);
|
selectedArray = snewn(numSelected, int);
|
||||||
SendDlgItemMessage(hwnd, 100, LB_GETSELITEMS,
|
SendDlgItemMessage(hwnd, IDC_KEYLIST_LISTBOX, LB_GETSELITEMS,
|
||||||
numSelected, (WPARAM)selectedArray);
|
numSelected, (WPARAM)selectedArray);
|
||||||
|
|
||||||
itemNum = numSelected - 1;
|
itemNum = numSelected - 1;
|
||||||
@ -630,16 +634,16 @@ static INT_PTR CALLBACK KeyListProc(HWND hwnd, UINT msg,
|
|||||||
keylist_update();
|
keylist_update();
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
case 103: /* help */
|
case IDC_KEYLIST_HELP:
|
||||||
if (HIWORD(wParam) == BN_CLICKED ||
|
if (HIWORD(wParam) == BN_CLICKED ||
|
||||||
HIWORD(wParam) == BN_DOUBLECLICKED) {
|
HIWORD(wParam) == BN_DOUBLECLICKED) {
|
||||||
launch_help(hwnd, WINHELP_CTX_pageant_general);
|
launch_help(hwnd, WINHELP_CTX_pageant_general);
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
case 105: /* fingerprint type */
|
case IDC_KEYLIST_FPTYPE:
|
||||||
if (HIWORD(wParam) == CBN_SELCHANGE) {
|
if (HIWORD(wParam) == CBN_SELCHANGE) {
|
||||||
int selection = SendDlgItemMessage(
|
int selection = SendDlgItemMessage(
|
||||||
hwnd, 105, CB_GETCURSEL, 0, 0);
|
hwnd, IDC_KEYLIST_FPTYPE, CB_GETCURSEL, 0, 0);
|
||||||
if (selection >= 0 && (size_t)selection < lenof(fptypes)) {
|
if (selection >= 0 && (size_t)selection < lenof(fptypes)) {
|
||||||
fptype = fptypes[selection].value;
|
fptype = fptypes[selection].value;
|
||||||
keylist_update();
|
keylist_update();
|
||||||
@ -652,9 +656,9 @@ static INT_PTR CALLBACK KeyListProc(HWND hwnd, UINT msg,
|
|||||||
int id = ((LPHELPINFO)lParam)->iCtrlId;
|
int id = ((LPHELPINFO)lParam)->iCtrlId;
|
||||||
const char *topic = NULL;
|
const char *topic = NULL;
|
||||||
switch (id) {
|
switch (id) {
|
||||||
case 100: topic = WINHELP_CTX_pageant_keylist; break;
|
case IDC_KEYLIST_LISTBOX: topic = WINHELP_CTX_pageant_keylist; break;
|
||||||
case 101: topic = WINHELP_CTX_pageant_addkey; break;
|
case IDC_KEYLIST_ADDKEY: topic = WINHELP_CTX_pageant_addkey; break;
|
||||||
case 102: topic = WINHELP_CTX_pageant_remkey; break;
|
case IDC_KEYLIST_REMOVE: topic = WINHELP_CTX_pageant_remkey; break;
|
||||||
}
|
}
|
||||||
if (topic) {
|
if (topic) {
|
||||||
launch_help(hwnd, topic);
|
launch_help(hwnd, topic);
|
||||||
@ -846,7 +850,8 @@ static bool ask_passphrase_common(PageantClientDialogId *dlgid,
|
|||||||
pps->comment = comment;
|
pps->comment = comment;
|
||||||
|
|
||||||
nonmodal_passphrase_hwnd = CreateDialogParam(
|
nonmodal_passphrase_hwnd = CreateDialogParam(
|
||||||
hinst, MAKEINTRESOURCE(212), NULL, PassphraseProc, (LPARAM)pps);
|
hinst, MAKEINTRESOURCE(IDD_ONDEMAND_PASSPHRASE),
|
||||||
|
NULL, PassphraseProc, (LPARAM)pps);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Try to put this passphrase prompt into the foreground.
|
* Try to put this passphrase prompt into the foreground.
|
||||||
@ -1060,7 +1065,8 @@ static void create_keylist_window(void)
|
|||||||
if (keylist)
|
if (keylist)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
keylist = CreateDialog(hinst, MAKEINTRESOURCE(211), NULL, KeyListProc);
|
keylist = CreateDialog(hinst, MAKEINTRESOURCE(IDD_KEYLIST),
|
||||||
|
NULL, KeyListProc);
|
||||||
ShowWindow(keylist, SW_SHOWNORMAL);
|
ShowWindow(keylist, SW_SHOWNORMAL);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1154,7 +1160,7 @@ static LRESULT CALLBACK TrayWndProc(HWND hwnd, UINT message,
|
|||||||
break;
|
break;
|
||||||
case IDM_ABOUT:
|
case IDM_ABOUT:
|
||||||
if (!aboutbox) {
|
if (!aboutbox) {
|
||||||
aboutbox = CreateDialog(hinst, MAKEINTRESOURCE(213),
|
aboutbox = CreateDialog(hinst, MAKEINTRESOURCE(IDD_ABOUT),
|
||||||
NULL, AboutProc);
|
NULL, AboutProc);
|
||||||
ShowWindow(aboutbox, SW_SHOWNORMAL);
|
ShowWindow(aboutbox, SW_SHOWNORMAL);
|
||||||
/*
|
/*
|
||||||
|
Loading…
Reference in New Issue
Block a user