summaryrefslogtreecommitdiffabout
authorLars Hjemli <hjemli@gmail.com>2007-05-14 21:58:29 (UTC)
committer Lars Hjemli <hjemli@gmail.com>2007-05-14 22:00:37 (UTC)
commit9927e63f387e6c9328eb3c347ecb0e339f8ac023 (patch) (unidiff)
tree3a73f7652445007a66aad5b8969201be9d42ed68
parent5ec6e02bd1cc0c05b7cfd0d53371e7d176daec39 (diff)
downloadcgit-9927e63f387e6c9328eb3c347ecb0e339f8ac023.zip
cgit-9927e63f387e6c9328eb3c347ecb0e339f8ac023.tar.gz
cgit-9927e63f387e6c9328eb3c347ecb0e339f8ac023.tar.bz2
Specify static storage class for file-local declarations
Also fix some whitespace issues while at it. Noticed by Kristian Høgsberg <krh@bitplanet.net> Signed-off-by: Lars Hjemli <hjemli@gmail.com>
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--ui-commit.c8
-rw-r--r--ui-summary.c14
2 files changed, 11 insertions, 11 deletions
diff --git a/ui-commit.c b/ui-commit.c
index 20a7cb2..b6a106f 100644
--- a/ui-commit.c
+++ b/ui-commit.c
@@ -1,111 +1,111 @@
1/* ui-commit.c: generate commit view 1/* ui-commit.c: generate commit view
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
11int files = 0, slots = 0; 11static int files, slots;
12int total_adds = 0, total_rems = 0, max_changes = 0; 12static int total_adds, total_rems, max_changes;
13int lines_added, lines_removed; 13static int lines_added, lines_removed;
14 14
15struct fileinfo { 15static struct fileinfo {
16 char status; 16 char status;
17 unsigned char old_sha1[20]; 17 unsigned char old_sha1[20];
18 unsigned char new_sha1[20]; 18 unsigned char new_sha1[20];
19 unsigned short old_mode; 19 unsigned short old_mode;
20 unsigned short new_mode; 20 unsigned short new_mode;
21 char *old_path; 21 char *old_path;
22 char *new_path; 22 char *new_path;
23 unsigned int added; 23 unsigned int added;
24 unsigned int removed; 24 unsigned int removed;
25} *items; 25} *items;
26 26
27 27
28void print_fileinfo(struct fileinfo *info) 28void print_fileinfo(struct fileinfo *info)
29{ 29{
30 char *query, *query2; 30 char *query, *query2;
31 char *class; 31 char *class;
32 double width; 32 double width;
33 33
34 switch (info->status) { 34 switch (info->status) {
35 case DIFF_STATUS_ADDED: 35 case DIFF_STATUS_ADDED:
36 class = "add"; 36 class = "add";
37 break; 37 break;
38 case DIFF_STATUS_COPIED: 38 case DIFF_STATUS_COPIED:
39 class = "cpy"; 39 class = "cpy";
40 break; 40 break;
41 case DIFF_STATUS_DELETED: 41 case DIFF_STATUS_DELETED:
42 class = "del"; 42 class = "del";
43 break; 43 break;
44 case DIFF_STATUS_MODIFIED: 44 case DIFF_STATUS_MODIFIED:
45 class = "upd"; 45 class = "upd";
46 break; 46 break;
47 case DIFF_STATUS_RENAMED: 47 case DIFF_STATUS_RENAMED:
48 class = "mov"; 48 class = "mov";
49 break; 49 break;
50 case DIFF_STATUS_TYPE_CHANGED: 50 case DIFF_STATUS_TYPE_CHANGED:
51 class = "typ"; 51 class = "typ";
52 break; 52 break;
53 case DIFF_STATUS_UNKNOWN: 53 case DIFF_STATUS_UNKNOWN:
54 class = "unk"; 54 class = "unk";
55 break; 55 break;
56 case DIFF_STATUS_UNMERGED: 56 case DIFF_STATUS_UNMERGED:
57 class = "stg"; 57 class = "stg";
58 break; 58 break;
59 default: 59 default:
60 die("bug: unhandled diff status %c", info->status); 60 die("bug: unhandled diff status %c", info->status);
61 } 61 }
62 62
63 html("<tr>"); 63 html("<tr>");
64 htmlf("<td class='mode'>"); 64 htmlf("<td class='mode'>");
65 if (is_null_sha1(info->new_sha1)) { 65 if (is_null_sha1(info->new_sha1)) {
66 html_filemode(info->old_mode); 66 html_filemode(info->old_mode);
67 } else { 67 } else {
68 html_filemode(info->new_mode); 68 html_filemode(info->new_mode);
69 } 69 }
70 70
71 if (info->old_mode != info->new_mode && 71 if (info->old_mode != info->new_mode &&
72 !is_null_sha1(info->old_sha1) && 72 !is_null_sha1(info->old_sha1) &&
73 !is_null_sha1(info->new_sha1)) { 73 !is_null_sha1(info->new_sha1)) {
74 html("<span class='modechange'>["); 74 html("<span class='modechange'>[");
75 html_filemode(info->old_mode); 75 html_filemode(info->old_mode);
76 html("]</span>"); 76 html("]</span>");
77 } 77 }
78 htmlf("</td><td class='%s'>", class); 78 htmlf("</td><td class='%s'>", class);
79 query = fmt("id=%s&id2=%s&path=%s", sha1_to_hex(info->old_sha1), 79 query = fmt("id=%s&id2=%s&path=%s", sha1_to_hex(info->old_sha1),
80 sha1_to_hex(info->new_sha1), info->new_path); 80 sha1_to_hex(info->new_sha1), info->new_path);
81 html_link_open(cgit_pageurl(cgit_query_repo, "diff", query), 81 html_link_open(cgit_pageurl(cgit_query_repo, "diff", query),
82 NULL, NULL); 82 NULL, NULL);
83 if (info->status == DIFF_STATUS_COPIED || 83 if (info->status == DIFF_STATUS_COPIED ||
84 info->status == DIFF_STATUS_RENAMED) { 84 info->status == DIFF_STATUS_RENAMED) {
85 html_txt(info->new_path); 85 html_txt(info->new_path);
86 htmlf("</a> (%s from ", info->status == DIFF_STATUS_COPIED ? 86 htmlf("</a> (%s from ", info->status == DIFF_STATUS_COPIED ?
87 "copied" : "renamed"); 87 "copied" : "renamed");
88 query2 = fmt("id=%s", sha1_to_hex(info->old_sha1)); 88 query2 = fmt("id=%s", sha1_to_hex(info->old_sha1));
89 html_link_open(cgit_pageurl(cgit_query_repo, "view", query2), 89 html_link_open(cgit_pageurl(cgit_query_repo, "view", query2),
90 NULL, NULL); 90 NULL, NULL);
91 html_txt(info->old_path); 91 html_txt(info->old_path);
92 html("</a>)"); 92 html("</a>)");
93 } else { 93 } else {
94 html_txt(info->new_path); 94 html_txt(info->new_path);
95 html("</a>"); 95 html("</a>");
96 } 96 }
97 html("</td><td class='right'>"); 97 html("</td><td class='right'>");
98 htmlf("%d", info->added + info->removed); 98 htmlf("%d", info->added + info->removed);
99 99
100 html("</td><td class='graph'>"); 100 html("</td><td class='graph'>");
101 width = (info->added + info->removed) * 100.0 / max_changes; 101 width = (info->added + info->removed) * 100.0 / max_changes;
102 if (width < 0.1) 102 if (width < 0.1)
103 width = 0.1; 103 width = 0.1;
104 html_link_open(cgit_pageurl(cgit_query_repo, "diff", query), 104 html_link_open(cgit_pageurl(cgit_query_repo, "diff", query),
105 NULL, NULL); 105 NULL, NULL);
106 htmlf("<img src='/cgit/add.png' style='width: %.1f%%;'/>", 106 htmlf("<img src='/cgit/add.png' style='width: %.1f%%;'/>",
107 info->added * width / (info->added + info->removed)); 107 info->added * width / (info->added + info->removed));
108 htmlf("<img src='/cgit/del.png' style='width: %.1f%%;'/>", 108 htmlf("<img src='/cgit/del.png' style='width: %.1f%%;'/>",
109 info->removed * width / (info->added + info->removed)); 109 info->removed * width / (info->added + info->removed));
110 html("</a></td></tr>\n"); 110 html("</a></td></tr>\n");
111} 111}
diff --git a/ui-summary.c b/ui-summary.c
index 9388f5f..f6120f9 100644
--- a/ui-summary.c
+++ b/ui-summary.c
@@ -1,192 +1,192 @@
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
11int items = 0; 11static int items;
12 12
13static int cgit_print_branch_cb(const char *refname, const unsigned char *sha1, 13static 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("id=%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
53static void cgit_print_object_ref(struct object *obj) 53static void cgit_print_object_ref(struct object *obj)
54{ 54{
55 char *page, *url; 55 char *page, *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 else if (obj->type == OBJ_TREE)
60 page = "tree"; 60 page = "tree";
61 else 61 else
62 page = "view"; 62 page = "view";
63 63
64 url = cgit_pageurl(cgit_query_repo, page, 64 url = cgit_pageurl(cgit_query_repo, page,
65 fmt("id=%s", sha1_to_hex(obj->sha1))); 65 fmt("id=%s", sha1_to_hex(obj->sha1)));
66 html_link_open(url, NULL, NULL); 66 html_link_open(url, NULL, NULL);
67 htmlf("%s %s", typename(obj->type), 67 htmlf("%s %s", typename(obj->type),
68 sha1_to_hex(obj->sha1)); 68 sha1_to_hex(obj->sha1));
69 html_link_close(); 69 html_link_close();
70} 70}
71 71
72static int cgit_print_tag_cb(const char *refname, const unsigned char *sha1, 72static int cgit_print_tag_cb(const char *refname, const unsigned char *sha1,
73 int flags, void *cb_data) 73 int flags, void *cb_data)
74{ 74{
75 struct tag *tag; 75 struct tag *tag;
76 struct taginfo *info; 76 struct taginfo *info;
77 struct object *obj; 77 struct object *obj;
78 char buf[256], *url; 78 char buf[256], *url;
79 79
80 strncpy(buf, refname, sizeof(buf)); 80 strncpy(buf, refname, sizeof(buf));
81 obj = parse_object(sha1); 81 obj = parse_object(sha1);
82 if (!obj) 82 if (!obj)
83 return 1; 83 return 1;
84 if (obj->type == OBJ_TAG) { 84 if (obj->type == OBJ_TAG) {
85 tag = lookup_tag(sha1); 85 tag = lookup_tag(sha1);
86 if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag))) 86 if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag)))
87 return 2; 87 return 2;
88 if (!items) { 88 if (!items) {
89 html("<tr class='nohover'><th class='left'>Tag</th>" 89 html("<tr class='nohover'><th class='left'>Tag</th>"
90 "<th class='left'>Created</th>" 90 "<th class='left'>Created</th>"
91 "<th class='left'>Author</th>" 91 "<th class='left'>Author</th>"
92 "<th class='left'>Reference</th></tr>\n"); 92 "<th class='left'>Reference</th></tr>\n");
93 } 93 }
94 items++; 94 items++;
95 html("<tr><td>"); 95 html("<tr><td>");
96 url = cgit_pageurl(cgit_query_repo, "view", 96 url = cgit_pageurl(cgit_query_repo, "view",
97 fmt("id=%s", sha1_to_hex(sha1))); 97 fmt("id=%s", sha1_to_hex(sha1)));
98 html_link_open(url, NULL, NULL); 98 html_link_open(url, NULL, NULL);
99 html_txt(buf); 99 html_txt(buf);
100 html_link_close(); 100 html_link_close();
101 html("</td><td>"); 101 html("</td><td>");
102 if (info->tagger_date > 0) 102 if (info->tagger_date > 0)
103 cgit_print_date(info->tagger_date); 103 cgit_print_date(info->tagger_date);
104 html("</td><td>"); 104 html("</td><td>");
105 if (info->tagger) 105 if (info->tagger)
106 html(info->tagger); 106 html(info->tagger);
107 html("</td><td>"); 107 html("</td><td>");
108 cgit_print_object_ref(tag->tagged); 108 cgit_print_object_ref(tag->tagged);
109 html("</td></tr>\n"); 109 html("</td></tr>\n");
110 } else { 110 } else {
111 html("<tr><td>"); 111 html("<tr><td>");
112 html_txt(buf); 112 html_txt(buf);
113 html("</td><td colspan='2'/><td>"); 113 html("</td><td colspan='2'/><td>");
114 cgit_print_object_ref(obj); 114 cgit_print_object_ref(obj);
115 html("</td></tr>\n"); 115 html("</td></tr>\n");
116 } 116 }
117 return 0; 117 return 0;
118} 118}
119 119
120static int cgit_print_archive_cb(const char *refname, const unsigned char *sha1, 120static int cgit_print_archive_cb(const char *refname, const unsigned char *sha1,
121 int flags, void *cb_data) 121 int flags, void *cb_data)
122{ 122{
123 struct tag *tag; 123 struct tag *tag;
124 struct taginfo *info; 124 struct taginfo *info;
125 struct object *obj; 125 struct object *obj;
126 char buf[256], *url; 126 char buf[256], *url;
127 127
128 if (prefixcmp(refname, "refs/archives")) 128 if (prefixcmp(refname, "refs/archives"))
129 return 0; 129 return 0;
130 strncpy(buf, refname+14, sizeof(buf)); 130 strncpy(buf, refname+14, sizeof(buf));
131 obj = parse_object(sha1); 131 obj = parse_object(sha1);
132 if (!obj) 132 if (!obj)
133 return 1; 133 return 1;
134 if (obj->type == OBJ_TAG) { 134 if (obj->type == OBJ_TAG) {
135 tag = lookup_tag(sha1); 135 tag = lookup_tag(sha1);
136 if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag))) 136 if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag)))
137 return 0; 137 return 0;
138 hashcpy(sha1, tag->tagged->sha1); 138 hashcpy(sha1, tag->tagged->sha1);
139 } else if (obj->type != OBJ_BLOB) { 139 } else if (obj->type != OBJ_BLOB) {
140 return 0; 140 return 0;
141 } 141 }
142 if (!items) { 142 if (!items) {
143 html("<table>"); 143 html("<table>");
144 html("<tr><th>Downloads</th></tr>"); 144 html("<tr><th>Downloads</th></tr>");
145 } 145 }
146 items++; 146 items++;
147 html("<tr><td>"); 147 html("<tr><td>");
148 url = cgit_pageurl(cgit_query_repo, "blob", 148 url = cgit_pageurl(cgit_query_repo, "blob",
149 fmt("id=%s&path=%s", sha1_to_hex(sha1), 149 fmt("id=%s&path=%s", sha1_to_hex(sha1),
150 buf)); 150 buf));
151 html_link_open(url, NULL, NULL); 151 html_link_open(url, NULL, NULL);
152 html_txt(buf); 152 html_txt(buf);
153 html_link_close(); 153 html_link_close();
154 html("</td><tr>"); 154 html("</td><tr>");
155 return 0; 155 return 0;
156} 156}
157 157
158static void cgit_print_branches() 158static void cgit_print_branches()
159{ 159{
160 html("<tr class='nohover'><th class='left'>Branch</th>" 160 html("<tr class='nohover'><th class='left'>Branch</th>"
161 "<th class='left'>Updated</th>" 161 "<th class='left'>Updated</th>"
162 "<th class='left'>Author</th>" 162 "<th class='left'>Author</th>"
163 "<th class='left'>Head commit</th></tr>\n"); 163 "<th class='left'>Head commit</th></tr>\n");
164 for_each_branch_ref(cgit_print_branch_cb, NULL); 164 for_each_branch_ref(cgit_print_branch_cb, NULL);
165} 165}
166 166
167static void cgit_print_tags() 167static void cgit_print_tags()
168{ 168{
169 items = 0; 169 items = 0;
170 for_each_tag_ref(cgit_print_tag_cb, NULL); 170 for_each_tag_ref(cgit_print_tag_cb, NULL);
171} 171}
172 172
173static void cgit_print_archives() 173static void cgit_print_archives()
174{ 174{
175 items = 0; 175 items = 0;
176 for_each_ref(cgit_print_archive_cb, NULL); 176 for_each_ref(cgit_print_archive_cb, NULL);
177 if (items) 177 if (items)
178 html("</table>"); 178 html("</table>");
179} 179}
180 180
181void cgit_print_summary() 181void cgit_print_summary()
182{ 182{
183 html("<table class='list nowrap'>"); 183 html("<table class='list nowrap'>");
184 html("<tr class='nohover'><td id='summary' colspan='3'>"); 184 html("<tr class='nohover'><td id='summary' colspan='3'>");
185 html("<h2>"); 185 html("<h2>");
186 html_txt(cgit_repo->name); 186 html_txt(cgit_repo->name);
187 html(" - "); 187 html(" - ");
188 html_txt(cgit_repo->desc); 188 html_txt(cgit_repo->desc);
189 html("</h2>"); 189 html("</h2>");
190 html("</td><td id='archivelist'>"); 190 html("</td><td id='archivelist'>");
191 cgit_print_archives(); 191 cgit_print_archives();
192 html("</td></tr>"); 192 html("</td></tr>");