2002-08-28 00:10:35 +02:00
|
|
|
--- esdlib.c.orig Mon Jul 15 05:28:26 2002
|
|
|
|
+++ esdlib.c Tue Aug 27 13:06:16 2002
|
2002-02-18 11:10:18 +01:00
|
|
|
@@ -20,6 +20,8 @@
|
2000-06-30 06:21:53 +02:00
|
|
|
#include <arpa/inet.h>
|
|
|
|
#include <errno.h>
|
|
|
|
#include <sys/wait.h>
|
|
|
|
+#include <pwd.h>
|
|
|
|
+#include <limits.h>
|
|
|
|
|
|
|
|
#include <sys/un.h>
|
|
|
|
|
2002-08-28 00:10:35 +02:00
|
|
|
@@ -660,8 +662,7 @@
|
2002-02-18 11:10:18 +01:00
|
|
|
setsid();
|
2002-08-28 00:10:35 +02:00
|
|
|
cmd = malloc(strlen(SERVERDIR"/esd -spawnfd 999999") + (esd_spawn_options?strlen(esd_spawn_options):0));
|
2002-02-18 11:10:18 +01:00
|
|
|
|
2002-08-28 00:10:35 +02:00
|
|
|
- sprintf(cmd, "%s/esd %s -spawnfd %d", SERVERDIR, esd_spawn_options?esd_spawn_options:"", esd_pipe[1]);
|
|
|
|
-
|
2002-02-18 11:10:18 +01:00
|
|
|
+ sprintf(cmd, "exec esd %s -spawnfd %d", esd_spawn_options?esd_spawn_options:"", esd_pipe[1]);
|
|
|
|
execl("/bin/sh", "/bin/sh", "-c", cmd, NULL);
|
|
|
|
perror("execl");
|
2002-08-28 00:10:35 +02:00
|
|
|
_exit(1);
|
|
|
|
@@ -1421,3 +1422,34 @@
|
2000-06-30 06:21:53 +02:00
|
|
|
|
|
|
|
return close( esd );
|
2002-08-28 00:10:35 +02:00
|
|
|
}
|
2000-06-30 06:21:53 +02:00
|
|
|
+
|
|
|
|
+char *
|
|
|
|
+esd_unix_socket_dir(void) {
|
2002-08-28 00:10:35 +02:00
|
|
|
+ static char *sockdir = NULL, sockdirbuf[PATH_MAX];
|
|
|
|
+ struct passwd *pw;
|
2000-06-30 06:21:53 +02:00
|
|
|
+
|
2002-08-28 00:10:35 +02:00
|
|
|
+ if (sockdir != NULL)
|
|
|
|
+ return (sockdir);
|
|
|
|
+ pw = getpwuid(getuid());
|
|
|
|
+ if (pw == NULL || pw->pw_dir == NULL) {
|
|
|
|
+ fprintf(stderr, "esd: could not find home directory\n");
|
|
|
|
+ exit(1);
|
|
|
|
+ }
|
|
|
|
+ snprintf(sockdirbuf, sizeof(sockdirbuf), "%s/.esd", pw->pw_dir);
|
|
|
|
+ endpwent();
|
|
|
|
+ sockdir = sockdirbuf;
|
|
|
|
+ return (sockdir);
|
2000-06-30 06:21:53 +02:00
|
|
|
+}
|
|
|
|
+
|
|
|
|
+char *
|
|
|
|
+esd_unix_socket_name(void) {
|
2002-08-28 00:10:35 +02:00
|
|
|
+ static char *sockname = NULL, socknamebuf[PATH_MAX];
|
|
|
|
+
|
|
|
|
+ if (sockname != NULL)
|
|
|
|
+ return (sockname);
|
|
|
|
+ snprintf(socknamebuf, sizeof(socknamebuf), "%s/socket",
|
|
|
|
+ esd_unix_socket_dir());
|
|
|
|
+ sockname = socknamebuf;
|
|
|
|
+ return (sockname);
|
|
|
|
+ }
|
2000-06-30 06:21:53 +02:00
|
|
|
+
|