Move string manipulation of the DISPLAY env var into get_client_addr
awesome-client.c manipulates the string returned from getenv("DISPLAY"), removing anything after the first dot ('.'). awesome.c however has no such thing, leading to awesome listening on a '...0.0' socket. Anyway, this seems like something that should be in get_client_addr as opposed to hardwired in awesome-client.c or awesome.c. The attached patch moves it into awesome-client-common.c:get_client_addr() and teaches awesome-client.c of the change.
This commit is contained in:
parent
ece6bb27f3
commit
963bef908e
|
@ -31,7 +31,7 @@
|
||||||
struct sockaddr_un *
|
struct sockaddr_un *
|
||||||
get_client_addr(const char *display)
|
get_client_addr(const char *display)
|
||||||
{
|
{
|
||||||
char *homedir;
|
char *homedir, *tmp;
|
||||||
ssize_t path_len;
|
ssize_t path_len;
|
||||||
struct sockaddr_un *addr;
|
struct sockaddr_un *addr;
|
||||||
|
|
||||||
|
@ -39,6 +39,8 @@ get_client_addr(const char *display)
|
||||||
homedir = getenv("HOME");
|
homedir = getenv("HOME");
|
||||||
/* (a_strlen(display) - 1) because we strcat on display + 1 and
|
/* (a_strlen(display) - 1) because we strcat on display + 1 and
|
||||||
* + 3 for /, \0 and possibly 0 if display is NULL */
|
* + 3 for /, \0 and possibly 0 if display is NULL */
|
||||||
|
if(display && (tmp = strrchr(display, '.')))
|
||||||
|
*tmp = '\0';
|
||||||
path_len = a_strlen(homedir) + a_strlen(CONTROL_UNIX_SOCKET_PATH) + (a_strlen(display) - 1) + 3;
|
path_len = a_strlen(homedir) + a_strlen(CONTROL_UNIX_SOCKET_PATH) + (a_strlen(display) - 1) + 3;
|
||||||
if(path_len >= ssizeof(addr->sun_path))
|
if(path_len >= ssizeof(addr->sun_path))
|
||||||
{
|
{
|
||||||
|
|
|
@ -38,14 +38,11 @@ int
|
||||||
main(void)
|
main(void)
|
||||||
{
|
{
|
||||||
struct sockaddr_un *addr;
|
struct sockaddr_un *addr;
|
||||||
char buf[1024], *display, *tmp;
|
char buf[1024];
|
||||||
int csfd, ret_value = EXIT_SUCCESS;
|
int csfd, ret_value = EXIT_SUCCESS;
|
||||||
|
|
||||||
csfd = get_client_socket();
|
csfd = get_client_socket();
|
||||||
display = a_strdup(getenv("DISPLAY"));
|
addr = get_client_addr(getenv("DISPLAY"));
|
||||||
if(display && (tmp = strrchr(display, '.')))
|
|
||||||
*tmp = '\0';
|
|
||||||
addr = get_client_addr(display);
|
|
||||||
|
|
||||||
if(!addr || csfd < 0)
|
if(!addr || csfd < 0)
|
||||||
return EXIT_FAILURE;
|
return EXIT_FAILURE;
|
||||||
|
@ -69,7 +66,6 @@ main(void)
|
||||||
close(csfd);
|
close(csfd);
|
||||||
|
|
||||||
p_delete(&addr);
|
p_delete(&addr);
|
||||||
p_delete(&display);
|
|
||||||
|
|
||||||
return ret_value;
|
return ret_value;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue