gitweb: tree view: hash_base and hash are now context sensitive

In tree view, by default, hash_base is HEAD and hash is the
entry equivalent.  Else the user had selected a hash_base or
hash, say by clicking on a revision or commit, in which case
those values are used.

Signed-off-by: Luben Tuikov <ltuikov@yahoo.com>
Signed-off-by: Junio C Hamano <junkio@cox.net>
This commit is contained in:
Luben Tuikov 2006-09-29 09:57:43 -07:00 committed by Junio C Hamano
parent 6d81c5a2ea
commit 6f7ea5fb33

View File

@ -1672,9 +1672,9 @@ sub git_print_tree_entry {
"history"); "history");
} }
print " | " . print " | " .
$cgi->a({-href => href(action=>"blob_plain", $cgi->a({-href => href(action=>"blob_plain", hash_base=>$hash_base,
hash=>$t->{'hash'}, file_name=>"$basedir$t->{'name'}")}, file_name=>"$basedir$t->{'name'}")},
"raw"); "raw");
print "</td>\n"; print "</td>\n";
} elsif ($t->{'type'} eq "tree") { } elsif ($t->{'type'} eq "tree") {
@ -2745,14 +2745,14 @@ sub git_blob {
sub git_tree { sub git_tree {
my $have_snapshot = gitweb_have_snapshot(); my $have_snapshot = gitweb_have_snapshot();
if (!defined $hash_base) {
$hash_base = "HEAD";
}
if (!defined $hash) { if (!defined $hash) {
$hash = git_get_head_hash($project);
if (defined $file_name) { if (defined $file_name) {
my $base = $hash_base || $hash; $hash = git_get_hash_by_path($hash_base, $file_name, "tree");
$hash = git_get_hash_by_path($base, $file_name, "tree"); } else {
} $hash = $hash_base;
if (!defined $hash_base) {
$hash_base = $hash;
} }
} }
$/ = "\0"; $/ = "\0";