author | Lars Hjemli <hjemli@gmail.com> | 2007-01-17 00:10:39 (UTC) |
---|---|---|
committer | Lars Hjemli <hjemli@gmail.com> | 2007-01-17 00:10:39 (UTC) |
commit | 23734c5a2b607dca2d634cafdc63202a687f26d3 (patch) (unidiff) | |
tree | a8c240e9299936ffad6dbab335175af51372f32c | |
parent | a69061fdb7380d73715aeb3a0da6e91a24df90e4 (diff) | |
download | cgit-23734c5a2b607dca2d634cafdc63202a687f26d3.zip cgit-23734c5a2b607dca2d634cafdc63202a687f26d3.tar.gz cgit-23734c5a2b607dca2d634cafdc63202a687f26d3.tar.bz2 |
Extend repo summary with tag list
Show all tags in the repo below the branch list.
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
-rw-r--r-- | cgit.css | 8 | ||||
-rw-r--r-- | ui-summary.c | 74 |
2 files changed, 72 insertions, 10 deletions
@@ -1,196 +1,200 @@ | |||
1 | body { | 1 | body { |
2 | font-family: arial; | 2 | font-family: arial; |
3 | font-size: normal; | 3 | font-size: normal; |
4 | background: white; | 4 | background: white; |
5 | padding: 0em; | 5 | padding: 0em; |
6 | margin: 0.5em 1em; | 6 | margin: 0.5em 1em; |
7 | } | 7 | } |
8 | 8 | ||
9 | 9 | ||
10 | h2 { | 10 | h2 { |
11 | font-size: 100%; | 11 | font-size: 120%; |
12 | font-weight: bold; | 12 | font-weight: bold; |
13 | margin-bottom: 0.1em; | 13 | margin-bottom: 0.5em; |
14 | } | 14 | } |
15 | 15 | ||
16 | a { | 16 | a { |
17 | color: blue; | 17 | color: blue; |
18 | text-decoration: none; | 18 | text-decoration: none; |
19 | } | 19 | } |
20 | 20 | ||
21 | a:hover { | 21 | a:hover { |
22 | text-decoration: underline; | 22 | text-decoration: underline; |
23 | } | 23 | } |
24 | 24 | ||
25 | table.list { | 25 | table.list { |
26 | border: solid 1px black; | 26 | border: solid 1px black; |
27 | border-collapse: collapse; | 27 | border-collapse: collapse; |
28 | border: solid 1px #aaa; | 28 | border: solid 1px #aaa; |
29 | } | 29 | } |
30 | table.list tr { | 30 | table.list tr { |
31 | background: white; | 31 | background: white; |
32 | } | 32 | } |
33 | table.list tr:hover { | 33 | table.list tr:hover { |
34 | background: #eeb; | 34 | background: #eeb; |
35 | } | 35 | } |
36 | table.list tr.nohover:hover { | ||
37 | background: white; | ||
38 | } | ||
36 | table.list th { | 39 | table.list th { |
37 | font-weight: normal; | 40 | font-weight: normal; |
38 | background: #ddd; | 41 | background: #ddd; |
42 | border-top: solid 1px #aaa; | ||
39 | border-bottom: solid 1px #aaa; | 43 | border-bottom: solid 1px #aaa; |
40 | padding: 0.1em 0.5em 0.1em 0.5em; | 44 | padding: 0.1em 0.5em 0.1em 0.5em; |
41 | vertical-align: baseline; | 45 | vertical-align: baseline; |
42 | } | 46 | } |
43 | table.list td { | 47 | table.list td { |
44 | border: none; | 48 | border: none; |
45 | padding: 0.1em 0.5em 0.1em 0.5em; | 49 | padding: 0.1em 0.5em 0.1em 0.5em; |
46 | } | 50 | } |
47 | img { | 51 | img { |
48 | border: none; | 52 | border: none; |
49 | } | 53 | } |
50 | 54 | ||
51 | 55 | ||
52 | div#header { | 56 | div#header { |
53 | background-color: #ddd; | 57 | background-color: #ddd; |
54 | padding: 0.25em 0.25em 0.25em 0.5em; | 58 | padding: 0.25em 0.25em 0.25em 0.5em; |
55 | font-size: 150%; | 59 | font-size: 150%; |
56 | font-weight: bold; | 60 | font-weight: bold; |
57 | border: solid 1px #aaa; | 61 | border: solid 1px #aaa; |
58 | vertical-align: middle; | 62 | vertical-align: middle; |
59 | margin-bottom: 2em; | 63 | margin-bottom: 2em; |
60 | } | 64 | } |
61 | div#header img#logo { | 65 | div#header img#logo { |
62 | float: right; | 66 | float: right; |
63 | } | 67 | } |
64 | 68 | ||
65 | div#header input { | 69 | div#header input { |
66 | float: right; | 70 | float: right; |
67 | margin: 0.25em 1em; | 71 | margin: 0.25em 1em; |
68 | } | 72 | } |
69 | div#header a { | 73 | div#header a { |
70 | color: black; | 74 | color: black; |
71 | } | 75 | } |
72 | 76 | ||
73 | div#content { | 77 | div#content { |
74 | margin: 0.5em 0.5em; | 78 | margin: 0.5em 0.5em; |
75 | } | 79 | } |
76 | 80 | ||
77 | div#blob { | 81 | div#blob { |
78 | border: solid 1px black; | 82 | border: solid 1px black; |
79 | } | 83 | } |
80 | 84 | ||
81 | div.error { | 85 | div.error { |
82 | color: red; | 86 | color: red; |
83 | font-weight: bold; | 87 | font-weight: bold; |
84 | margin: 1em 2em; | 88 | margin: 1em 2em; |
85 | } | 89 | } |
86 | div.ls-blob, div.ls-dir { | 90 | div.ls-blob, div.ls-dir { |
87 | font-family: monospace; | 91 | font-family: monospace; |
88 | } | 92 | } |
89 | div.ls-dir a { | 93 | div.ls-dir a { |
90 | font-weight: bold; | 94 | font-weight: bold; |
91 | } | 95 | } |
92 | th.filesize, td.filesize { | 96 | th.filesize, td.filesize { |
93 | text-align: right; | 97 | text-align: right; |
94 | } | 98 | } |
95 | td.filesize { | 99 | td.filesize { |
96 | font-family: monospace; | 100 | font-family: monospace; |
97 | } | 101 | } |
98 | td.filemode { | 102 | td.filemode { |
99 | font-family: monospace; | 103 | font-family: monospace; |
100 | } | 104 | } |
101 | 105 | ||
102 | td.blob { | 106 | td.blob { |
103 | white-space: pre; | 107 | white-space: pre; |
104 | font-family: monospace; | 108 | font-family: monospace; |
105 | background-color: white; | 109 | background-color: white; |
106 | } | 110 | } |
107 | 111 | ||
108 | table.nowrap td { | 112 | table.nowrap td { |
109 | white-space: nowrap; | 113 | white-space: nowrap; |
110 | } | 114 | } |
111 | 115 | ||
112 | table.commit-info { | 116 | table.commit-info { |
113 | border-collapse: collapse; | 117 | border-collapse: collapse; |
114 | margin-top: 1.5em; | 118 | margin-top: 1.5em; |
115 | } | 119 | } |
116 | table.commit-info th { | 120 | table.commit-info th { |
117 | text-align: left; | 121 | text-align: left; |
118 | font-weight: normal; | 122 | font-weight: normal; |
119 | padding: 0.1em 1em 0.1em 0.1em; | 123 | padding: 0.1em 1em 0.1em 0.1em; |
120 | } | 124 | } |
121 | table.commit-info td { | 125 | table.commit-info td { |
122 | font-weight: normal; | 126 | font-weight: normal; |
123 | padding: 0.1em 1em 0.1em 0.1em; | 127 | padding: 0.1em 1em 0.1em 0.1em; |
124 | } | 128 | } |
125 | div.commit-subject { | 129 | div.commit-subject { |
126 | font-weight: bold; | 130 | font-weight: bold; |
127 | font-size: 125%; | 131 | font-size: 125%; |
128 | margin: 1.5em 0em 0.5em 0em; | 132 | margin: 1.5em 0em 0.5em 0em; |
129 | padding: 0em; | 133 | padding: 0em; |
130 | } | 134 | } |
131 | div.commit-msg { | 135 | div.commit-msg { |
132 | white-space: pre; | 136 | white-space: pre; |
133 | font-family: monospace; | 137 | font-family: monospace; |
134 | } | 138 | } |
135 | table.diffstat { | 139 | table.diffstat { |
136 | border-collapse: collapse; | 140 | border-collapse: collapse; |
137 | margin-top: 1.5em; | 141 | margin-top: 1.5em; |
138 | } | 142 | } |
139 | table.diffstat th { | 143 | table.diffstat th { |
140 | font-weight: normal; | 144 | font-weight: normal; |
141 | text-align: left; | 145 | text-align: left; |
142 | text-decoration: underline; | 146 | text-decoration: underline; |
143 | padding: 0.1em 1em 0.1em 0.1em; | 147 | padding: 0.1em 1em 0.1em 0.1em; |
144 | font-size: 100%; | 148 | font-size: 100%; |
145 | } | 149 | } |
146 | table.diffstat td { | 150 | table.diffstat td { |
147 | padding: 0.1em 1em 0.1em 0.1em; | 151 | padding: 0.1em 1em 0.1em 0.1em; |
148 | font-size: 100%; | 152 | font-size: 100%; |
149 | } | 153 | } |
150 | table.diffstat td span.modechange { | 154 | table.diffstat td span.modechange { |
151 | padding-left: 1em; | 155 | padding-left: 1em; |
152 | color: red; | 156 | color: red; |
153 | } | 157 | } |
154 | table.diffstat td.add a { | 158 | table.diffstat td.add a { |
155 | color: green; | 159 | color: green; |
156 | } | 160 | } |
157 | table.diffstat td.del a { | 161 | table.diffstat td.del a { |
158 | color: red; | 162 | color: red; |
159 | } | 163 | } |
160 | table.diffstat td.upd a { | 164 | table.diffstat td.upd a { |
161 | color: blue; | 165 | color: blue; |
162 | } | 166 | } |
163 | table.diffstat td.summary { | 167 | table.diffstat td.summary { |
164 | /* border-top: solid 1px black; */ | 168 | /* border-top: solid 1px black; */ |
165 | color: #888; | 169 | color: #888; |
166 | padding-top: 0.5em; | 170 | padding-top: 0.5em; |
167 | } | 171 | } |
168 | 172 | ||
169 | table.diff td { | 173 | table.diff td { |
170 | border: solid 1px black; | 174 | border: solid 1px black; |
171 | font-family: monospace; | 175 | font-family: monospace; |
172 | white-space: pre; | 176 | white-space: pre; |
173 | } | 177 | } |
174 | 178 | ||
175 | table.diff td div.hunk { | 179 | table.diff td div.hunk { |
176 | background: #ccc; | 180 | background: #ccc; |
177 | } | 181 | } |
178 | 182 | ||
179 | table.diff td div.add { | 183 | table.diff td div.add { |
180 | color: green; | 184 | color: green; |
181 | } | 185 | } |
182 | 186 | ||
183 | table.diff td div.del { | 187 | table.diff td div.del { |
184 | color: red; | 188 | color: red; |
185 | } | 189 | } |
186 | 190 | ||
187 | .sha1 { | 191 | .sha1 { |
188 | font-family: courier; | 192 | font-family: courier; |
189 | font-size: 90%; | 193 | font-size: 90%; |
190 | } | 194 | } |
191 | .left { | 195 | .left { |
192 | text-align: left; | 196 | text-align: left; |
193 | } | 197 | } |
194 | .right { | 198 | .right { |
195 | text-align: right; | 199 | text-align: right; |
196 | } | 200 | } |
diff --git a/ui-summary.c b/ui-summary.c index de95053..1591632 100644 --- a/ui-summary.c +++ b/ui-summary.c | |||
@@ -1,67 +1,125 @@ | |||
1 | /* ui-summary.c: functions for generating repo summary page | 1 | /* ui-summary.c: functions for generating repo summary page |
2 | * | 2 | * |
3 | * Copyright (C) 2006 Lars Hjemli | 3 | * Copyright (C) 2006 Lars Hjemli |
4 | * | 4 | * |
5 | * Licensed under GNU General Public License v2 | 5 | * Licensed under GNU General Public License v2 |
6 | * (see COPYING for full license text) | 6 | * (see COPYING for full license text) |
7 | */ | 7 | */ |
8 | 8 | ||
9 | #include "cgit.h" | 9 | #include "cgit.h" |
10 | 10 | ||
11 | static int cgit_print_branch_cb(const char *refname, const unsigned char *sha1, | 11 | static int cgit_print_branch_cb(const char *refname, const unsigned char *sha1, |
12 | int flags, void *cb_data) | 12 | int flags, void *cb_data) |
13 | { | 13 | { |
14 | struct commit *commit; | 14 | struct commit *commit; |
15 | struct commitinfo *info; | 15 | struct commitinfo *info; |
16 | char buf[256], *url; | 16 | char buf[256], *url; |
17 | 17 | ||
18 | strncpy(buf, refname, sizeof(buf)); | ||
18 | commit = lookup_commit(sha1); | 19 | commit = lookup_commit(sha1); |
19 | if (commit && !parse_commit(commit)){ | 20 | if (commit && !parse_commit(commit)){ |
20 | info = cgit_parse_commit(commit); | 21 | info = cgit_parse_commit(commit); |
21 | html("<tr><td>"); | 22 | html("<tr><td>"); |
22 | url = cgit_pageurl(cgit_query_repo, "log", | 23 | url = cgit_pageurl(cgit_query_repo, "log", |
23 | fmt("h=%s", refname)); | 24 | fmt("h=%s", refname)); |
24 | html_link_open(url, NULL, NULL); | 25 | html_link_open(url, NULL, NULL); |
25 | strncpy(buf, refname, sizeof(buf)); | ||
26 | html_txt(buf); | 26 | html_txt(buf); |
27 | html_link_close(); | 27 | html_link_close(); |
28 | html("</td><td>"); | 28 | html("</td><td>"); |
29 | cgit_print_date(commit->date); | 29 | cgit_print_date(commit->date); |
30 | html("</td><td>"); | 30 | html("</td><td>"); |
31 | html_txt(info->author); | ||
32 | html("</td><td>"); | ||
31 | url = cgit_pageurl(cgit_query_repo, "commit", | 33 | url = cgit_pageurl(cgit_query_repo, "commit", |
32 | fmt("id=%s", sha1_to_hex(sha1))); | 34 | fmt("id=%s", sha1_to_hex(sha1))); |
33 | html_link_open(url, NULL, NULL); | 35 | html_link_open(url, NULL, NULL); |
34 | html_ntxt(80, info->subject); | 36 | html_ntxt(80, info->subject); |
35 | html_link_close(); | 37 | html_link_close(); |
36 | html("</td><td>"); | ||
37 | html_txt(info->author); | ||
38 | html("</td></tr>\n"); | 38 | html("</td></tr>\n"); |
39 | cgit_free_commitinfo(info); | 39 | cgit_free_commitinfo(info); |
40 | } else { | 40 | } else { |
41 | html("<tr><td>"); | 41 | html("<tr><td>"); |
42 | html_txt(buf); | 42 | html_txt(buf); |
43 | html("</td><td colspan='3'>"); | ||
44 | htmlf("*** bad ref %s ***", sha1_to_hex(sha1)); | ||
45 | html("</td></tr>\n"); | ||
46 | } | ||
47 | return 0; | ||
48 | } | ||
49 | |||
50 | static int cgit_print_tag_cb(const char *refname, const unsigned char *sha1, | ||
51 | int flags, void *cb_data) | ||
52 | { | ||
53 | struct tag *tag; | ||
54 | struct taginfo *info; | ||
55 | char buf[256], *page, *url; | ||
56 | |||
57 | strncpy(buf, refname, sizeof(buf)); | ||
58 | tag = lookup_tag(sha1); | ||
59 | if (tag && !parse_tag(tag) && (info = cgit_parse_tag(tag))){ | ||
60 | html("<tr><td>"); | ||
61 | url = cgit_pageurl(cgit_query_repo, "view", | ||
62 | fmt("id=%s", sha1_to_hex(sha1))); | ||
63 | html_link_open(url, NULL, NULL); | ||
64 | html_txt(buf); | ||
65 | html_link_close(); | ||
66 | html("</td><td>"); | ||
67 | if (info->tagger_date > 0) | ||
68 | cgit_print_date(info->tagger_date); | ||
43 | html("</td><td>"); | 69 | html("</td><td>"); |
44 | htmlf("*** bad ref %s", sha1_to_hex(sha1)); | 70 | if (info->tagger) |
71 | html(info->tagger); | ||
72 | html("</td><td>"); | ||
73 | if (tag->tagged->type == OBJ_COMMIT) | ||
74 | page = "commit"; | ||
75 | else if (tag->tagged->type == OBJ_TREE) | ||
76 | page = "tree"; | ||
77 | else | ||
78 | page = "view"; | ||
79 | |||
80 | url = cgit_pageurl(cgit_query_repo, page, | ||
81 | fmt("id=%s", sha1_to_hex(tag->tagged->sha1))); | ||
82 | html_link_open(url, NULL, NULL); | ||
83 | htmlf("%s %s", type_names[tag->tagged->type], | ||
84 | sha1_to_hex(tag->tagged->sha1)); | ||
85 | html_link_close(); | ||
86 | html("</td></tr>\n"); | ||
87 | } else { | ||
88 | html("<tr><td>"); | ||
89 | html_txt(buf); | ||
90 | html("</td><td colspan='3'>"); | ||
91 | htmlf("*** bad ref %s ***", sha1_to_hex(sha1)); | ||
45 | html("</td></tr>\n"); | 92 | html("</td></tr>\n"); |
46 | } | 93 | } |
47 | return 0; | 94 | return 0; |
48 | } | 95 | } |
49 | 96 | ||
50 | static void cgit_print_branches() | 97 | static void cgit_print_branches() |
51 | { | 98 | { |
52 | html("<table class='list nowrap'>"); | ||
53 | html("<tr><th class='left'>Branch</th>" | 99 | html("<tr><th class='left'>Branch</th>" |
54 | "<th class='left'>Updated</th>" | 100 | "<th class='left'>Updated</th>" |
55 | "<th class='left'>Commit subject</th>" | 101 | "<th class='left'>Author</th>" |
56 | "<th class='left'>Author</th></tr>\n"); | 102 | "<th class='left'>Head commit</th></tr>\n"); |
57 | for_each_branch_ref(cgit_print_branch_cb, NULL); | 103 | for_each_branch_ref(cgit_print_branch_cb, NULL); |
58 | html("</table>"); | 104 | } |
105 | |||
106 | static void cgit_print_tags() | ||
107 | { | ||
108 | html("<tr><th class='left'>Tag</th>" | ||
109 | "<th class='left'>Created</th>" | ||
110 | "<th class='left'>Author</th>" | ||
111 | "<th class='left'>Reference</th></tr>\n"); | ||
112 | for_each_tag_ref(cgit_print_tag_cb, NULL); | ||
59 | } | 113 | } |
60 | 114 | ||
61 | void cgit_print_summary() | 115 | void cgit_print_summary() |
62 | { | 116 | { |
63 | html("<h2>"); | 117 | html("<h2>"); |
64 | html_txt("Repo summary page"); | 118 | html_txt("Repo summary page"); |
65 | html("</h2>"); | 119 | html("</h2>"); |
120 | html("<table class='list nowrap'>"); | ||
66 | cgit_print_branches(); | 121 | cgit_print_branches(); |
122 | html("<tr class='nohover'><td colspan='4'> </td></tr>"); | ||
123 | cgit_print_tags(); | ||
124 | html("</table>"); | ||
67 | } | 125 | } |