summaryrefslogtreecommitdiffabout
authorLars Hjemli <hjemli@gmail.com>2007-05-22 21:15:36 (UTC)
committer Lars Hjemli <hjemli@gmail.com>2007-05-22 21:15:36 (UTC)
commit237ef7b06d461ddf27b21cd13bfcb50befa4a916 (patch) (unidiff)
treeba64f8b921abf9025cb73daa5a57ff2878bd7c90
parent5db39170b6c979655a0238dcd627e206febed88b (diff)
downloadcgit-237ef7b06d461ddf27b21cd13bfcb50befa4a916.zip
cgit-237ef7b06d461ddf27b21cd13bfcb50befa4a916.tar.gz
cgit-237ef7b06d461ddf27b21cd13bfcb50befa4a916.tar.bz2
Use cgit_print_age() on summary and log pages
Update the pages to show relative dates instead of yyyy-mm-dd hh:mm:ss Signed-off-by: Lars Hjemli <hjemli@gmail.com>
Diffstat (more/less context) (ignore whitespace changes)
-rw-r--r--ui-log.c8
-rw-r--r--ui-summary.c8
2 files changed, 6 insertions, 10 deletions
diff --git a/ui-log.c b/ui-log.c
index 4237921..c80fd73 100644
--- a/ui-log.c
+++ b/ui-log.c
@@ -1,132 +1,128 @@
1/* ui-log.c: functions for log output 1/* ui-log.c: functions for log output
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, lines; 11int files, lines;
12 12
13void count_lines(char *line, int size) 13void count_lines(char *line, int size)
14{ 14{
15 if (size>0 && (line[0] == '+' || line[0] == '-')) 15 if (size>0 && (line[0] == '+' || line[0] == '-'))
16 lines++; 16 lines++;
17} 17}
18 18
19void inspect_files(struct diff_filepair *pair) 19void inspect_files(struct diff_filepair *pair)
20{ 20{
21 files++; 21 files++;
22 if (cgit_repo->enable_log_linecount) 22 if (cgit_repo->enable_log_linecount)
23 cgit_diff_files(pair->one->sha1, pair->two->sha1, count_lines); 23 cgit_diff_files(pair->one->sha1, pair->two->sha1, count_lines);
24} 24}
25 25
26void print_commit(struct commit *commit) 26void print_commit(struct commit *commit)
27{ 27{
28 char buf[32];
29 struct commitinfo *info; 28 struct commitinfo *info;
30 struct tm *time;
31 29
32 info = cgit_parse_commit(commit); 30 info = cgit_parse_commit(commit);
33 time = gmtime(&commit->date);
34 html("<tr><td>"); 31 html("<tr><td>");
35 strftime(buf, sizeof(buf), "%Y-%m-%d %H:%M", time); 32 cgit_print_age(commit->date, TM_WEEK * 2, FMT_SHORTDATE);
36 html_txt(buf);
37 html("</td><td>"); 33 html("</td><td>");
38 char *qry = fmt("h=%s", sha1_to_hex(commit->object.sha1)); 34 char *qry = fmt("h=%s", sha1_to_hex(commit->object.sha1));
39 char *url = cgit_pageurl(cgit_query_repo, "commit", qry); 35 char *url = cgit_pageurl(cgit_query_repo, "commit", qry);
40 html_link_open(url, NULL, NULL); 36 html_link_open(url, NULL, NULL);
41 html_ntxt(cgit_max_msg_len, info->subject); 37 html_ntxt(cgit_max_msg_len, info->subject);
42 html_link_close(); 38 html_link_close();
43 if (cgit_repo->enable_log_filecount) { 39 if (cgit_repo->enable_log_filecount) {
44 files = 0; 40 files = 0;
45 lines = 0; 41 lines = 0;
46 cgit_diff_commit(commit, inspect_files); 42 cgit_diff_commit(commit, inspect_files);
47 html("</td><td class='right'>"); 43 html("</td><td class='right'>");
48 htmlf("%d", files); 44 htmlf("%d", files);
49 if (cgit_repo->enable_log_linecount) { 45 if (cgit_repo->enable_log_linecount) {
50 html("</td><td class='right'>"); 46 html("</td><td class='right'>");
51 htmlf("%d", lines); 47 htmlf("%d", lines);
52 } 48 }
53 } 49 }
54 html("</td><td>"); 50 html("</td><td>");
55 html_txt(info->author); 51 html_txt(info->author);
56 html("</td></tr>\n"); 52 html("</td></tr>\n");
57 cgit_free_commitinfo(info); 53 cgit_free_commitinfo(info);
58} 54}
59 55
60 56
61void cgit_print_log(const char *tip, int ofs, int cnt, char *grep, char *path) 57void cgit_print_log(const char *tip, int ofs, int cnt, char *grep, char *path)
62{ 58{
63 struct rev_info rev; 59 struct rev_info rev;
64 struct commit *commit; 60 struct commit *commit;
65 const char *argv[] = {NULL, tip, NULL, NULL, NULL}; 61 const char *argv[] = {NULL, tip, NULL, NULL, NULL};
66 int argc = 2; 62 int argc = 2;
67 int i; 63 int i;
68 64
69 if (grep) 65 if (grep)
70 argv[argc++] = fmt("--grep=%s", grep); 66 argv[argc++] = fmt("--grep=%s", grep);
71 if (path) { 67 if (path) {
72 argv[argc++] = "--"; 68 argv[argc++] = "--";
73 argv[argc++] = path; 69 argv[argc++] = path;
74 } 70 }
75 init_revisions(&rev, NULL); 71 init_revisions(&rev, NULL);
76 rev.abbrev = DEFAULT_ABBREV; 72 rev.abbrev = DEFAULT_ABBREV;
77 rev.commit_format = CMIT_FMT_DEFAULT; 73 rev.commit_format = CMIT_FMT_DEFAULT;
78 rev.verbose_header = 1; 74 rev.verbose_header = 1;
79 rev.show_root_diff = 0; 75 rev.show_root_diff = 0;
80 setup_revisions(argc, argv, &rev, NULL); 76 setup_revisions(argc, argv, &rev, NULL);
81 if (rev.grep_filter) { 77 if (rev.grep_filter) {
82 rev.grep_filter->regflags |= REG_ICASE; 78 rev.grep_filter->regflags |= REG_ICASE;
83 compile_grep_patterns(rev.grep_filter); 79 compile_grep_patterns(rev.grep_filter);
84 } 80 }
85 prepare_revision_walk(&rev); 81 prepare_revision_walk(&rev);
86 82
87 html("<table class='list nowrap'>"); 83 html("<table class='list nowrap'>");
88 html("<tr class='nohover'><th class='left'>Date</th>" 84 html("<tr class='nohover'><th class='left'>Age</th>"
89 "<th class='left'>Message</th>"); 85 "<th class='left'>Message</th>");
90 86
91 if (cgit_repo->enable_log_filecount) { 87 if (cgit_repo->enable_log_filecount) {
92 html("<th class='left'>Files</th>"); 88 html("<th class='left'>Files</th>");
93 if (cgit_repo->enable_log_linecount) 89 if (cgit_repo->enable_log_linecount)
94 html("<th class='left'>Lines</th>"); 90 html("<th class='left'>Lines</th>");
95 } 91 }
96 html("<th class='left'>Author</th></tr>\n"); 92 html("<th class='left'>Author</th></tr>\n");
97 93
98 if (ofs<0) 94 if (ofs<0)
99 ofs = 0; 95 ofs = 0;
100 96
101 for (i = 0; i < ofs && (commit = get_revision(&rev)) != NULL; i++) { 97 for (i = 0; i < ofs && (commit = get_revision(&rev)) != NULL; i++) {
102 free(commit->buffer); 98 free(commit->buffer);
103 commit->buffer = NULL; 99 commit->buffer = NULL;
104 free_commit_list(commit->parents); 100 free_commit_list(commit->parents);
105 commit->parents = NULL; 101 commit->parents = NULL;
106 } 102 }
107 103
108 for (i = 0; i < cnt && (commit = get_revision(&rev)) != NULL; i++) { 104 for (i = 0; i < cnt && (commit = get_revision(&rev)) != NULL; i++) {
109 print_commit(commit); 105 print_commit(commit);
110 free(commit->buffer); 106 free(commit->buffer);
111 commit->buffer = NULL; 107 commit->buffer = NULL;
112 free_commit_list(commit->parents); 108 free_commit_list(commit->parents);
113 commit->parents = NULL; 109 commit->parents = NULL;
114 } 110 }
115 html("</table>\n"); 111 html("</table>\n");
116 112
117 html("<div class='pager'>"); 113 html("<div class='pager'>");
118 if (ofs > 0) { 114 if (ofs > 0) {
119 html("&nbsp;<a href='"); 115 html("&nbsp;<a href='");
120 html(cgit_pageurl(cgit_query_repo, cgit_query_page, 116 html(cgit_pageurl(cgit_query_repo, cgit_query_page,
121 fmt("h=%s&ofs=%d", tip, ofs-cnt))); 117 fmt("h=%s&ofs=%d", tip, ofs-cnt)));
122 html("'>[prev]</a>&nbsp;"); 118 html("'>[prev]</a>&nbsp;");
123 } 119 }
124 120
125 if ((commit = get_revision(&rev)) != NULL) { 121 if ((commit = get_revision(&rev)) != NULL) {
126 html("&nbsp;<a href='"); 122 html("&nbsp;<a href='");
127 html(cgit_pageurl(cgit_query_repo, "log", 123 html(cgit_pageurl(cgit_query_repo, "log",
128 fmt("h=%s&ofs=%d", tip, ofs+cnt))); 124 fmt("h=%s&ofs=%d", tip, ofs+cnt)));
129 html("'>[next]</a>&nbsp;"); 125 html("'>[next]</a>&nbsp;");
130 } 126 }
131 html("</div>"); 127 html("</div>");
132} 128}
diff --git a/ui-summary.c b/ui-summary.c
index 20394de..5799773 100644
--- a/ui-summary.c
+++ b/ui-summary.c
@@ -1,210 +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
11static int header; 11static int header;
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, FMT_LONGDATE); 31 cgit_print_age(commit->date, -1, NULL);
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("h=%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
53static void cgit_print_object_ref(struct object *obj) 53static void cgit_print_object_ref(struct object *obj)
54{ 54{
55 char *page, *arg, *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 arg = "h"; 59 arg = "h";
60 } else if (obj->type == OBJ_TREE) { 60 } else if (obj->type == OBJ_TREE) {
61 page = "tree"; 61 page = "tree";
62 arg = "id"; 62 arg = "id";
63 } else { 63 } else {
64 page = "view"; 64 page = "view";
65 arg = "id"; 65 arg = "id";
66 } 66 }
67 67
68 url = cgit_pageurl(cgit_query_repo, page, 68 url = cgit_pageurl(cgit_query_repo, page,
69 fmt("%s=%s", arg, sha1_to_hex(obj->sha1))); 69 fmt("%s=%s", arg, sha1_to_hex(obj->sha1)));
70 html_link_open(url, NULL, NULL); 70 html_link_open(url, NULL, NULL);
71 htmlf("%s %s", typename(obj->type), 71 htmlf("%s %s", typename(obj->type),
72 sha1_to_hex(obj->sha1)); 72 sha1_to_hex(obj->sha1));
73 html_link_close(); 73 html_link_close();
74} 74}
75 75
76static void print_tag_header() 76static void print_tag_header()
77{ 77{
78 html("<tr class='nohover'><th class='left'>Tag</th>" 78 html("<tr class='nohover'><th class='left'>Tag</th>"
79 "<th class='left'>Created</th>" 79 "<th class='left'>Age</th>"
80 "<th class='left'>Author</th>" 80 "<th class='left'>Author</th>"
81 "<th class='left'>Reference</th></tr>\n"); 81 "<th class='left'>Reference</th></tr>\n");
82 header = 1; 82 header = 1;
83} 83}
84 84
85static int cgit_print_tag_cb(const char *refname, const unsigned char *sha1, 85static int cgit_print_tag_cb(const char *refname, const unsigned char *sha1,
86 int flags, void *cb_data) 86 int flags, void *cb_data)
87{ 87{
88 struct tag *tag; 88 struct tag *tag;
89 struct taginfo *info; 89 struct taginfo *info;
90 struct object *obj; 90 struct object *obj;
91 char buf[256], *url; 91 char buf[256], *url;
92 92
93 strncpy(buf, refname, sizeof(buf)); 93 strncpy(buf, refname, sizeof(buf));
94 obj = parse_object(sha1); 94 obj = parse_object(sha1);
95 if (!obj) 95 if (!obj)
96 return 1; 96 return 1;
97 if (obj->type == OBJ_TAG) { 97 if (obj->type == OBJ_TAG) {
98 tag = lookup_tag(sha1); 98 tag = lookup_tag(sha1);
99 if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag))) 99 if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag)))
100 return 2; 100 return 2;
101 if (!header) 101 if (!header)
102 print_tag_header(); 102 print_tag_header();
103 html("<tr><td>"); 103 html("<tr><td>");
104 url = cgit_pageurl(cgit_query_repo, "view", 104 url = cgit_pageurl(cgit_query_repo, "view",
105 fmt("id=%s", sha1_to_hex(sha1))); 105 fmt("id=%s", sha1_to_hex(sha1)));
106 html_link_open(url, NULL, NULL); 106 html_link_open(url, NULL, NULL);
107 html_txt(buf); 107 html_txt(buf);
108 html_link_close(); 108 html_link_close();
109 html("</td><td>"); 109 html("</td><td>");
110 if (info->tagger_date > 0) 110 if (info->tagger_date > 0)
111 cgit_print_date(info->tagger_date, FMT_LONGDATE); 111 cgit_print_age(info->tagger_date, -1, NULL);
112 html("</td><td>"); 112 html("</td><td>");
113 if (info->tagger) 113 if (info->tagger)
114 html(info->tagger); 114 html(info->tagger);
115 html("</td><td>"); 115 html("</td><td>");
116 cgit_print_object_ref(tag->tagged); 116 cgit_print_object_ref(tag->tagged);
117 html("</td></tr>\n"); 117 html("</td></tr>\n");
118 } else { 118 } else {
119 if (!header) 119 if (!header)
120 print_tag_header(); 120 print_tag_header();
121 html("<tr><td>"); 121 html("<tr><td>");
122 html_txt(buf); 122 html_txt(buf);
123 html("</td><td colspan='2'/><td>"); 123 html("</td><td colspan='2'/><td>");
124 cgit_print_object_ref(obj); 124 cgit_print_object_ref(obj);
125 html("</td></tr>\n"); 125 html("</td></tr>\n");
126 } 126 }
127 return 0; 127 return 0;
128} 128}
129 129
130static int cgit_print_archive_cb(const char *refname, const unsigned char *sha1, 130static int cgit_print_archive_cb(const char *refname, const unsigned char *sha1,
131 int flags, void *cb_data) 131 int flags, void *cb_data)
132{ 132{
133 struct tag *tag; 133 struct tag *tag;
134 struct taginfo *info; 134 struct taginfo *info;
135 struct object *obj; 135 struct object *obj;
136 char buf[256], *url; 136 char buf[256], *url;
137 unsigned char fileid[20]; 137 unsigned char fileid[20];
138 138
139 if (prefixcmp(refname, "refs/archives")) 139 if (prefixcmp(refname, "refs/archives"))
140 return 0; 140 return 0;
141 strncpy(buf, refname+14, sizeof(buf)); 141 strncpy(buf, refname+14, sizeof(buf));
142 obj = parse_object(sha1); 142 obj = parse_object(sha1);
143 if (!obj) 143 if (!obj)
144 return 1; 144 return 1;
145 if (obj->type == OBJ_TAG) { 145 if (obj->type == OBJ_TAG) {
146 tag = lookup_tag(sha1); 146 tag = lookup_tag(sha1);
147 if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag))) 147 if (!tag || parse_tag(tag) || !(info = cgit_parse_tag(tag)))
148 return 0; 148 return 0;
149 hashcpy(fileid, tag->tagged->sha1); 149 hashcpy(fileid, tag->tagged->sha1);
150 } else if (obj->type != OBJ_BLOB) { 150 } else if (obj->type != OBJ_BLOB) {
151 return 0; 151 return 0;
152 } else { 152 } else {
153 hashcpy(fileid, sha1); 153 hashcpy(fileid, sha1);
154 } 154 }
155 if (!header) { 155 if (!header) {
156 html("<table>"); 156 html("<table>");
157 html("<tr><th>Downloads</th></tr>"); 157 html("<tr><th>Downloads</th></tr>");
158 header = 1; 158 header = 1;
159 } 159 }
160 html("<tr><td>"); 160 html("<tr><td>");
161 url = cgit_pageurl(cgit_query_repo, "blob", 161 url = cgit_pageurl(cgit_query_repo, "blob",
162 fmt("id=%s&path=%s", sha1_to_hex(fileid), 162 fmt("id=%s&path=%s", sha1_to_hex(fileid),
163 buf)); 163 buf));
164 html_link_open(url, NULL, NULL); 164 html_link_open(url, NULL, NULL);
165 html_txt(buf); 165 html_txt(buf);
166 html_link_close(); 166 html_link_close();
167 html("</td><tr>"); 167 html("</td><tr>");
168 return 0; 168 return 0;
169} 169}
170 170
171static void cgit_print_branches() 171static void cgit_print_branches()
172{ 172{
173 html("<tr class='nohover'><th class='left'>Branch</th>" 173 html("<tr class='nohover'><th class='left'>Branch</th>"
174 "<th class='left'>Updated</th>" 174 "<th class='left'>Idle</th>"
175 "<th class='left'>Author</th>" 175 "<th class='left'>Author</th>"
176 "<th class='left'>Head commit</th></tr>\n"); 176 "<th class='left'>Head commit</th></tr>\n");
177 for_each_branch_ref(cgit_print_branch_cb, NULL); 177 for_each_branch_ref(cgit_print_branch_cb, NULL);
178} 178}
179 179
180static void cgit_print_tags() 180static void cgit_print_tags()
181{ 181{
182 header = 0; 182 header = 0;
183 for_each_tag_ref(cgit_print_tag_cb, NULL); 183 for_each_tag_ref(cgit_print_tag_cb, NULL);
184} 184}
185 185
186static void cgit_print_archives() 186static void cgit_print_archives()
187{ 187{
188 header = 0; 188 header = 0;
189 for_each_ref(cgit_print_archive_cb, NULL); 189 for_each_ref(cgit_print_archive_cb, NULL);
190 if (header) 190 if (header)
191 html("</table>"); 191 html("</table>");
192} 192}
193 193
194void cgit_print_summary() 194void cgit_print_summary()
195{ 195{
196 html("<table class='list nowrap'>"); 196 html("<table class='list nowrap'>");
197 html("<tr class='nohover'><td id='summary' colspan='3'>"); 197 html("<tr class='nohover'><td id='summary' colspan='3'>");
198 html("<h2>"); 198 html("<h2>");
199 html_txt(cgit_repo->name); 199 html_txt(cgit_repo->name);
200 html(" - "); 200 html(" - ");
201 html_txt(cgit_repo->desc); 201 html_txt(cgit_repo->desc);
202 html("</h2>"); 202 html("</h2>");
203 html("</td><td id='archivelist'>"); 203 html("</td><td id='archivelist'>");
204 cgit_print_archives(); 204 cgit_print_archives();
205 html("</td></tr>"); 205 html("</td></tr>");
206 cgit_print_branches(); 206 cgit_print_branches();
207 html("<tr class='nohover'><td colspan='4'>&nbsp;</td></tr>"); 207 html("<tr class='nohover'><td colspan='4'>&nbsp;</td></tr>");
208 cgit_print_tags(); 208 cgit_print_tags();
209 html("</table>"); 209 html("</table>");
210} 210}