--- rxvt-unicode/src/rxvtdaemon.C 2003/11/24 17:28:08 1.1 +++ rxvt-unicode/src/rxvtdaemon.C 2004/07/29 15:25:43 1.7 @@ -1,13 +1,55 @@ -#include -#include +/*--------------------------------*-C-*---------------------------------* + * File: rxvtdaemon.C + *----------------------------------------------------------------------* + * + * All portions of code are copyright by their respective author/s. + * Copyright (c) 2003-2004 Marc Lehmann + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + *----------------------------------------------------------------------*/ + #include #include +#include + +#include +#include +#include +#include #include "rxvtdaemon.h" -const char *rxvt_connection::unix_sockname () +char *rxvt_connection::unix_sockname () { - return "/tmp/rxvtd~"; + char name[PATH_MAX]; + char *path = getenv ("RXVT_SOCKET"); + + if (!path) + { + struct utsname u; + uname (&u); + + path = getenv ("HOME"); + snprintf (name, PATH_MAX, "%s/.rxvt-%s", + path ? path : "/tmp", + u.nodename); + + path = name; + } + + return strdup (path); } void rxvt_connection::send (const char *data, int len) @@ -25,7 +67,7 @@ send (data, strlen (data)); } -bool rxvt_connection::recv (char *&data, int *len) +bool rxvt_connection::recv (auto_str &data, int *len) { uint8_t s[2]; int l; @@ -53,27 +95,11 @@ return true; } -bool rxvt_connection::recv (token &data) -{ - char *d; - int l; - - if (!recv (d, &l)) - return false; - - if (l < sizeof (token) - 1) - strcpy (data, d); - - delete [] d; - - return l < sizeof (token) - 1; -} - void rxvt_connection::send (int data) { uint8_t s[4]; - s[0] = data >> 24; s[1] = data >> 16; s[0] = data >> 8; s[1] = data; + s[0] = data >> 24; s[1] = data >> 16; s[2] = data >> 8; s[3] = data; write (fd, s, 4); }