From: Ben Mansell Date: Wed, 2 May 2001 17:19:58 +0000 (+0000) Subject: Patch from Stephen Landamore: speed up the environment merging by X-Git-Tag: php-4.0.6RC1~196 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=98af7a8d7d1ae975bc1daf5b100b0341b439d697;p=php Patch from Stephen Landamore: speed up the environment merging by using memcpy instead of putenv. --- diff --git a/sapi/fastcgi/fastcgi.c b/sapi/fastcgi/fastcgi.c index 065b7df0af..92b0e36c2a 100644 --- a/sapi/fastcgi/fastcgi.c +++ b/sapi/fastcgi/fastcgi.c @@ -281,7 +281,7 @@ int main(int argc, char *argv[]) int max_requests = 500; int requests = 0; int status; - int env_size; + int env_size, cgi_env_size; #ifdef FASTCGI_DEBUG fprintf( stderr, "Initialising now!\n" ); @@ -384,21 +384,17 @@ int main(int argc, char *argv[]) fprintf( stderr, "Got accept\n" ); #endif - /* Allocate for our environment */ - merge_env = malloc( env_size * sizeof( char *)); - if( !merge_env ) { - perror( "Can't malloc environment" ); - exit( 1 ); - } - memcpy( merge_env, orig_env, env_size * sizeof( char *)); - - /* Use the new environment */ - environ = merge_env; - - /* Populate our environment with the CGI's */ - for( i = 0; cgi_env[ i ]; i++ ) { - putenv( cgi_env[ i ] ); - } + cgi_env_size = 0; + while( cgi_env[ cgi_env_size ] ) { cgi_env_size++; } + merge_env = malloc( (env_size+cgi_env_size)*sizeof(char*) ); + if( !merge_env ) { + perror( "Can't malloc environment" ); + exit( 1 ); + } + memcpy( merge_env, orig_env, (env_size-1)*sizeof(char *) ); + memcpy( merge_env + env_size - 1, + cgi_env, (cgi_env_size+1)*sizeof(char *) ); + environ = merge_env; init_request_info( TLS_C SLS_CC ); SG(server_context) = (void *) 1; /* avoid server_context==NULL checks */