diff options
-rw-r--r-- | gethost.c | 17 | ||||
-rw-r--r-- | parsedpy.c | 3 | ||||
-rw-r--r-- | process.c | 3 |
3 files changed, 19 insertions, 4 deletions
@@ -280,7 +280,22 @@ struct addrlist *get_address_info ( src = buf; len = strlen (buf); } - } else { + } else if(prefix == 0 && (strncmp (fulldpyname, "/tmp/launch", 11) == 0)) { + /* Use the bundle id (part preceding : in the basename) as our src id */ + char *c; + strlcpy(buf, strrchr(fulldpyname, '/') + 1, sizeof(buf)); + c = strchr(buf, ':'); + + /* In the legacy case with no bundle id, use the full path */ + if(c == buf) { + src = fulldpyname; + } else { + *c = '\0'; + src = buf; + } + + len = strlen(src); + } else { src = fulldpyname; len = prefix; } @@ -162,6 +162,9 @@ parse_displayname (char *displayname, if (!host) return False; + if(strncmp (host, "/tmp/launch", 11) == 0) { + family = FamilyLocal; + } /* * get the display number; we know that there is something after the @@ -485,9 +485,6 @@ get_displayname_auth(char *displayname, AuthList **authl) if (cp && strncmp (cp, "/unix:", 6) == 0) prelen = (cp - displayname); - if (strncmp (displayname, "/tmp/launch", 11) == 0) - displayname = strrchr(displayname, '/') + 1; - if (!parse_displayname (displayname + ((prelen > 0) ? prelen + 1 : 0), &family, &host, &dpynum, &scrnum, &rest)) { return False; |