author | Lars Hjemli <hjemli@gmail.com> | 2007-05-15 22:26:23 (UTC) |
---|---|---|
committer | Lars Hjemli <hjemli@gmail.com> | 2007-05-15 22:26:23 (UTC) |
commit | a2ddc10479ec463708e422ca5ce7ec02c22a7d02 (patch) (unidiff) | |
tree | e099ad98a79d61eb6e368a7e7972700f0e65b9ae /ui-summary.c | |
parent | b28b105ec172b258ae5d629381a5890697c2f938 (diff) | |
download | cgit-a2ddc10479ec463708e422ca5ce7ec02c22a7d02.zip cgit-a2ddc10479ec463708e422ca5ce7ec02c22a7d02.tar.gz cgit-a2ddc10479ec463708e422ca5ce7ec02c22a7d02.tar.bz2 |
Change commit-view to expect h parameter, not id
The change makes the commit-page benefit from repo.defbranch.
Signed-off-by: Lars Hjemli <hjemli@gmail.com>
-rw-r--r-- | ui-summary.c | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/ui-summary.c b/ui-summary.c index b99ea98..e7158cc 100644 --- a/ui-summary.c +++ b/ui-summary.c | |||
@@ -1,206 +1,210 @@ | |||
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 header; | 11 | static int header; |
12 | 12 | ||
13 | static int cgit_print_branch_cb(const char *refname, const unsigned char *sha1, | 13 | static int cgit_print_branch_cb(const char *refname, const unsigned char *sha1, |
14 | int flags, void *cb_data) | 14 | int flags, void *cb_data) |
15 | { | 15 | { |
16 | struct commit *commit; | 16 | struct commit *commit; |
17 | struct commitinfo *info; | 17 | struct commitinfo *info; |
18 | char buf[256], *url; | 18 | char buf[256], *url; |
19 | 19 | ||
20 | strncpy(buf, refname, sizeof(buf)); | 20 | strncpy(buf, refname, sizeof(buf)); |
21 | commit = lookup_commit(sha1); | 21 | commit = lookup_commit(sha1); |
22 | if (commit && !parse_commit(commit)){ | 22 | if (commit && !parse_commit(commit)){ |
23 | info = cgit_parse_commit(commit); | 23 | info = cgit_parse_commit(commit); |
24 | html("<tr><td>"); | 24 | html("<tr><td>"); |
25 | url = cgit_pageurl(cgit_query_repo, "log", | 25 | url = cgit_pageurl(cgit_query_repo, "log", |
26 | fmt("h=%s", refname)); | 26 | fmt("h=%s", refname)); |
27 | html_link_open(url, NULL, NULL); | 27 | html_link_open(url, NULL, NULL); |
28 | html_txt(buf); | 28 | html_txt(buf); |
29 | html_link_close(); | 29 | html_link_close(); |
30 | html("</td><td>"); | 30 | html("</td><td>"); |
31 | cgit_print_date(commit->date); | 31 | cgit_print_date(commit->date); |
32 | html("</td><td>"); | 32 | html("</td><td>"); |
33 | html_txt(info->author); | 33 | html_txt(info->author); |
34 | html("</td><td>"); | 34 | html("</td><td>"); |
35 | url = cgit_pageurl(cgit_query_repo, "commit", | 35 | url = cgit_pageurl(cgit_query_repo, "commit", |
36 | fmt("id=%s", sha1_to_hex(sha1))); | 36 | fmt("h=%s", sha1_to_hex(sha1))); |
37 | html_link_open(url, NULL, NULL); | 37 | html_link_open(url, NULL, NULL); |
38 | html_ntxt(cgit_max_msg_len, info->subject); | 38 | html_ntxt(cgit_max_msg_len, info->subject); |
39 | html_link_close(); | 39 | html_link_close(); |
40 | html("</td></tr>\n"); | 40 | html("</td></tr>\n"); |
41 | cgit_free_commitinfo(info); | 41 | cgit_free_commitinfo(info); |
42 | } else { | 42 | } else { |
43 | html("<tr><td>"); | 43 | html("<tr><td>"); |
44 | html_txt(buf); | 44 | html_txt(buf); |
45 | html("</td><td colspan='3'>"); | 45 | html("</td><td colspan='3'>"); |
46 | htmlf("*** bad ref %s ***", sha1_to_hex(sha1)); | 46 | htmlf("*** bad ref %s ***", sha1_to_hex(sha1)); |
47 | html("</td></tr>\n"); | 47 | html("</td></tr>\n"); |
48 | } | 48 | } |
49 | return 0; | 49 | return 0; |
50 | } | 50 | } |
51 | 51 | ||
52 | 52 | ||
53 | static void cgit_print_object_ref(struct object *obj) | 53 | static void cgit_print_object_ref(struct object *obj) |
54 | { | 54 | { |
55 | char *page, *url; | 55 | char *page, *arg, *url; |
56 | 56 | ||
57 | if (obj->type == OBJ_COMMIT) | 57 | if (obj->type == OBJ_COMMIT) { |
58 | page = "commit"; | 58 | page = "commit"; |
59 | else if (obj->type == OBJ_TREE) | 59 | arg = "h"; |
60 | } else if (obj->type == OBJ_TREE) { | ||
60 | page = "tree"; | 61 | page = "tree"; |
61 | else | 62 | arg = "id"; |
63 | } else { | ||
62 | page = "view"; | 64 | page = "view"; |
65 | arg = "id"; | ||
66 | } | ||
63 | 67 | ||
64 | url = cgit_pageurl(cgit_query_repo, page, | 68 | url = cgit_pageurl(cgit_query_repo, page, |
65 | fmt("id=%s", sha1_to_hex(obj->sha1))); | 69 | fmt("%s=%s", arg, sha1_to_hex(obj->sha1))); |
66 | html_link_open(url, NULL, NULL); | 70 | html_link_open(url, NULL, NULL); |
67 | htmlf("%s %s", typename(obj->type), | 71 | htmlf("%s %s", typename(obj->type), |
68 | sha1_to_hex(obj->sha1)); | 72 | sha1_to_hex(obj->sha1)); |
69 | html_link_close(); | 73 | html_link_close(); |
70 | } | 74 | } |
71 | 75 | ||
72 | static void print_tag_header() | 76 | static void print_tag_header() |
73 | { | 77 | { |
74 | html("<tr class='nohover'><th class='left'>Tag</th>" | 78 | html("<tr class='nohover'><th class='left'>Tag</th>" |
75 | "<th class='left'>Created</th>" | 79 | "<th class='left'>Created</th>" |
76 | "<th class='left'>Author</th>" | 80 | "<th class='left'>Author</th>" |
77 | "<th class='left'>Reference</th></tr>\n"); | 81 | "<th class='left'>Reference</th></tr>\n"); |
78 | header = 1; | 82 | header = 1; |
79 | } | 83 | } |
80 | 84 | ||
81 | static int cgit_print_tag_cb(const char *refname, const unsigned char *sha1, | 85 | static int cgit_print_tag_cb(const char *refname, const unsigned char *sha1, |
82 | int flags, void *cb_data) | 86 | int flags, void *cb_data) |
83 | { | 87 | { |
84 | struct tag *tag; | 88 | struct tag *tag; |
85 | struct taginfo *info; | 89 | struct taginfo *info; |
86 | struct object *obj; | 90 | struct object *obj; |
87 | char buf[256], *url; | 91 | char buf[256], *url; |
88 | 92 | ||
89 | strncpy(buf, refname, sizeof(buf)); | 93 | strncpy(buf, refname, sizeof(buf)); |
90 | obj = parse_object(sha1); | 94 | obj = parse_object(sha1); |
91 | if (!obj) | 95 | if (!obj) |
92 | return 1; | 96 | return 1; |
93 | if (obj->type == OBJ_TAG) { | 97 | if (obj->type == OBJ_TAG) { |
94 | tag = lookup_tag(sha1); | 98 | tag = lookup_tag(sha1); |
95 | if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag))) | 99 | if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag))) |
96 | return 2; | 100 | return 2; |
97 | if (!header) | 101 | if (!header) |
98 | print_tag_header(); | 102 | print_tag_header(); |
99 | html("<tr><td>"); | 103 | html("<tr><td>"); |
100 | url = cgit_pageurl(cgit_query_repo, "view", | 104 | url = cgit_pageurl(cgit_query_repo, "view", |
101 | fmt("id=%s", sha1_to_hex(sha1))); | 105 | fmt("id=%s", sha1_to_hex(sha1))); |
102 | html_link_open(url, NULL, NULL); | 106 | html_link_open(url, NULL, NULL); |
103 | html_txt(buf); | 107 | html_txt(buf); |
104 | html_link_close(); | 108 | html_link_close(); |
105 | html("</td><td>"); | 109 | html("</td><td>"); |
106 | if (info->tagger_date > 0) | 110 | if (info->tagger_date > 0) |
107 | cgit_print_date(info->tagger_date); | 111 | cgit_print_date(info->tagger_date); |
108 | html("</td><td>"); | 112 | html("</td><td>"); |
109 | if (info->tagger) | 113 | if (info->tagger) |
110 | html(info->tagger); | 114 | html(info->tagger); |
111 | html("</td><td>"); | 115 | html("</td><td>"); |
112 | cgit_print_object_ref(tag->tagged); | 116 | cgit_print_object_ref(tag->tagged); |
113 | html("</td></tr>\n"); | 117 | html("</td></tr>\n"); |
114 | } else { | 118 | } else { |
115 | if (!header) | 119 | if (!header) |
116 | print_tag_header(); | 120 | print_tag_header(); |
117 | html("<tr><td>"); | 121 | html("<tr><td>"); |
118 | html_txt(buf); | 122 | html_txt(buf); |
119 | html("</td><td colspan='2'/><td>"); | 123 | html("</td><td colspan='2'/><td>"); |
120 | cgit_print_object_ref(obj); | 124 | cgit_print_object_ref(obj); |
121 | html("</td></tr>\n"); | 125 | html("</td></tr>\n"); |
122 | } | 126 | } |
123 | return 0; | 127 | return 0; |
124 | } | 128 | } |
125 | 129 | ||
126 | static int cgit_print_archive_cb(const char *refname, const unsigned char *sha1, | 130 | static int cgit_print_archive_cb(const char *refname, const unsigned char *sha1, |
127 | int flags, void *cb_data) | 131 | int flags, void *cb_data) |
128 | { | 132 | { |
129 | struct tag *tag; | 133 | struct tag *tag; |
130 | struct taginfo *info; | 134 | struct taginfo *info; |
131 | struct object *obj; | 135 | struct object *obj; |
132 | char buf[256], *url; | 136 | char buf[256], *url; |
133 | unsigned char fileid[20]; | 137 | unsigned char fileid[20]; |
134 | 138 | ||
135 | if (prefixcmp(refname, "refs/archives")) | 139 | if (prefixcmp(refname, "refs/archives")) |
136 | return 0; | 140 | return 0; |
137 | strncpy(buf, refname+14, sizeof(buf)); | 141 | strncpy(buf, refname+14, sizeof(buf)); |
138 | obj = parse_object(sha1); | 142 | obj = parse_object(sha1); |
139 | if (!obj) | 143 | if (!obj) |
140 | return 1; | 144 | return 1; |
141 | if (obj->type == OBJ_TAG) { | 145 | if (obj->type == OBJ_TAG) { |
142 | tag = lookup_tag(sha1); | 146 | tag = lookup_tag(sha1); |
143 | if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag))) | 147 | if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag))) |
144 | return 0; | 148 | return 0; |
145 | hashcpy(fileid, tag->tagged->sha1); | 149 | hashcpy(fileid, tag->tagged->sha1); |
146 | } else if (obj->type != OBJ_BLOB) { | 150 | } else if (obj->type != OBJ_BLOB) { |
147 | return 0; | 151 | return 0; |
148 | } else { | 152 | } else { |
149 | hashcpy(fileid, sha1); | 153 | hashcpy(fileid, sha1); |
150 | } | 154 | } |
151 | if (!header) { | 155 | if (!header) { |
152 | html("<table>"); | 156 | html("<table>"); |
153 | html("<tr><th>Downloads</th></tr>"); | 157 | html("<tr><th>Downloads</th></tr>"); |
154 | header = 1; | 158 | header = 1; |
155 | } | 159 | } |
156 | html("<tr><td>"); | 160 | html("<tr><td>"); |
157 | url = cgit_pageurl(cgit_query_repo, "blob", | 161 | url = cgit_pageurl(cgit_query_repo, "blob", |
158 | fmt("id=%s&path=%s", sha1_to_hex(fileid), | 162 | fmt("id=%s&path=%s", sha1_to_hex(fileid), |
159 | buf)); | 163 | buf)); |
160 | html_link_open(url, NULL, NULL); | 164 | html_link_open(url, NULL, NULL); |
161 | html_txt(buf); | 165 | html_txt(buf); |
162 | html_link_close(); | 166 | html_link_close(); |
163 | html("</td><tr>"); | 167 | html("</td><tr>"); |
164 | return 0; | 168 | return 0; |
165 | } | 169 | } |
166 | 170 | ||
167 | static void cgit_print_branches() | 171 | static void cgit_print_branches() |
168 | { | 172 | { |
169 | html("<tr class='nohover'><th class='left'>Branch</th>" | 173 | html("<tr class='nohover'><th class='left'>Branch</th>" |
170 | "<th class='left'>Updated</th>" | 174 | "<th class='left'>Updated</th>" |
171 | "<th class='left'>Author</th>" | 175 | "<th class='left'>Author</th>" |
172 | "<th class='left'>Head commit</th></tr>\n"); | 176 | "<th class='left'>Head commit</th></tr>\n"); |
173 | for_each_branch_ref(cgit_print_branch_cb, NULL); | 177 | for_each_branch_ref(cgit_print_branch_cb, NULL); |
174 | } | 178 | } |
175 | 179 | ||
176 | static void cgit_print_tags() | 180 | static void cgit_print_tags() |
177 | { | 181 | { |
178 | header = 0; | 182 | header = 0; |
179 | for_each_tag_ref(cgit_print_tag_cb, NULL); | 183 | for_each_tag_ref(cgit_print_tag_cb, NULL); |
180 | } | 184 | } |
181 | 185 | ||
182 | static void cgit_print_archives() | 186 | static void cgit_print_archives() |
183 | { | 187 | { |
184 | header = 0; | 188 | header = 0; |
185 | for_each_ref(cgit_print_archive_cb, NULL); | 189 | for_each_ref(cgit_print_archive_cb, NULL); |
186 | if (header) | 190 | if (header) |
187 | html("</table>"); | 191 | html("</table>"); |
188 | } | 192 | } |
189 | 193 | ||
190 | void cgit_print_summary() | 194 | void cgit_print_summary() |
191 | { | 195 | { |
192 | html("<table class='list nowrap'>"); | 196 | html("<table class='list nowrap'>"); |
193 | html("<tr class='nohover'><td id='summary' colspan='3'>"); | 197 | html("<tr class='nohover'><td id='summary' colspan='3'>"); |
194 | html("<h2>"); | 198 | html("<h2>"); |
195 | html_txt(cgit_repo->name); | 199 | html_txt(cgit_repo->name); |
196 | html(" - "); | 200 | html(" - "); |
197 | html_txt(cgit_repo->desc); | 201 | html_txt(cgit_repo->desc); |
198 | html("</h2>"); | 202 | html("</h2>"); |
199 | html("</td><td id='archivelist'>"); | 203 | html("</td><td id='archivelist'>"); |
200 | cgit_print_archives(); | 204 | cgit_print_archives(); |
201 | html("</td></tr>"); | 205 | html("</td></tr>"); |
202 | cgit_print_branches(); | 206 | cgit_print_branches(); |
203 | html("<tr class='nohover'><td colspan='4'> </td></tr>"); | 207 | html("<tr class='nohover'><td colspan='4'> </td></tr>"); |
204 | cgit_print_tags(); | 208 | cgit_print_tags(); |
205 | html("</table>"); | 209 | html("</table>"); |
206 | } | 210 | } |