\n";
if (!defined($order) || (defined($order) && ($order eq "project"))) {
@projects = sort {$a->{'path'} cmp $b->{'path'}} @projects;
@@ -882,15 +901,7 @@ sub git_project_list {
print "" . $cgi->a({-href => "$my_uri?" . esc_param("p=$pr->{'path'};a=summary"), -class => "list"}, esc_html($pr->{'path'})) . " | \n" .
"$pr->{'descr'} | \n" .
"" . chop_str($pr->{'owner'}, 15) . " | \n";
- my $colored_age;
- if ($pr->{'commit'}{'age'} < 60*60*2) {
- $colored_age = "$pr->{'commit'}{'age_string'}";
- } elsif ($pr->{'commit'}{'age'} < 60*60*24*2) {
- $colored_age = "$pr->{'commit'}{'age_string'}";
- } else {
- $colored_age = "$pr->{'commit'}{'age_string'}";
- }
- print "$colored_age | \n" .
+ print "{'commit'}{'age'}) . "\">" . $pr->{'commit'}{'age_string'} . " | \n" .
"" .
$cgi->a({-href => "$my_uri?" . esc_param("p=$pr->{'path'};a=summary")}, "summary") .
" | " . $cgi->a({-href => "$my_uri?" . esc_param("p=$pr->{'path'};a=shortlog")}, "shortlog") .
@@ -1234,7 +1245,7 @@ sub git_blame {
print " " . esc_html($file_name) . " \n";
print "\n";
print <
+
Commit |
Age |
@@ -1255,7 +1266,7 @@ HTML
my $data;
my $age;
my $age_str;
- my $age_style;
+ my $age_class;
chomp $line;
$line_class_num = ($line_class_num + 1) % $line_class_len;
@@ -1267,16 +1278,14 @@ HTML
$lineno = $4;
$data = $5;
} else {
- print qq( Unable to parse: $line | \n);
+ print qq( Unable to parse: $line | \n);
next;
}
$short_rev = substr ($long_rev, 0, 8);
$age = time () - $time;
$age_str = age_string ($age);
$age_str =~ s/ / /g;
- $age_style = 'font-style: italic;';
- $age_style .= ' color: #009900; background: transparent;' if ($age < 60*60*24*2);
- $age_style .= ' font-weight: bold;' if ($age < 60*60*2);
+ $age_class = age_class($age);
$author = esc_html ($author);
$author =~ s/ / /g;
# escape tabs
@@ -1287,15 +1296,14 @@ HTML
}
}
$data = esc_html ($data);
- $data =~ s/ / /g;
print <
- $short_rev.. |
- $age_str |
+ $short_rev.. |
+ $age_str |
$author |
- $lineno |
- $data |
+ $lineno |
+ $data |
HTML
} # while (my $line = <$fd>)
@@ -1640,7 +1648,7 @@ sub git_tree {
print "\n";
}
$alternate ^= 1;
- print "" . mode_str($t_mode) . " | \n";
+ print "" . mode_str($t_mode) . " | \n";
if ($t_type eq "blob") {
print "" .
$cgi->a({-href => "$my_uri?" . esc_param("p=$project;a=blob;h=$t_hash$base_key;f=$base$t_name"), -class => "list"}, esc_html($t_name)) .
@@ -1906,7 +1914,7 @@ sub git_commit {
" | " .
" | $ad{'rfc2822'}";
if ($ad{'hour_local'} < 6) {
- printf(" (%02d:%02d %s)", $ad{'hour_local'}, $ad{'minute_local'}, $ad{'tz_local'});
+ printf(" (%02d:%02d %s)", $ad{'hour_local'}, $ad{'minute_local'}, $ad{'tz_local'});
} else {
printf(" (%02d:%02d %s)", $ad{'hour_local'}, $ad{'minute_local'}, $ad{'tz_local'});
}
@@ -1914,10 +1922,10 @@ sub git_commit {
" | \n";
print "committer | " . esc_html($co{'committer'}) . " | \n";
print " | $cd{'rfc2822'}" . sprintf(" (%02d:%02d %s)", $cd{'hour_local'}, $cd{'minute_local'}, $cd{'tz_local'}) . " | \n";
- print "commit | $co{'id'} | \n";
+ print "commit | $co{'id'} | \n";
print "" .
"tree | " .
- "" .
+ " | " .
$cgi->a({-href => "$my_uri?" . esc_param("p=$project;a=tree;h=$co{'tree'};hb=$hash"), class => "list"}, $co{'tree'}) .
" | " .
"" . $cgi->a({-href => "$my_uri?" . esc_param("p=$project;a=tree;h=$co{'tree'};hb=$hash")}, "tree") .
@@ -1927,7 +1935,7 @@ sub git_commit {
foreach my $par (@$parents) {
print " | " .
"parent | " .
- "" . $cgi->a({-href => "$my_uri?" . esc_param("p=$project;a=commit;h=$par"), class => "list"}, $par) . " | " .
+ "" . $cgi->a({-href => "$my_uri?" . esc_param("p=$project;a=commit;h=$par"), class => "list"}, $par) . " | " .
"" .
$cgi->a({-href => "$my_uri?" . esc_param("p=$project;a=commit;h=$par")}, "commit") .
" | " . $cgi->a({-href => "$my_uri?" . esc_param("p=$project;a=commitdiff;h=$hash;hp=$par")}, "commitdiff") .
@@ -1952,7 +1960,7 @@ sub git_commit {
}
if ($line =~ m/^ *(signed[ \-]off[ \-]by[ :]|acked[ \-]by[ :]|cc[ :])/i) {
$signed = 1;
- print "" . esc_html($line) . " \n";
+ print "" . esc_html($line) . " \n";
} else {
$signed = 0;
print format_log_line_html($line) . " \n";
@@ -1964,7 +1972,7 @@ sub git_commit {
print(($#difftree + 1) . " files changed:\n");
}
print "\n";
- print "\n";
+ print "\n";
my $alternate = 0;
foreach my $line (@difftree) {
# ':100644 100644 03b218260e99b78c6df0ed378e59ed9205ccc96d 3b93d5e7cc7f7dd4ebed13a5cc1a4ad976fc94d8 M ls-files.c'
@@ -1992,12 +2000,12 @@ sub git_commit {
}
print "" .
$cgi->a({-href => "$my_uri?" . esc_param("p=$project;a=blob;h=$to_id;hb=$hash;f=$file"), -class => "list"}, esc_html($file)) . " | \n" .
- "[new " . file_type($to_mode) . "$mode_chng] | \n" .
+ "[new " . file_type($to_mode) . "$mode_chng] | \n" .
"" . $cgi->a({-href => "$my_uri?" . esc_param("p=$project;a=blob;h=$to_id;hb=$hash;f=$file")}, "blob") . " | \n";
} elsif ($status eq "D") {
print "" .
$cgi->a({-href => "$my_uri?" . esc_param("p=$project;a=blob;h=$from_id;hb=$hash;f=$file"), -class => "list"}, esc_html($file)) . " | \n" .
- "[deleted " . file_type($from_mode). "] | \n" .
+ "[deleted " . file_type($from_mode). "] | \n" .
"" .
$cgi->a({-href => "$my_uri?" . esc_param("p=$project;a=blob;h=$from_id;hb=$hash;f=$file")}, "blob") .
" | " . $cgi->a({-href => "$my_uri?" . esc_param("p=$project;a=history;h=$hash;f=$file")}, "history") .
@@ -2005,7 +2013,7 @@ sub git_commit {
} elsif ($status eq "M" || $status eq "T") {
my $mode_chnge = "";
if ($from_mode != $to_mode) {
- $mode_chnge = " [changed";
+ $mode_chnge = " [changed";
if (((oct $from_mode) & S_IFMT) != ((oct $to_mode) & S_IFMT)) {
$mode_chnge .= " from " . file_type($from_mode) . " to " . file_type($to_mode);
}
@@ -2041,7 +2049,7 @@ sub git_commit {
}
print " | " .
$cgi->a({-href => "$my_uri?" . esc_param("p=$project;a=blob;h=$to_id;hb=$hash;f=$to_file"), -class => "list"}, esc_html($to_file)) . " | \n" .
- "[moved from " .
+ " | [moved from " .
$cgi->a({-href => "$my_uri?" . esc_param("p=$project;a=blob;h=$from_id;hb=$hash;f=$from_file"), -class => "list"}, esc_html($from_file)) .
" with " . (int $similarity) . "% similarity$mode_chng] | \n" .
"" .
@@ -2401,7 +2409,7 @@ sub git_search {
my $match = esc_html($2) || "";
my $trail = esc_html($3) || "";
$trail = chop_str($trail, 30, 10);
- my $text = "$lead$match$trail";
+ my $text = "$lead$match$trail";
print chop_str($text, 80, 5) . " \n";
}
}
@@ -2450,7 +2458,7 @@ sub git_search {
while (my $setref = shift @files) {
my %set = %$setref;
print $cgi->a({-href => "$my_uri?" . esc_param("p=$project;a=blob;h=$set{'id'};hb=$co{'id'};f=$set{'file'}"), class => "list"},
- "" . esc_html($set{'file'}) . "") .
+ "" . esc_html($set{'file'}) . "") .
" \n";
}
print " | \n" .
diff --git a/gitweb/gitweb.css b/gitweb/gitweb.css
index 4378067d3c..ac6a3c774d 100644
--- a/gitweb/gitweb.css
+++ b/gitweb/gitweb.css
@@ -1,230 +1,320 @@
body {
- font-family: sans-serif;
- font-size: 12px;
- border:solid #d9d8d1;
- border-width: 1px;
- margin: 10px;
- background-color: #ffffff;
- color: #000000;
+ font-family: sans-serif;
+ font-size: 12px;
+ border:solid #d9d8d1;
+ border-width: 1px;
+ margin: 10px;
+ background-color: #ffffff;
+ color: #000000;
}
a {
- color: #0000cc;
+ color: #0000cc;
}
a:hover, a:visited, a:active {
- color: #880000;
+ color: #880000;
}
div.page_header {
- height: 25px;
- padding: 8px;
- font-size: 18px;
- font-weight: bold;
- background-color: #d9d8d1;
+ height: 25px;
+ padding: 8px;
+ font-size: 18px;
+ font-weight: bold;
+ background-color: #d9d8d1;
}
div.page_header a:visited, a.header {
- color: #0000cc;
+ color: #0000cc;
}
div.page_header a:hover {
- color: #880000;
+ color: #880000;
}
div.page_nav {
- padding:8px;
+ padding:8px;
}
div.page_nav a:visited {
- color: #0000cc;
+ color: #0000cc;
}
div.page_path {
- padding: 8px;
- border: solid #d9d8d1;
- border-width: 0px 0px 1px;
+ padding: 8px;
+ border: solid #d9d8d1;
+ border-width: 0px 0px 1px;
}
div.page_footer {
- height: 17px;
- padding: 4px 8px;
- background-color: #d9d8d1;
+ height: 17px;
+ padding: 4px 8px;
+ background-color: #d9d8d1;
}
div.page_footer_text {
- float: left;
- color: #555555;
- font-style: italic;
+ float: left;
+ color: #555555;
+ font-style: italic;
}
div.page_body {
- padding: 8px;
+ padding: 8px;
}
div.title, a.title {
- display: block;
- padding: 6px 8px;
- font-weight: bold;
- background-color: #edece6;
- text-decoration: none;
- color: #000000;
+ display: block;
+ padding: 6px 8px;
+ font-weight: bold;
+ background-color: #edece6;
+ text-decoration: none;
+ color: #000000;
}
a.title:hover {
- background-color: #d9d8d1;
+ background-color: #d9d8d1;
}
div.title_text {
- padding: 6px 0px;
- border: solid #d9d8d1;
- border-width: 0px 0px 1px;
+ padding: 6px 0px;
+ border: solid #d9d8d1;
+ border-width: 0px 0px 1px;
}
div.log_body {
- padding: 8px 8px 8px 150px;
+ padding: 8px 8px 8px 150px;
}
span.age {
- position: relative;
- float: left;
- width: 142px;
- font-style:italic;
+ position: relative;
+ float: left;
+ width: 142px;
+ font-style: italic;
+}
+
+div.page_body span.signoff {
+ color: #888888;
}
div.log_link {
- padding: 0px 8px;
- font-size: 10px;
- font-family: sans-serif;
- font-style:normal;
- position: relative;
- float: left;
- width: 136px;
+ padding: 0px 8px;
+ font-size: 10px;
+ font-family: sans-serif;
+ font-style: normal;
+ position: relative;
+ float: left;
+ width: 136px;
}
div.list_head {
- padding: 6px 8px 4px;
- border: solid #d9d8d1;
- border-width: 1px 0px 0px;
- font-style: italic;
+ padding: 6px 8px 4px;
+ border: solid #d9d8d1;
+ border-width: 1px 0px 0px;
+ font-style: italic;
}
a.list {
- text-decoration: none;
- color: #000000;
+ text-decoration: none;
+ color: #000000;
}
a.list:hover {
- text-decoration: underline;
- color: #880000;
+ text-decoration: underline;
+ color: #880000;
}
a.text {
- text-decoration: none;
- color: #0000cc;
+ text-decoration: none;
+ color: #0000cc;
}
a.text:visited {
- text-decoration: none;
- color: #880000;
+ text-decoration: none;
+ color: #880000;
}
a.text:hover {
- text-decoration: underline;
- color: #880000;
+ text-decoration: underline;
+ color: #880000;
}
table {
- padding: 8px 4px;
+ padding: 8px 4px;
+}
+
+table.project_list, table.diff_tree {
+ border-spacing: 0;
+}
+
+table.blame {
+ border-collapse: collapse;
}
th {
- padding: 2px 5px;
- font-size: 12px;
- text-align: left;
+ padding: 2px 5px;
+ font-size: 12px;
+ text-align: left;
}
tr.light:hover {
- background-color: #edece6;
+ background-color: #edece6;
}
tr.dark {
- background-color: #f6f6f0;
+ background-color: #f6f6f0;
}
tr.dark:hover {
- background-color: #edece6;
+ background-color: #edece6;
}
-
td {
- padding: 2px 5px;
- font-size: 12px;
- vertical-align:top;
+ padding: 2px 5px;
+ font-size: 12px;
+ vertical-align: top;
}
td.link {
- padding: 2px 5px;
- font-family: sans-serif;
- font-size: 10px;
+ padding: 2px 5px;
+ font-family: sans-serif;
+ font-size: 10px;
}
-div.pre {
- font-family: monospace;
- font-size: 12px;
- white-space: pre;
+td.sha1 {
+ font-family: monospace;
+}
+
+td.error {
+ color: red;
+ background-color: yellow;
+}
+
+table.diff_tree span.file_status.new {
+ color: #008000;
+}
+
+table.diff_tree span.file_status.deleted {
+ color: #c00000;
+}
+
+table.diff_tree span.file_status.moved,
+table.diff_tree span.file_status.mode_chnge {
+ color: #777777;
+}
+
+/* age2: 60*60*24*2 <= age */
+table.project_list td.age2, table.blame td.age2 {
+ font-style: italic;
+}
+
+/* age1: 60*60*2 <= age < 60*60*24*2 */
+table.project_list td.age1 {
+ color: #009900;
+ font-style: italic;
+}
+
+table.blame td.age1 {
+ color: #009900;
+ background: transparent;
+}
+
+/* age0: age < 60*60*2 */
+table.project_list td.age0 {
+ color: #009900;
+ font-style: italic;
+ font-weight: bold;
+}
+
+table.blame td.age0 {
+ color: #009900;
+ background: transparent;
+ font-weight: bold;
+}
+
+td.pre, div.pre, div.diff {
+ font-family: monospace;
+ font-size: 12px;
+ white-space: pre;
+}
+
+td.mode {
+ font-family: monospace;
+}
+
+div.diff.add {
+ color: #008800;
+}
+
+div.diff.rem {
+ color: #cc0000;
+}
+
+div.diff.chunk_header {
+ color: #990099;
}
div.diff_info {
- font-family: monospace;
- color: #000099;
- background-color: #edece6;
- font-style: italic;
+ font-family: monospace;
+ color: #000099;
+ background-color: #edece6;
+ font-style: italic;
}
div.index_include {
- border: solid #d9d8d1;
- border-width: 0px 0px 1px;
- padding: 12px 8px;
+ border: solid #d9d8d1;
+ border-width: 0px 0px 1px;
+ padding: 12px 8px;
}
div.search {
- margin: 4px 8px;
- position: absolute;
- top: 56px;
- right: 12px
+ margin: 4px 8px;
+ position: absolute;
+ top: 56px;
+ right: 12px
+}
+
+td.linenr {
+ text-align: right;
}
a.linenr {
- color: #999999;
- text-decoration: none
+ color: #999999;
+ text-decoration: none
}
a.rss_logo {
- float: right;
- padding: 3px 0px;
- width: 35px;
- line-height: 10px;
- border: 1px solid;
- border-color: #fcc7a5 #7d3302 #3e1a01 #ff954e;
- color: #ffffff;
- background-color: #ff6600;
- font-weight: bold;
- font-family: sans-serif;
- font-size: 10px;
- text-align: center;
- text-decoration: none;
+ float: right;
+ padding: 3px 0px;
+ width: 35px;
+ line-height: 10px;
+ border: 1px solid;
+ border-color: #fcc7a5 #7d3302 #3e1a01 #ff954e;
+ color: #ffffff;
+ background-color: #ff6600;
+ font-weight: bold;
+ font-family: sans-serif;
+ font-size: 10px;
+ text-align: center;
+ text-decoration: none;
}
a.rss_logo:hover {
- background-color: #ee5500;
+ background-color: #ee5500;
}
span.tag {
- padding: 0px 4px;
- font-size: 10px;
- font-weight: normal;
- background-color: #ffffaa;
- border: 1px solid;
- border-color: #ffffcc #ffee00 #ffee00 #ffffcc;
+ padding: 0px 4px;
+ font-size: 10px;
+ font-weight: normal;
+ background-color: #ffffaa;
+ border: 1px solid;
+ border-color: #ffffcc #ffee00 #ffee00 #ffffcc;
+}
+
+span.atnight {
+ color: #cc0000;
+}
+
+span.match {
+ color: #e00000;
}
| |