X-Git-Url: https://git.distorted.org.uk/u/mdw/putty/blobdiff_plain/4a4b36177579a15b96b61610369121326481dde5..b3d375b244187cd77f45dc013668e6273e133179:/unix/uxputty.c diff --git a/unix/uxputty.c b/unix/uxputty.c index 6b1eabb7..73e11973 100644 --- a/unix/uxputty.c +++ b/unix/uxputty.c @@ -7,11 +7,18 @@ #include #include #include +#include #include "putty.h" #include "storage.h" /* + * 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. */ void cleanup_exit(int code) @@ -26,27 +33,24 @@ void cleanup_exit(int code) Backend *select_backend(Config *cfg) { - 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(cfg->protocol); assert(back != NULL); return back; } int cfgbox(Config *cfg) { - return do_config_box("PuTTY Configuration", cfg, 0); + char *title = dupcat(appname, " Configuration", NULL); + int ret = do_config_box(title, cfg, 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, Config *cfg, int *allow_launch) { char *p, *q = arg; @@ -97,12 +101,27 @@ int process_nonoption_arg(char *arg, Config *cfg) cfg->host[sizeof(cfg->host) - 1] = '\0'; 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) @@ -113,13 +132,10 @@ int main(int argc, char **argv) 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); }