diff options
| author | Junio C Hamano <gitster@pobox.com> | 2010-12-12 21:49:52 -0800 | 
|---|---|---|
| committer | Junio C Hamano <gitster@pobox.com> | 2010-12-12 21:49:52 -0800 | 
| commit | e6234122b89cc21538d9d76cc3803a578b577e52 (patch) | |
| tree | ea917ebf8bc27f9af157ac0fc79414868eef3dcf /gitweb/gitweb.perl | |
| parent | 4a29c6a0db2a3ae7b8b94ad369f3b21c88482f95 (diff) | |
| parent | b3f52a9c3a5d02a6d1a3d05fe35deb90b70de510 (diff) | |
| download | git-e6234122b89cc21538d9d76cc3803a578b577e52.tar.gz | |
Merge branch 'jn/gitweb-per-request-config'
* jn/gitweb-per-request-config:
  gitweb: document $per_request_config better
  gitweb: selectable configurations that change with each request
Diffstat (limited to 'gitweb/gitweb.perl')
| -rwxr-xr-x | gitweb/gitweb.perl | 24 | 
1 files changed, 22 insertions, 2 deletions
| diff --git a/gitweb/gitweb.perl b/gitweb/gitweb.perl index 75306ca967..62b2d21b84 100755 --- a/gitweb/gitweb.perl +++ b/gitweb/gitweb.perl @@ -611,6 +611,14 @@ sub filter_snapshot_fmts {  		!$known_snapshot_formats{$_}{'disabled'}} @fmts;  } +# If it is set to code reference, it is code that it is to be run once per +# request, allowing updating configurations that change with each request, +# while running other code in config file only once. +# +# Otherwise, if it is false then gitweb would process config file only once; +# if it is true then gitweb config would be run for each request. +our $per_request_config = 1; +  our ($GITWEB_CONFIG, $GITWEB_CONFIG_SYSTEM);  sub evaluate_gitweb_config {  	our $GITWEB_CONFIG = $ENV{'GITWEB_CONFIG'} || "++GITWEB_CONFIG++"; @@ -1081,12 +1089,22 @@ sub reset_timer {  	our $number_of_git_cmds = 0;  } +our $first_request = 1;  sub run_request {  	reset_timer();  	evaluate_uri(); -	evaluate_gitweb_config(); -	evaluate_git_version(); +	if ($first_request) { +		evaluate_gitweb_config(); +		evaluate_git_version(); +	} +	if ($per_request_config) { +		if (ref($per_request_config) eq 'CODE') { +			$per_request_config->(); +		} elsif (!$first_request) { +			evaluate_gitweb_config(); +		} +	}  	check_loadavg();  	# $projectroot and $projects_list might be set in gitweb config file @@ -1140,6 +1158,7 @@ sub evaluate_argv {  sub run {  	evaluate_argv(); +	$first_request = 1;  	$pre_listen_hook->()  		if $pre_listen_hook; @@ -1152,6 +1171,7 @@ sub run {  		$post_dispatch_hook->()  			if $post_dispatch_hook; +		$first_request = 0;  		last REQUEST if ($is_last_request->());  	} | 
