mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-25 09:12: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:
parent
043c24844a
commit
2a26ebd0d5
76
config.c
76
config.c
@ -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));
|
||||||
|
7
putty.h
7
putty.h
@ -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.
|
||||||
*/
|
*/
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user