"John 'Warthog9' Hawley" <warthog9@xxxxxxxxxxxxxx> writes: > This adds output buffering for gitweb, mainly in preparation for > caching support. This is a dramatic change to how caching was being > done, mainly in passing around the variable manually and such. > > This centrally flips the entire STDOUT to a variable, which after the > completion of the run, flips it back and does a print on the resulting > data. > > This should save on the previous 10K line patch (or so) that adds more > explicit output passing. Signoff? > --- > gitweb/gitweb.perl | 29 +++++++++++++++++++++++++++++ > 1 files changed, 29 insertions(+), 0 deletions(-) > > diff --git a/gitweb/gitweb.perl b/gitweb/gitweb.perl > index 215a4e9..757ef46 100755 > --- a/gitweb/gitweb.perl > +++ b/gitweb/gitweb.perl > @@ -30,6 +30,9 @@ BEGIN { > > our $version = "++GIT_VERSION++"; > > +# Output buffer variable > +$output = ""; > + > our ($my_url, $my_uri, $base_url, $path_info, $home_link); > sub evaluate_uri { > our $cgi; > @@ -1151,6 +1154,25 @@ sub evaluate_argv { > ); > } > > +sub change_output { > + our $output; > + > + # Trap the 'proper' STDOUT to STDOUT_REAL for things like error messages and such > + open(STDOUT_REAL,">&STDOUT") or die "Unable to capture STDOUT $!\n"; > + > + # Close STDOUT, so that it isn't being used anymore. > + close STDOUT; > + > + # Trap STDOUT to the $output variable, which is what I was using in the original > + # patch anyway. > + open(STDOUT,">", \$output) || die "Unable to open STDOUT: $!"; #open STDOUT handle to use $var > +} > + > +sub reset_output { > + # This basically takes STDOUT_REAL and puts it back as STDOUTl > + open(STDOUT,">&STDOUT_REAL"); > +} Nice solution. I'll steal it for GitwebCache::Capture::Redirect (or something like that, instead of relying on a bit cryptic select($fh)). > @@ -1163,7 +1185,10 @@ sub run { > $pre_dispatch_hook->() > if $pre_dispatch_hook; > > + change_output(); > run_request(); > + reset_output(); > + print $output; Doesn't this enable capture unconditionally? Wouldn't that screw-up the blame_data part of blame_interactive Ajax-y view? Wouldn't that decrease perceived responsiveness of gitweb? > > $post_dispatch_hook->() > if $post_dispatch_hook; > @@ -3673,6 +3698,10 @@ sub die_error { > 500 => '500 Internal Server Error', > 503 => '503 Service Unavailable', > ); > + # Reset the output so that we are actually going to STDOUT as opposed > + # to buffering the output. > + reset_output(); > + Good. > git_header_html($http_responses{$status}, undef, %opts); > print <<EOF; > <div class="page_body"> -- Jakub Narebski Poland ShadeHawk on #git -- To unsubscribe from this list: send the line "unsubscribe git" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html