diff options
| author | Jeremy Huddleston <jeremyhu@freedesktop.org> | 2008-12-08 21:59:49 -0800 |
|---|---|---|
| committer | Jeremy Huddleston <jeremyhu@freedesktop.org> | 2008-12-10 15:07:35 -0800 |
| commit | e5ce6e198f4c245f4dc840c5e9e90a7ef80fb6e9 (patch) | |
| tree | 7cb170cae8f512ad3ce0d41befd35c3064d88a44 | |
| parent | ecaaf0462d6c70cabfcaf6868a526e5415505e2c (diff) | |
XQuartz: unset DISPLAY if we didn't get a launchd socket handoff
(cherry picked from commit b959727f38733009c6381cc8ca06b5984257bdac)
| -rw-r--r-- | hw/xquartz/mach-startup/bundle-main.c | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/hw/xquartz/mach-startup/bundle-main.c b/hw/xquartz/mach-startup/bundle-main.c index 8b6d45849..6b48c132d 100644 --- a/hw/xquartz/mach-startup/bundle-main.c +++ b/hw/xquartz/mach-startup/bundle-main.c @@ -278,8 +278,12 @@ static int create_socket(char *filename_out) { return 0; } +static int launchd_socket_handed_off = 0; + kern_return_t do_request_fd_handoff_socket(mach_port_t port, string_t filename) { socket_handoff_t *handoff_data; + + launchd_socket_handed_off = 1; handoff_data = (socket_handoff_t *)calloc(1,sizeof(socket_handoff_t)); if(!handoff_data) { @@ -318,6 +322,12 @@ kern_return_t do_start_x11_server(mach_port_t port, string_array_t argv, char **_envp = alloca((envpCnt + 1) * sizeof(char *)); size_t i; + /* If we didn't get handed a launchd DISPLAY socket, we shoul + * unset DISPLAY or we can run into problems with pbproxy + */ + if(!launchd_socket_handed_off) + unsetenv("DISPLAY"); + if(!_argv || !_envp) { return KERN_FAILURE; } |
