From: Shane Caraveo Date: Sun, 29 Jun 2003 20:09:36 +0000 (+0000) Subject: fix bug http://bugs.php.net/bug.php?id=24009 X-Git-Tag: BEFORE_ARG_INFO~553 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=97ffab21a6621ff697272dfa80ae887293d24d0c;p=php fix bug http://bugs.php.net/bug.php?id=24009 also do not use APPL_PHYSICAL_PATH as DOCUMENT_ROOT under IIS, it's different depending on IIS configuration. Code works fine without it, that was just an attempt at a shortcut. --- diff --git a/sapi/cgi/cgi_main.c b/sapi/cgi/cgi_main.c index c7a9be5f8b..f5f32645d9 100644 --- a/sapi/cgi/cgi_main.c +++ b/sapi/cgi/cgi_main.c @@ -684,8 +684,6 @@ static void init_request_info(TSRMLS_D) _sapi_cgibin_putenv("ORIG_SCRIPT_FILENAME",env_script_filename TSRMLS_CC); } if (!env_document_root) { - /* IIS version of DOCUMENT_ROOT, not avail in cgi, but is in fastcgi */ - env_document_root = sapi_cgibin_getenv("APPL_PHYSICAL_PATH",0 TSRMLS_CC); /* ini version of document root */ if (!env_document_root) { env_document_root = PG(doc_root); @@ -1477,6 +1475,11 @@ consult the installation file that came with this distribution, or visit \n\ /* request startup only after we've done all we can to get path_translated */ if (php_request_startup(TSRMLS_C)==FAILURE) { +#if PHP_FASTCGI + if (fastcgi) { + FCGX_Finish_r(&request); + } +#endif php_module_shutdown(TSRMLS_C); return FAILURE; } @@ -1504,6 +1507,14 @@ consult the installation file that came with this distribution, or visit \n\ if (retval == FAILURE && file_handle.handle.fp == NULL) { SG(sapi_headers).http_response_code = 404; PUTS("No input file specified.\n"); +#if PHP_FASTCGI + /* we want to serve more requests if this is fastcgi + so cleanup and continue, request shutdown is + handled later */ + if (fastcgi) { + goto fastcgi_request_done; + } +#endif php_request_shutdown((void *) 0); php_module_shutdown(TSRMLS_C); return FAILURE; @@ -1573,6 +1584,9 @@ consult the installation file that came with this distribution, or visit \n\ #endif } +#if PHP_FASTCGI +fastcgi_request_done: +#endif { char *path_translated;