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

Turn the proxy type radio buttons into a dropdown list.

This makes room to add more entries without the Proxy panel
overflowing. It also means we can put in a bit more explanation in
some of the more cryptic one-word names!
This commit is contained in:
Simon Tatham 2022-04-22 14:55:44 +01:00
parent 043c24844a
commit 2a26ebd0d5
4 changed files with 68 additions and 73 deletions

View File

@ -1708,6 +1708,58 @@ static void serial_flow_handler(union control *ctrl, dlgparam *dlg,
} }
} }
void proxy_type_handler(union control *ctrl, dlgparam *dlg,
void *data, int event)
{
Conf *conf = (Conf *)data;
if (event == EVENT_REFRESH) {
/*
* We must fetch the previously configured value from the Conf
* before we start modifying the drop-down list, otherwise the
* spurious SELCHANGE we trigger in the process will overwrite
* the value we wanted to keep.
*/
int proxy_type = conf_get_int(conf, CONF_proxy_type);
dlg_update_start(ctrl, dlg);
dlg_listbox_clear(ctrl, dlg);
int index_to_select = 0, current_index = 0;
#define ADD(id, title) do { \
dlg_listbox_addwithid(ctrl, dlg, title, id); \
if (id == proxy_type) \
index_to_select = current_index; \
current_index++; \
} while (0)
ADD(PROXY_NONE, "None");
ADD(PROXY_SOCKS5, "SOCKS 5");
ADD(PROXY_SOCKS4, "SOCKS 4");
ADD(PROXY_HTTP, "HTTP CONNECT");
if (ssh_proxy_supported) {
ADD(PROXY_SSH, "SSH to proxy and use port forwarding");
}
if (ctrl->generic.context.i & PROXY_UI_FLAG_LOCAL) {
ADD(PROXY_CMD, "Local (run a subprogram to connect)");
}
ADD(PROXY_TELNET, "'Telnet' (send an ad-hoc command)");
#undef ADD
dlg_listbox_select(ctrl, dlg, index_to_select);
dlg_update_done(ctrl, dlg);
} else if (event == EVENT_SELCHANGE) {
int i = dlg_listbox_index(ctrl, dlg);
if (i < 0)
i = AUTO;
else
i = dlg_listbox_getid(ctrl, dlg, i);
conf_set_int(conf, CONF_proxy_type, i);
}
}
void setup_config_box(struct controlbox *b, bool midsession, void setup_config_box(struct controlbox *b, bool midsession,
int protocol, int protcfginfo) int protocol, int protcfginfo)
{ {
@ -2522,26 +2574,8 @@ void setup_config_box(struct controlbox *b, bool midsession,
"Options controlling proxy usage"); "Options controlling proxy usage");
s = ctrl_getset(b, "Connection/Proxy", "basics", NULL); s = ctrl_getset(b, "Connection/Proxy", "basics", NULL);
c = ctrl_radiobuttons(s, "Proxy type:", 't', 3, c = ctrl_droplist(s, "Proxy type:", 't', 70,
HELPCTX(proxy_type), HELPCTX(proxy_type), proxy_type_handler, I(0));
conf_radiobutton_handler,
I(CONF_proxy_type),
"None", I(PROXY_NONE),
"SOCKS 4", I(PROXY_SOCKS4),
"SOCKS 5", I(PROXY_SOCKS5),
"HTTP", I(PROXY_HTTP),
"Telnet", I(PROXY_TELNET),
NULL);
if (ssh_proxy_supported) {
/* Add an extra radio button to the above list. */
c->radio.nbuttons++;
c->radio.buttons =
sresize(c->radio.buttons, c->radio.nbuttons, char *);
c->radio.buttons[c->radio.nbuttons-1] = dupstr("SSH");
c->radio.buttondata =
sresize(c->radio.buttondata, c->radio.nbuttons, intorptr);
c->radio.buttondata[c->radio.nbuttons-1] = I(PROXY_SSH);
}
ctrl_columns(s, 2, 80, 20); ctrl_columns(s, 2, 80, 20);
c = ctrl_editbox(s, "Proxy hostname", 'y', 100, c = ctrl_editbox(s, "Proxy hostname", 'y', 100,
HELPCTX(proxy_main), HELPCTX(proxy_main),
@ -2579,7 +2613,7 @@ void setup_config_box(struct controlbox *b, bool midsession,
conf_editbox_handler, conf_editbox_handler,
I(CONF_proxy_password), I(1)); I(CONF_proxy_password), I(1));
c->editbox.password = true; c->editbox.password = true;
ctrl_editbox(s, "Telnet command", 'm', 100, ctrl_editbox(s, "Command to send to proxy (for some types)", 'm', 100,
HELPCTX(proxy_command), HELPCTX(proxy_command),
conf_editbox_handler, conf_editbox_handler,
I(CONF_proxy_telnet_command), I(1)); I(CONF_proxy_telnet_command), I(1));

View File

@ -2584,6 +2584,13 @@ void conf_fontsel_handler(union control *ctrl, dlgparam *dlg,
void setup_config_box(struct controlbox *b, bool midsession, void setup_config_box(struct controlbox *b, bool midsession,
int protocol, int protcfginfo); int protocol, int protcfginfo);
/* Visible outside config.c so that platforms can use it to recognise
* the proxy type control */
void proxy_type_handler(union control *ctrl, dlgparam *dlg,
void *data, int event);
/* And then they'll set this flag in its generic.context.i */
#define PROXY_UI_FLAG_LOCAL 1 /* has a local proxy */
/* /*
* Exports from bidi.c. * Exports from bidi.c.
*/ */

View File

@ -32,8 +32,7 @@ void unix_setup_config_box(struct controlbox *b, bool midsession, int protocol)
s->ctrls[0]->editbox.has_list = false; s->ctrls[0]->editbox.has_list = false;
/* /*
* Unix supports a local-command proxy. This also means we must * Unix supports a local-command proxy.
* adjust the text on the `Telnet command' control.
*/ */
if (!midsession) { if (!midsession) {
int i; int i;
@ -41,30 +40,8 @@ void unix_setup_config_box(struct controlbox *b, bool midsession, int protocol)
for (i = 0; i < s->ncontrols; i++) { for (i = 0; i < s->ncontrols; i++) {
c = s->ctrls[i]; c = s->ctrls[i];
if (c->generic.type == CTRL_RADIO && if (c->generic.type == CTRL_RADIO &&
c->generic.context.i == CONF_proxy_type) { c->generic.handler == proxy_type_handler) {
assert(c->generic.handler == conf_radiobutton_handler); c->generic.context.i |= PROXY_UI_FLAG_LOCAL;
c->radio.nbuttons++;
c->radio.buttons =
sresize(c->radio.buttons, c->radio.nbuttons, char *);
c->radio.buttons[c->radio.nbuttons-1] =
dupstr("Local");
c->radio.buttondata =
sresize(c->radio.buttondata, c->radio.nbuttons, intorptr);
c->radio.buttondata[c->radio.nbuttons-1] = I(PROXY_CMD);
if (c->radio.ncolumns < 4)
c->radio.ncolumns = 4;
break;
}
}
for (i = 0; i < s->ncontrols; i++) {
c = s->ctrls[i];
if (c->generic.type == CTRL_EDITBOX &&
c->generic.context.i == CONF_proxy_telnet_command) {
assert(c->generic.handler == conf_editbox_handler);
sfree(c->generic.label);
c->generic.label = dupstr("Telnet command, or local"
" proxy command");
break; break;
} }
} }

View File

@ -355,8 +355,7 @@ void win_setup_config_box(struct controlbox *b, HWND *hwndp, bool has_help,
I(CONF_fullscreenonaltenter)); I(CONF_fullscreenonaltenter));
/* /*
* Windows supports a local-command proxy. This also means we * Windows supports a local-command proxy.
* must adjust the text on the `Telnet command' control.
*/ */
if (!midsession) { if (!midsession) {
int i; int i;
@ -364,30 +363,8 @@ void win_setup_config_box(struct controlbox *b, HWND *hwndp, bool has_help,
for (i = 0; i < s->ncontrols; i++) { for (i = 0; i < s->ncontrols; i++) {
c = s->ctrls[i]; c = s->ctrls[i];
if (c->generic.type == CTRL_RADIO && if (c->generic.type == CTRL_RADIO &&
c->generic.context.i == CONF_proxy_type) { c->generic.handler == proxy_type_handler) {
assert(c->generic.handler == conf_radiobutton_handler); c->generic.context.i |= PROXY_UI_FLAG_LOCAL;
c->radio.nbuttons++;
c->radio.buttons =
sresize(c->radio.buttons, c->radio.nbuttons, char *);
c->radio.buttons[c->radio.nbuttons-1] =
dupstr("Local");
c->radio.buttondata =
sresize(c->radio.buttondata, c->radio.nbuttons, intorptr);
c->radio.buttondata[c->radio.nbuttons-1] = I(PROXY_CMD);
if (c->radio.ncolumns < 4)
c->radio.ncolumns = 4;
break;
}
}
for (i = 0; i < s->ncontrols; i++) {
c = s->ctrls[i];
if (c->generic.type == CTRL_EDITBOX &&
c->generic.context.i == CONF_proxy_telnet_command) {
assert(c->generic.handler == conf_editbox_handler);
sfree(c->generic.label);
c->generic.label = dupstr("Telnet command, or local"
" proxy command");
break; break;
} }
} }