X-Git-Url: https://asedeno.scripts.mit.edu/gitweb/?a=blobdiff_plain;f=x11fwd.c;h=52b320d15ae784cc5b2a160d608bc47ac9a54a76;hb=8053aea3606c3717ac2eb27ba2532b80284ed4c9;hp=049381b4bacad60f4f149266e02f86c10175e046;hpb=a2acc6ae0d9f3afe72e85e583ed50c75479e787a;p=PuTTY.git diff --git a/x11fwd.c b/x11fwd.c index 049381b4..52b320d1 100644 --- a/x11fwd.c +++ b/x11fwd.c @@ -1,3 +1,7 @@ +/* + * Platform-independent bits of X11 forwarding. + */ + #include #include #include @@ -228,14 +232,21 @@ int x11_get_screen_number(char *display) /* Find the right display, returns an allocated string */ char *x11_display(const char *display) { - if(!display || !*display) - if(!(display = getenv("DISPLAY"))) - display = ":0"; - if(display[0] == ':') { + char *ret; + if(!display || !*display) { + /* try to find platform-specific local display */ + if(!(ret = platform_get_x_display())) + /* plausible default for all platforms */ + ret = dupstr(":0"); + } else + ret = dupstr(display); + if(ret[0] == ':') { /* no transport specified, use whatever we think is best */ - return dupcat(platform_x11_best_transport, display, (char *)0); + char *s = dupcat(platform_x11_best_transport, ret, (char *)0); + sfree(ret); + return s; } else - return dupstr(display); + return ret; } /* @@ -290,7 +301,7 @@ const char *x11_init(Socket * s, char *display, void *c, void *auth, /* * Try to find host. */ - addr = name_lookup(host, port, &dummy_realhost, cfg); + addr = name_lookup(host, port, &dummy_realhost, cfg, ADDRTYPE_UNSPEC); if ((err = sk_addr_error(addr)) != NULL) { sk_addr_free(addr); return err; @@ -310,7 +321,7 @@ const char *x11_init(Socket * s, char *display, void *c, void *auth, pr->c = c; pr->s = *s = new_connection(addr, dummy_realhost, port, - 0, 1, 0, (Plug) pr, cfg); + 0, 1, 0, 0, (Plug) pr, cfg); if ((err = sk_socket_error(*s)) != NULL) { sfree(pr); return err;