]> granicus.if.org Git - php/commitdiff
fix heuristic: if someone passed "-b IP:port", this check would
authorSascha Schumann <sas@php.net>
Wed, 3 Sep 2003 08:15:09 +0000 (08:15 +0000)
committerSascha Schumann <sas@php.net>
Wed, 3 Sep 2003 08:15:09 +0000 (08:15 +0000)
falsely recognize the parameter as defining only a port.

sapi/cgi/cgi_main.c

index 24e001efe2518e30be24cc46ec625af74e0deade..664c7483634cbc9af30b0f0af1c161b8913847fa 100644 (file)
@@ -1111,7 +1111,6 @@ consult the installation file that came with this distribution, or visit \n\
        /* for windows, socket listening is broken in the fastcgi library itself
           so dissabling this feature on windows till time is available to fix it */
        if (bindpath) {
-               int port = 0;
                /* this must be done to make FCGX_OpenSocket work correctly 
                   bug 23664 */
                close(0);
@@ -1119,11 +1118,16 @@ consult the installation file that came with this distribution, or visit \n\
                 * If just a port is specified, then we prepend a ':' onto the
                 * path (it's what the fastcgi library expects)
                 */
-               port = atoi(bindpath);
-               if (port) {
-                       char bindport[32];
-                       snprintf(bindport, 32, ":%s", bindpath);
-                       fcgi_fd = FCGX_OpenSocket(bindport, 128);
+               
+               if (strchr(bindpath, ':') == NULL) {
+                       char *tmp;
+
+                       tmp = malloc(strlen(bindpath) + 2);
+                       tmp[0] = ':';
+                       memcpy(tmp + 1, bindpath, strlen(bindpath) + 1);
+
+                       fcgi_fd = FCGX_OpenSocket(tmp, 128);
+                       free(tmp);
                } else {
                        fcgi_fd = FCGX_OpenSocket(bindpath, 128);
                }