X-Git-Url: http://www.git.stargrave.org/?p=public-inbox.git;a=blobdiff_plain;f=lib%2FPublicInbox%2FWwwStream.pm;h=4d82cbb48e03202edf9c3234812444c24f6ebf5b;hp=c80440d14dad6291abdc0fe091c7f9011c9e1eb7;hb=55263c56cf41c87f8977cd6a6be65ac07b5cea87;hpb=52a02a813a46940530183ede4d4cc7028290cd8f diff --git a/lib/PublicInbox/WwwStream.pm b/lib/PublicInbox/WwwStream.pm index c80440d1..4d82cbb4 100644 --- a/lib/PublicInbox/WwwStream.pm +++ b/lib/PublicInbox/WwwStream.pm @@ -31,7 +31,6 @@ sub init { my ($ctx, $cb) = @_; $ctx->{cb} = $cb; $ctx->{base_url} = base_url($ctx); - $ctx->{nr} = 0; bless $ctx, __PACKAGE__; } @@ -43,7 +42,7 @@ sub response { [ $code, $h, $ctx ] } -sub _html_top ($) { +sub html_top ($) { my ($ctx) = @_; my $ibx = $ctx->{-inbox}; my $desc = ascii_html($ibx->description); @@ -159,15 +158,9 @@ EOF # callback for HTTP.pm (and any other PSGI servers) sub getline { my ($ctx) = @_; - my $nr = $ctx->{nr}++; - - my $buf = do { - if ($nr == 0) { - _html_top($ctx); - } elsif (my $middle = $ctx->{cb}) { - $middle->($nr, $ctx); - } - } // (delete($ctx->{cb}) ? _html_end($ctx) : undef); + my $cb = $ctx->{cb}; + my $buf = $cb->($ctx) if $cb; + $buf //= delete($ctx->{cb}) ? _html_end($ctx) : undef; # gzf may be GzipFilter, `undef' or `0' my $gzf = $ctx->{gzf} or return $buf; @@ -185,12 +178,12 @@ sub html_oneshot ($$;$) { my $h = [ 'Content-Type' => 'text/html; charset=UTF-8', 'Content-Length' => undef ]; if (my $gzf = gzf_maybe($h, $ctx->{env})) { - $gzf->zmore(_html_top($ctx)); + $gzf->zmore(html_top($ctx)); $gzf->zmore($$sref) if $sref; $x[0] = $gzf->zflush(_html_end($ctx)); $h->[3] = length($x[0]); } else { - @x = (_html_top($ctx), $sref ? $$sref : (), _html_end($ctx)); + @x = (html_top($ctx), $sref ? $$sref : (), _html_end($ctx)); $h->[3] += bytes::length($_) for @x; } [ $code, $h, \@x ]