X-Git-Url: https://git.distorted.org.uk/~mdw/sgt/putty/blobdiff_plain/56801e3d8daa0638bec8753c3790de586f8f7d11..f08a390fab250d5d200b3fbdc531916f388a0ef3:/unix/uxputty.c diff --git a/unix/uxputty.c b/unix/uxputty.c index ca1208d6..fbaf029d 100644 --- a/unix/uxputty.c +++ b/unix/uxputty.c @@ -7,31 +7,16 @@ #include #include #include +#include #include "putty.h" #include "storage.h" /* - * TODO: - * - * - Go through all the config options and ensure they can all be - * configured and reconfigured properly. - * + icon title appears to be a non-option on Unix. - * + Why the hell did I faff about disabling two of the vtmode - * options? The rest aren't used either in pterm! Work out - * whether they should be, and how they can be. - * + Refresh in the codepage combo is badly broken. - * + `Don't translate line drawing chars' ?? What is this crap? - * It does nothing at all, and where's the option to paste as - * lqqqk? What was I smoking? - * - * - Better control of the individual config box features. - * + SSH packet logging shouldn't be mentioned in pterm, and in - * fact not PuTTYtel either. - * + Keepalives, and the Connection panel in general, shouldn't - * crop up in pterm. (And perhaps also not mid-session in - * rlogin and raw?) + * Stubs to avoid uxpty.c needing to be linked in. */ +const int use_pty_argv = FALSE; +char **pty_argv; /* never used */ /* * Clean up and exit. @@ -46,29 +31,26 @@ void cleanup_exit(int code) exit(code); } -Backend *select_backend(Config *cfg) +Backend *select_backend(Conf *conf) { - int i; - Backend *back = NULL; - for (i = 0; backends[i].backend != NULL; i++) - if (backends[i].protocol == cfg->protocol) { - back = backends[i].backend; - break; - } + Backend *back = backend_from_proto(conf_get_int(conf, CONF_protocol)); assert(back != NULL); return back; } -int cfgbox(Config *cfg) +int cfgbox(Conf *conf) { - return do_config_box("PuTTY Configuration", cfg, 0); + char *title = dupcat(appname, " Configuration", NULL); + int ret = do_config_box(title, conf, 0, 0); + sfree(title); + return ret; } static int got_host = 0; const int use_event_log = 1, new_session = 1, saved_sessions = 1; -int process_nonoption_arg(char *arg, Config *cfg) +int process_nonoption_arg(char *arg, Conf *conf, int *allow_launch) { char *p, *q = arg; @@ -79,7 +61,7 @@ int process_nonoption_arg(char *arg, Config *cfg) * argument, so that it will be deferred until it's a good * moment to run it. */ - int ret = cmdline_process_param("-P", arg, 1, cfg); + int ret = cmdline_process_param("-P", arg, 1, conf); assert(ret == 2); } else if (!strncmp(q, "telnet:", 7)) { /* @@ -92,7 +74,7 @@ int process_nonoption_arg(char *arg, Config *cfg) q += 7; if (q[0] == '/' && q[1] == '/') q += 2; - cfg->protocol = PROT_TELNET; + conf_set_int(conf, CONF_protocol, PROT_TELNET); p = q; while (*p && *p != ':' && *p != '/') p++; @@ -100,11 +82,10 @@ int process_nonoption_arg(char *arg, Config *cfg) if (*p) *p++ = '\0'; if (c == ':') - cfg->port = atoi(p); + conf_set_int(conf, CONF_port, atoi(p)); else - cfg->port = -1; - strncpy(cfg->host, q, sizeof(cfg->host) - 1); - cfg->host[sizeof(cfg->host) - 1] = '\0'; + conf_set_int(conf, CONF_port, -1); + conf_set_str(conf, CONF_host, q); got_host = 1; } else { /* @@ -115,33 +96,48 @@ int process_nonoption_arg(char *arg, Config *cfg) p++; if (*p) *p++ = '\0'; - strncpy(cfg->host, q, sizeof(cfg->host) - 1); - cfg->host[sizeof(cfg->host) - 1] = '\0'; + conf_set_str(conf, CONF_host, q); got_host = 1; } + if (got_host) + *allow_launch = TRUE; return 1; } char *make_default_wintitle(char *hostname) { - return dupcat(hostname, " - PuTTY", NULL); + return dupcat(hostname, " - ", appname, NULL); +} + +/* + * X11-forwarding-related things suitable for Gtk app. + */ + +char *platform_get_x_display(void) { + const char *display; + /* Try to take account of --display and what have you. */ + if (!(display = gdk_get_display())) + /* fall back to traditional method */ + display = getenv("DISPLAY"); + return dupstr(display); } int main(int argc, char **argv) { extern int pt_main(int argc, char **argv); + int ret; + sk_init(); flags = FLAG_VERBOSE | FLAG_INTERACTIVE; default_protocol = be_default_protocol; /* Find the appropriate default port. */ { - int i; + Backend *b = backend_from_proto(default_protocol); default_port = 0; /* illegal */ - for (i = 0; backends[i].backend != NULL; i++) - if (backends[i].protocol == default_protocol) { - default_port = backends[i].backend->default_port; - break; - } + if (b) + default_port = b->default_port; } - return pt_main(argc, argv); + ret = pt_main(argc, argv); + cleanup_exit(ret); + return ret; /* not reached, but placates optimisers */ }