OSDN Git Service

Patch from Goran Thyni
authorBruce Momjian <bruce@momjian.us>
Mon, 10 Nov 1997 02:21:18 +0000 (02:21 +0000)
committerBruce Momjian <bruce@momjian.us>
Mon, 10 Nov 1997 02:21:18 +0000 (02:21 +0000)
src/backend/libpq/pqcomm.c

index a75631e..c3223bf 100644 (file)
@@ -7,7 +7,7 @@
  *
  *
  * IDENTIFICATION
- *       $Header: /cvsroot/pgsql/src/backend/libpq/pqcomm.c,v 1.24 1997/11/07 20:51:34 momjian Exp $
+ *       $Header: /cvsroot/pgsql/src/backend/libpq/pqcomm.c,v 1.25 1997/11/10 02:21:18 momjian Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -582,15 +582,16 @@ static void do_unlink()
 int
 StreamServerPort(char *hostName, short portName, int *fdP)
 {
-       struct sockaddr_in sin;
-       struct sockaddr_un sun;
+        union {
+         struct sockaddr_in in;
+         struct sockaddr_un un;
+       } saddr;
        int                     fd, err, family;
+       size_t                  len;
        int                     one = 1;
 
        family = hostName != NULL ? AF_INET : AF_UNIX;
 
-       MemSet((char *) &sin, 0, sizeof sin);
-
        if ((fd = socket(family, SOCK_STREAM, 0)) < 0)
        {
                sprintf(PQerrormsg,
@@ -611,23 +612,21 @@ StreamServerPort(char *hostName, short portName, int *fdP)
                pqdebug("%s", PQerrormsg);
                return (STATUS_ERROR);
        }
+       bzero(&saddr, sizeof(saddr));
        if (family == AF_UNIX)
          {
-           size_t len;
-           bzero(&sun, sizeof(sun));
-           sun.sun_family = family;
-           len = UNIXSOCK_PATH(sun,portName);
-           strcpy(sock_path, sun.sun_path);
-           err = bind(fd, (struct sockaddr *) &sun, len);
+           saddr.un.sun_family = family;
+           len = UNIXSOCK_PATH(saddr.un,portName);
+           strcpy(sock_path, saddr.un.sun_path);
          }
        else
          {
-           bzero(&sin, sizeof(sin));
-           sin.sin_family = family;
-           sin.sin_addr.s_addr = htonl(INADDR_ANY);
-           sin.sin_port = htons(portName);
-           err = bind(fd, (struct sockaddr *) &sin, sizeof sin);
+           saddr.in.sin_family = family;
+           saddr.in.sin_addr.s_addr = htonl(INADDR_ANY);
+           saddr.in.sin_port = htons(portName);
+           len = sizeof saddr.in;
          }
+       err = bind(fd, (struct sockaddr *) &saddr, len);
        if (err < 0)
        {
                sprintf(PQerrormsg,