--- rxvt-unicode/src/rxvtdaemon.C 2003/11/24 19:52:16 1.2 +++ rxvt-unicode/src/rxvtdaemon.C 2012/01/23 14:29:24 1.20 @@ -1,19 +1,72 @@ +/*----------------------------------------------------------------------* + * File: rxvtdaemon.C + *----------------------------------------------------------------------* + * + * All portions of code are copyright by their respective author/s. + * Copyright (c) 2003-2007 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 +#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"); + if (!path) + path = "/tmp"; + + snprintf (name, PATH_MAX, "%s/.urxvt", path); + mkdir (name, 0777); + + snprintf (name, PATH_MAX, "%s/.urxvt/urxvtd-%s", + path, + u.nodename); + + path = name; + } + + return strdup (path); } void rxvt_connection::send (const char *data, int len) { uint8_t s[2]; + if (len > 65535) + len = 65535; + s[0] = len >> 8; s[1] = len; write (fd, s, 2); @@ -34,13 +87,13 @@ return false; l = (s[0] << 8) + s[1]; - if (l > 4096) + if (l > 65535) return false; if (len) *len = l; - data = new char[l + 1]; + data = (char *)malloc (l + 1); if (!data) return false; @@ -57,7 +110,7 @@ { 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); }