]> Sergey Matveev's repositories - public-inbox.git/blobdiff - lib/PublicInbox/ViewVCS.pm
viewvcs: prepopulate search bar with dfpost + dfn
[public-inbox.git] / lib / PublicInbox / ViewVCS.pm
index eae5b7f416cf88f8c35823dc5647ef01b0c415ca..51a7bcbcb43b81dd2062c662394972b2be3d2d1b 100644 (file)
@@ -126,9 +126,9 @@ sub cmt_title { # git->cat_async callback
 }
 
 sub do_cat_async {
-       my ($ctx, $cb, @oids) = @_;
+       my ($ctx, $cb, @req) = @_;
        # favor git(1) over Gcf2 (libgit2) for SHA-256 support
-       $ctx->{git}->cat_async($_, $cb, $ctx) for @oids;
+       $ctx->{git}->cat_async($_, $cb, $ctx) for @req;
        if ($ctx->{env}->{'pi-httpd.async'}) {
                PublicInbox::GitAsyncCat::watch_cat($ctx->{git});
        } else { # synchronous, generic PSGI
@@ -136,6 +136,16 @@ sub do_cat_async {
        }
 }
 
+sub do_check_async {
+       my ($ctx, $cb, @req) = @_;
+       if ($ctx->{env}->{'pi-httpd.async'}) {
+               async_check($ctx, $_, $cb, $ctx) for @req;
+       } else { # synchronous, generic PSGI
+               $ctx->{git}->check_async($_, $cb, $ctx) for @req;
+               $ctx->{git}->check_async_wait;
+       }
+}
+
 sub show_commit_start { # ->psgi_qx callback
        my ($bref, $ctx) = @_;
        if (my $qsp_err = delete $ctx->{-qsp_err}) {
@@ -490,11 +500,20 @@ sub solve_result {
        return show_tree($ctx, $res) if $type eq 'tree';
        return show_tag($ctx, $res) if $type eq 'tag';
        return show_other($ctx, $res) if $type ne 'blob';
+       my $fn = $di->{path_b} // $hints->{path_b};
        my $paths = $ctx->{-paths} //= do {
-               my $path = to_filename($di->{path_b}//$hints->{path_b}//'blob');
+               my $path = to_filename($fn // 'blob');
                my $raw_more = qq[(<a\nhref="$path">raw</a>)];
+
+               # XXX not sure if this is the correct wording
+               defined($fn) and $raw_more .=
+"\nname: ${\ascii_html($fn)} \t # note: path name is non-authoritative";
                [ $path, $raw_more ];
        };
+       $ctx->{-q_value_html} //= do {
+               my $s = defined($fn) ? 'dfn:'.ascii_html($fn).' ' : '';
+               $s.'dfpost:'.substr($oid, 0, 7);
+       };
 
        if ($size > $MAX_SIZE) {
                return stream_large_blob($ctx, $res) if defined $ctx->{fn};