diff options
| author | Junio C Hamano <junkio@cox.net> | 2006-07-05 16:40:15 -0700 | 
|---|---|---|
| committer | Junio C Hamano <junkio@cox.net> | 2006-07-05 16:40:15 -0700 | 
| commit | bc483d04804888c2da64e4c6685c2860a9041122 (patch) | |
| tree | 65470b5467691e41b8e9a8a0fc6fd6d8236c7be0 | |
| parent | a3d470c2d5a4da60184928ccbdb1fb3708ceab16 (diff) | |
| parent | 4a87b43e374626a95c14362f21c9ca1023638a2c (diff) | |
| download | git-bc483d04804888c2da64e4c6685c2860a9041122.tar.gz | |
Merge branch 'lt/gitweb'
* lt/gitweb:
  gitweb: Declare global variables with "our"
  gitweb: Enable tree (directory) history display
  gitweb: optimize per-file history generation
| -rwxr-xr-x | gitweb/gitweb.cgi | 66 | 
1 files changed, 31 insertions, 35 deletions
| diff --git a/gitweb/gitweb.cgi b/gitweb/gitweb.cgi index 035e76d0a3..3e2790c5d6 100755 --- a/gitweb/gitweb.cgi +++ b/gitweb/gitweb.cgi @@ -16,21 +16,21 @@ use Encode;  use Fcntl ':mode';  binmode STDOUT, ':utf8'; -my $cgi = new CGI; -my $version = "267"; -my $my_url = $cgi->url(); -my $my_uri = $cgi->url(-absolute => 1); -my $rss_link = ""; +our $cgi = new CGI; +our $version = "267"; +our $my_url = $cgi->url(); +our $my_uri = $cgi->url(-absolute => 1); +our $rss_link = "";  # location of the git-core binaries -my $gitbin = "/usr/bin"; +our $gitbin = "/usr/bin";  # absolute fs-path which will be prepended to the project path -#my $projectroot = "/pub/scm"; -my $projectroot = "/home/kay/public_html/pub/scm"; +#our $projectroot = "/pub/scm"; +our $projectroot = "/home/kay/public_html/pub/scm";  # version of the git-core binaries -my $git_version = qx($gitbin/git --version); +our $git_version = qx($gitbin/git --version);  if ($git_version =~ m/git version (.*)$/) {  	$git_version = $1;  } else { @@ -38,32 +38,31 @@ if ($git_version =~ m/git version (.*)$/) {  }  # location for temporary files needed for diffs -my $git_temp = "/tmp/gitweb"; +our $git_temp = "/tmp/gitweb";  # target of the home link on top of all pages -my $home_link = $my_uri; +our $home_link = $my_uri;  # html text to include at home page -my $home_text = "indextext.html"; +our $home_text = "indextext.html";  # URI of default stylesheet -my $stylesheet = "gitweb.css"; +our $stylesheet = "gitweb.css";  # source of projects list -#my $projects_list = $projectroot; -my $projects_list = "index/index.aux"; +#our $projects_list = $projectroot; +our $projects_list = "index/index.aux";  # default blob_plain mimetype and default charset for text/plain blob -my $default_blob_plain_mimetype = 'text/plain'; -my $default_text_plain_charset  = undef; +our $default_blob_plain_mimetype = 'text/plain'; +our $default_text_plain_charset  = undef;  # file to use for guessing MIME types before trying /etc/mime.types  # (relative to the current git repository) -my $mimetypes_file = undef; - +our $mimetypes_file = undef;  # input validation and dispatch -my $action = $cgi->param('a'); +our $action = $cgi->param('a');  if (defined $action) {  	if ($action =~ m/[^0-9a-zA-Z\.\-_]/) {  		undef $action; @@ -78,7 +77,7 @@ if (defined $action) {  	}  } -my $order = $cgi->param('o'); +our $order = $cgi->param('o');  if (defined $order) {  	if ($order =~ m/[^0-9a-zA-Z_]/) {  		undef $order; @@ -86,7 +85,7 @@ if (defined $order) {  	}  } -my $project = ($cgi->param('p') || $ENV{'PATH_INFO'}); +our $project = ($cgi->param('p') || $ENV{'PATH_INFO'});  if (defined $project) {  	$project =~ s|^/||; $project =~ s|/$||;  	$project = validate_input($project); @@ -109,7 +108,7 @@ if (defined $project) {  	exit;  } -my $file_name = $cgi->param('f'); +our $file_name = $cgi->param('f');  if (defined $file_name) {  	$file_name = validate_input($file_name);  	if (!defined($file_name)) { @@ -117,7 +116,7 @@ if (defined $file_name) {  	}  } -my $hash = $cgi->param('h'); +our $hash = $cgi->param('h');  if (defined $hash) {  	$hash = validate_input($hash);  	if (!defined($hash)) { @@ -125,7 +124,7 @@ if (defined $hash) {  	}  } -my $hash_parent = $cgi->param('hp'); +our $hash_parent = $cgi->param('hp');  if (defined $hash_parent) {  	$hash_parent = validate_input($hash_parent);  	if (!defined($hash_parent)) { @@ -133,7 +132,7 @@ if (defined $hash_parent) {  	}  } -my $hash_base = $cgi->param('hb'); +our $hash_base = $cgi->param('hb');  if (defined $hash_base) {  	$hash_base = validate_input($hash_base);  	if (!defined($hash_base)) { @@ -141,7 +140,7 @@ if (defined $hash_base) {  	}  } -my $page = $cgi->param('pg'); +our $page = $cgi->param('pg');  if (defined $page) {  	if ($page =~ m/[^0-9]$/) {  		undef $page; @@ -149,7 +148,7 @@ if (defined $page) {  	}  } -my $searchtext = $cgi->param('s'); +our $searchtext = $cgi->param('s');  if (defined $searchtext) {  	if ($searchtext =~ m/[^a-zA-Z0-9_\.\/\-\+\:\@ ]/) {  		undef $searchtext; @@ -1676,6 +1675,7 @@ sub git_tree {  			      "</td>\n" .  			      "<td class=\"link\">" .  			      $cgi->a({-href => "$my_uri?" . esc_param("p=$project;a=tree;h=$t_hash$base_key;f=$base$t_name")}, "tree") . +			      " | " . $cgi->a({-href => "$my_uri?" . esc_param("p=$project;a=history;h=$hash_base;f=$base$t_name")}, "history") .  			      "</td>\n";  		}  		print "</tr>\n"; @@ -2295,16 +2295,13 @@ sub git_history {  	      "</div>\n";  	print "<div class=\"page_path\"><b>/" . esc_html($file_name) . "</b><br/></div>\n"; -	open my $fd, "-|", "$gitbin/git-rev-list $hash | $gitbin/git-diff-tree -r --stdin -- \'$file_name\'"; -	my $commit; +	open my $fd, "-|", +		"$gitbin/git-rev-list --full-history $hash -- \'$file_name\'";  	print "<table cellspacing=\"0\">\n";  	my $alternate = 0;  	while (my $line = <$fd>) {  		if ($line =~ m/^([0-9a-fA-F]{40})/){ -			$commit = $1; -			next; -		} -		if ($line =~ m/^:([0-7]{6}) ([0-7]{6}) ([0-9a-fA-F]{40}) ([0-9a-fA-F]{40}) (.)\t(.*)$/ && (defined $commit)) { +			my $commit = $1;  			my %co = git_read_commit($commit);  			if (!%co) {  				next; @@ -2336,7 +2333,6 @@ sub git_history {  			}  			print "</td>\n" .  			      "</tr>\n"; -			undef $commit;  		}  	}  	print "</table>\n"; | 
