-rw-r--r-- | cgit.h | 1 | ||||
-rw-r--r-- | ui-commit.c | 11 | ||||
-rw-r--r-- | ui-shared.c | 12 | ||||
-rw-r--r-- | ui-summary.c | 20 |
4 files changed, 24 insertions, 20 deletions
@@ -80,16 +80,17 @@ extern int cache_cancel_lock(struct cacheitem *item); | |||
80 | extern int cache_exist(struct cacheitem *item); | 80 | extern int cache_exist(struct cacheitem *item); |
81 | extern int cache_expired(struct cacheitem *item); | 81 | extern int cache_expired(struct cacheitem *item); |
82 | 82 | ||
83 | extern char *cgit_repourl(const char *reponame); | 83 | extern char *cgit_repourl(const char *reponame); |
84 | extern char *cgit_pageurl(const char *reponame, const char *pagename, | 84 | extern char *cgit_pageurl(const char *reponame, const char *pagename, |
85 | const char *query); | 85 | const char *query); |
86 | 86 | ||
87 | extern void cgit_print_error(char *msg); | 87 | extern void cgit_print_error(char *msg); |
88 | extern void cgit_print_date(unsigned long secs); | ||
88 | extern void cgit_print_docstart(char *title, struct cacheitem *item); | 89 | extern void cgit_print_docstart(char *title, struct cacheitem *item); |
89 | extern void cgit_print_docend(); | 90 | extern void cgit_print_docend(); |
90 | extern void cgit_print_pageheader(char *title); | 91 | extern void cgit_print_pageheader(char *title); |
91 | 92 | ||
92 | extern void cgit_print_repolist(struct cacheitem *item); | 93 | extern void cgit_print_repolist(struct cacheitem *item); |
93 | extern void cgit_print_summary(); | 94 | extern void cgit_print_summary(); |
94 | extern void cgit_print_log(const char *tip, int ofs, int cnt); | 95 | extern void cgit_print_log(const char *tip, int ofs, int cnt); |
95 | extern void cgit_print_view(const char *hex); | 96 | extern void cgit_print_view(const char *hex); |
diff --git a/ui-commit.c b/ui-commit.c index 1c0e7e5..2d38f0b 100644 --- a/ui-commit.c +++ b/ui-commit.c | |||
@@ -1,21 +1,10 @@ | |||
1 | #include "cgit.h" | 1 | #include "cgit.h" |
2 | 2 | ||
3 | void cgit_print_date(unsigned long secs) | ||
4 | { | ||
5 | char buf[32]; | ||
6 | struct tm *time; | ||
7 | |||
8 | time = gmtime(&secs); | ||
9 | strftime(buf, sizeof(buf), "%Y-%m-%d %H:%M:%S", time); | ||
10 | html_txt(buf); | ||
11 | |||
12 | } | ||
13 | |||
14 | void cgit_print_commit(const char *hex) | 3 | void cgit_print_commit(const char *hex) |
15 | { | 4 | { |
16 | struct commit *commit; | 5 | struct commit *commit; |
17 | struct commitinfo *info; | 6 | struct commitinfo *info; |
18 | struct commit_list *p; | 7 | struct commit_list *p; |
19 | unsigned long size; | 8 | unsigned long size; |
20 | char type[20]; | 9 | char type[20]; |
21 | char *buf; | 10 | char *buf; |
diff --git a/ui-shared.c b/ui-shared.c index cb8a8df..1a6c127 100644 --- a/ui-shared.c +++ b/ui-shared.c | |||
@@ -55,16 +55,28 @@ char *cgit_pageurl(const char *reponame, const char *pagename, | |||
55 | if (cgit_virtual_root) { | 55 | if (cgit_virtual_root) { |
56 | return fmt("%s/%s/%s/?%s", cgit_virtual_root, reponame, | 56 | return fmt("%s/%s/%s/?%s", cgit_virtual_root, reponame, |
57 | pagename, query); | 57 | pagename, query); |
58 | } else { | 58 | } else { |
59 | return fmt("?r=%s&p=%s&%s", reponame, pagename, query); | 59 | return fmt("?r=%s&p=%s&%s", reponame, pagename, query); |
60 | } | 60 | } |
61 | } | 61 | } |
62 | 62 | ||
63 | |||
64 | void cgit_print_date(unsigned long secs) | ||
65 | { | ||
66 | char buf[32]; | ||
67 | struct tm *time; | ||
68 | |||
69 | time = gmtime(&secs); | ||
70 | strftime(buf, sizeof(buf), "%Y-%m-%d %H:%M:%S", time); | ||
71 | html_txt(buf); | ||
72 | |||
73 | } | ||
74 | |||
63 | void cgit_print_docstart(char *title, struct cacheitem *item) | 75 | void cgit_print_docstart(char *title, struct cacheitem *item) |
64 | { | 76 | { |
65 | html("Content-Type: text/html; charset=utf-8\n"); | 77 | html("Content-Type: text/html; charset=utf-8\n"); |
66 | htmlf("Last-Modified: %s\n", http_date(item->st.st_mtime)); | 78 | htmlf("Last-Modified: %s\n", http_date(item->st.st_mtime)); |
67 | htmlf("Expires: %s\n", http_date(item->st.st_mtime + | 79 | htmlf("Expires: %s\n", http_date(item->st.st_mtime + |
68 | ttl_seconds(item->ttl))); | 80 | ttl_seconds(item->ttl))); |
69 | html("\n"); | 81 | html("\n"); |
70 | html(cgit_doctype); | 82 | html(cgit_doctype); |
diff --git a/ui-summary.c b/ui-summary.c index 46814dd..8ff3642 100644 --- a/ui-summary.c +++ b/ui-summary.c | |||
@@ -7,51 +7,53 @@ | |||
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 | char buf[256], *url; | 16 | char buf[256], *url; |
16 | 17 | ||
17 | commit = lookup_commit(sha1); | 18 | commit = lookup_commit(sha1); |
18 | if (commit && !parse_commit(commit)){ | 19 | if (commit && !parse_commit(commit)){ |
20 | info = cgit_parse_commit(commit); | ||
19 | html("<tr><td>"); | 21 | html("<tr><td>"); |
20 | url = cgit_pageurl(cgit_query_repo, "log", | 22 | url = cgit_pageurl(cgit_query_repo, "log", |
21 | fmt("h=%s", refname)); | 23 | fmt("h=%s", refname)); |
22 | html_link_open(url, NULL, NULL); | 24 | html_link_open(url, NULL, NULL); |
23 | strncpy(buf, refname, sizeof(buf)); | 25 | strncpy(buf, refname, sizeof(buf)); |
24 | html_txt(buf); | 26 | html_txt(buf); |
25 | html_link_close(); | 27 | html_link_close(); |
26 | html("</td><td>"); | 28 | html("</td><td>"); |
27 | pretty_print_commit(CMIT_FMT_ONELINE, commit, ~0, buf, | 29 | cgit_print_date(commit->date); |
28 | sizeof(buf), 0, NULL, NULL, 0); | 30 | html("</td><td>"); |
29 | html_txt(buf); | 31 | url = cgit_pageurl(cgit_query_repo, "commit", fmt("id=%s", sha1_to_hex(sha1))); |
30 | html("</td><td><a href='"); | 32 | html_link_open(url, NULL, NULL); |
31 | html_attr(cgit_pageurl(cgit_query_repo, "tree", | 33 | html_txt(info->subject); |
32 | fmt("id=%s", | 34 | html_link_close(); |
33 | sha1_to_hex(commit->tree->object.sha1)))); | 35 | html("</td><td>"); |
34 | html("'>tree</a>"); | 36 | html_txt(info->author); |
35 | html("</td></tr>\n"); | 37 | html("</td></tr>\n"); |
36 | } else { | 38 | } else { |
37 | html("<tr><td>"); | 39 | html("<tr><td>"); |
38 | html_txt(buf); | 40 | html_txt(buf); |
39 | html("</td><td>"); | 41 | html("</td><td>"); |
40 | htmlf("*** bad ref %s", sha1_to_hex(sha1)); | 42 | htmlf("*** bad ref %s", sha1_to_hex(sha1)); |
41 | html("</td></tr>\n"); | 43 | html("</td></tr>\n"); |
42 | } | 44 | } |
43 | return 0; | 45 | return 0; |
44 | } | 46 | } |
45 | 47 | ||
46 | static void cgit_print_branches() | 48 | static void cgit_print_branches() |
47 | { | 49 | { |
48 | html("<table class='list'>"); | 50 | html("<table class='list'>"); |
49 | html("<tr><th>Branch</th><th>Last commit</th><th>Link</th></tr>\n"); | 51 | html("<tr><th class='left'>Branch</th><th class='left'>Updated</th><th class='left'>Commit subject</th><th class='left'>Author</th></tr>\n"); |
50 | for_each_branch_ref(cgit_print_branch_cb, NULL); | 52 | for_each_branch_ref(cgit_print_branch_cb, NULL); |
51 | html("</table>"); | 53 | html("</table>"); |
52 | } | 54 | } |
53 | 55 | ||
54 | void cgit_print_summary() | 56 | void cgit_print_summary() |
55 | { | 57 | { |
56 | html("<h2>"); | 58 | html("<h2>"); |
57 | html_txt("Repo summary page"); | 59 | html_txt("Repo summary page"); |