]> granicus.if.org Git - php/commitdiff
renable -b option (removed when longopts were added)
authorShane Caraveo <shane@php.net>
Sun, 29 Jun 2003 20:45:38 +0000 (20:45 +0000)
committerShane Caraveo <shane@php.net>
Sun, 29 Jun 2003 20:45:38 +0000 (20:45 +0000)
dissable -b on windows due to fastcgi lib bug
close stdin on linux when using socket server (bug 23664)

sapi/cgi/cgi_main.c

index f5f32645d999335e871f1d74c1e6bed99c28f306..f7c038bb5e458197595728da6673e79ffac44479 100644 (file)
@@ -122,6 +122,9 @@ static int optind = 1;
 
 static const opt_struct OPTIONS[] = {
        {'a', 0, "interactive"},
+#ifndef PHP_WIN32
+       {'b', 1, "bindpath"},
+#endif
        {'C', 0, "no-chdir"},
        {'c', 1, "php-ini"},
        {'d', 1, "define"},
@@ -937,7 +940,9 @@ int main(int argc, char *argv[])
        int max_requests = 500;
        int requests = 0;
        int fastcgi = !FCGX_IsCGI();
+#ifndef PHP_WIN32
        char *bindpath = NULL;
+#endif
        int fcgi_fd = 0;
        FCGX_Request request;
 #ifdef PHP_WIN32
@@ -1012,6 +1017,7 @@ int main(int argc, char *argv[])
                                        cgi_sapi_module.php_ini_ignore = 1;
                                        break;
 #if PHP_FASTCGI
+#ifndef PHP_WIN32
                                /* if we're started on command line, check to see if
                                   we are being started as an 'external' fastcgi
                                   server by accepting a bindpath parameter. */
@@ -1020,6 +1026,7 @@ int main(int argc, char *argv[])
                                                bindpath = strdup(optarg);
                                        }
                                        break;
+#endif
 #endif
                        }
 
@@ -1100,12 +1107,19 @@ consult the installation file that came with this distribution, or visit \n\
 #endif
 
 #if PHP_FASTCGI
+#ifndef PHP_WIN32
+       /* 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);
                /* Pass on the arg to the FastCGI library, with one exception.
                 * If just a port is specified, then we prepend a ':' onto the
                 * path (it's what the fastcgi library expects)
                 */
-               int port = atoi(bindpath);
+               port = atoi(bindpath);
                if (port) {
                        char bindport[32];
                        snprintf(bindport, 32, ":%s", bindpath);
@@ -1122,6 +1136,7 @@ consult the installation file that came with this distribution, or visit \n\
                }
                fastcgi = !FCGX_IsCGI();
        }
+#endif
        if (fastcgi) {
                /* How many times to run PHP scripts before dying */
                if( getenv( "PHP_FCGI_MAX_REQUESTS" )) {
@@ -1613,9 +1628,11 @@ fastcgi_request_done:
                        requests++;
                        if(max_requests && (requests == max_requests)) {
                                FCGX_Finish_r(&request);
+#ifndef PHP_WIN32
                                if (bindpath) {
                                        free(bindpath);
                                }
+#endif
                                break;
                        }
                        /* end of fastcgi loop */