listen: fix namespace collision on OpenSolaris
The listen.c module breaks the build because the variable name used ("sun") for the Unix domain socket part collides with something else on an OpenSolaris system, likely Sun specific. Renaming it to _sun (or something else of choice) fixes the build. [mk: renamed to "s_un"]
This commit is contained in:
parent
2e0ba90208
commit
ea92576219
12
src/listen.c
12
src/listen.c
@ -159,19 +159,19 @@ static void parseListenConfigParam(unsigned int port, ConfigParam * param)
|
|||||||
#ifdef HAVE_UN
|
#ifdef HAVE_UN
|
||||||
} else if (param->value[0] == '/') {
|
} else if (param->value[0] == '/') {
|
||||||
size_t path_length;
|
size_t path_length;
|
||||||
struct sockaddr_un sun;
|
struct sockaddr_un s_un;
|
||||||
|
|
||||||
path_length = strlen(param->value);
|
path_length = strlen(param->value);
|
||||||
if (path_length >= sizeof(sun.sun_path))
|
if (path_length >= sizeof(s_un.sun_path))
|
||||||
FATAL("unix socket path is too long\n");
|
FATAL("unix socket path is too long\n");
|
||||||
|
|
||||||
unlink(param->value);
|
unlink(param->value);
|
||||||
|
|
||||||
sun.sun_family = AF_UNIX;
|
s_un.sun_family = AF_UNIX;
|
||||||
memcpy(sun.sun_path, param->value, path_length + 1);
|
memcpy(s_un.sun_path, param->value, path_length + 1);
|
||||||
|
|
||||||
addrp = (const struct sockaddr *)&sun;
|
addrp = (const struct sockaddr *)&s_un;
|
||||||
addrlen = sizeof(sun);
|
addrlen = sizeof(s_un);
|
||||||
|
|
||||||
if (establishListen(PF_UNIX, addrp, addrlen) < 0)
|
if (establishListen(PF_UNIX, addrp, addrlen) < 0)
|
||||||
FATAL("unable to bind to %s: %s\n",
|
FATAL("unable to bind to %s: %s\n",
|
||||||
|
Loading…
Reference in New Issue
Block a user