diff options
| -rw-r--r-- | cgit.c | 2 | ||||
| -rw-r--r-- | cgit.h | 1 | ||||
| -rw-r--r-- | shared.c | 9 | ||||
| -rw-r--r-- | ui-log.c | 31 | 
4 files changed, 37 insertions, 6 deletions
| @@ -29,7 +29,7 @@ static void cgit_print_repo_page(struct cacheitem *item) | |||
| 29 | if (!cgit_query_page) { | 29 | if (!cgit_query_page) { | 
| 30 | cgit_print_summary(); | 30 | cgit_print_summary(); | 
| 31 | } else if (!strcmp(cgit_query_page, "log")) { | 31 | } else if (!strcmp(cgit_query_page, "log")) { | 
| 32 | cgit_print_log(cgit_query_head, 0, 100); | 32 | cgit_print_log(cgit_query_head, cgit_query_ofs, 100); | 
| 33 | } else if (!strcmp(cgit_query_page, "tree")) { | 33 | } else if (!strcmp(cgit_query_page, "tree")) { | 
| 34 | cgit_print_tree(cgit_query_sha1); | 34 | cgit_print_tree(cgit_query_sha1); | 
| 35 | } else if (!strcmp(cgit_query_page, "view")) { | 35 | } else if (!strcmp(cgit_query_page, "view")) { | 
| @@ -44,6 +44,7 @@ extern char *cgit_query_repo; | |||
| 44 | extern char *cgit_query_page; | 44 | extern char *cgit_query_page; | 
| 45 | extern char *cgit_query_head; | 45 | extern char *cgit_query_head; | 
| 46 | extern char *cgit_query_sha1; | 46 | extern char *cgit_query_sha1; | 
| 47 | extern int cgit_query_ofs; | ||
| 47 | 48 | ||
| 48 | extern int htmlfd; | 49 | extern int htmlfd; | 
| 49 | 50 | ||
| @@ -28,6 +28,7 @@ char *cgit_query_repo = NULL; | |||
| 28 | char *cgit_query_page = NULL; | 28 | char *cgit_query_page = NULL; | 
| 29 | char *cgit_query_head = NULL; | 29 | char *cgit_query_head = NULL; | 
| 30 | char *cgit_query_sha1 = NULL; | 30 | char *cgit_query_sha1 = NULL; | 
| 31 | int cgit_query_ofs = 0; | ||
| 31 | 32 | ||
| 32 | int htmlfd = 0; | 33 | int htmlfd = 0; | 
| 33 | 34 | ||
| @@ -59,16 +60,18 @@ void cgit_repo_config_cb(const char *name, const char *value) | |||
| 59 | 60 | ||
| 60 | void cgit_querystring_cb(const char *name, const char *value) | 61 | void cgit_querystring_cb(const char *name, const char *value) | 
| 61 | { | 62 | { | 
| 62 | if (!strcmp(name,"r")) | 63 | if (!strcmp(name,"r")) { | 
| 63 | cgit_query_repo = xstrdup(value); | 64 | cgit_query_repo = xstrdup(value); | 
| 64 | else if (!strcmp(name, "p")) | 65 | } else if (!strcmp(name, "p")) { | 
| 65 | cgit_query_page = xstrdup(value); | 66 | cgit_query_page = xstrdup(value); | 
| 66 | else if (!strcmp(name, "h")) { | 67 | } else if (!strcmp(name, "h")) { | 
| 67 | cgit_query_head = xstrdup(value); | 68 | cgit_query_head = xstrdup(value); | 
| 68 | cgit_query_has_symref = 1; | 69 | cgit_query_has_symref = 1; | 
| 69 | } else if (!strcmp(name, "id")) { | 70 | } else if (!strcmp(name, "id")) { | 
| 70 | cgit_query_sha1 = xstrdup(value); | 71 | cgit_query_sha1 = xstrdup(value); | 
| 71 | cgit_query_has_sha1 = 1; | 72 | cgit_query_has_sha1 = 1; | 
| 73 | } else if (!strcmp(name, "ofs")) { | ||
| 74 | cgit_query_ofs = atoi(value); | ||
| 72 | } | 75 | } | 
| 73 | } | 76 | } | 
| 74 | 77 | ||
| @@ -95,7 +95,7 @@ void cgit_print_log(const char *tip, int ofs, int cnt) | |||
| 95 | struct rev_info rev; | 95 | struct rev_info rev; | 
| 96 | struct commit *commit; | 96 | struct commit *commit; | 
| 97 | const char *argv[2] = {NULL, tip}; | 97 | const char *argv[2] = {NULL, tip}; | 
| 98 | int n = 0; | 98 | int i; | 
| 99 | 99 | ||
| 100 | init_revisions(&rev, NULL); | 100 | init_revisions(&rev, NULL); | 
| 101 | rev.abbrev = DEFAULT_ABBREV; | 101 | rev.abbrev = DEFAULT_ABBREV; | 
| @@ -108,7 +108,18 @@ void cgit_print_log(const char *tip, int ofs, int cnt) | |||
| 108 | html("<h2>Log</h2>"); | 108 | html("<h2>Log</h2>"); | 
| 109 | html("<table class='list'>"); | 109 | html("<table class='list'>"); | 
| 110 | html("<tr><th>Date</th><th>Message</th><th>Author</th><th>Link</th></tr>\n"); | 110 | html("<tr><th>Date</th><th>Message</th><th>Author</th><th>Link</th></tr>\n"); | 
| 111 | while ((commit = get_revision(&rev)) != NULL && n++ < 100) { | 111 | |
| 112 | if (ofs<0) | ||
| 113 | ofs = 0; | ||
| 114 | |||
| 115 | for (i = 0; i < ofs && (commit = get_revision(&rev)) != NULL; i++) { | ||
| 116 | free(commit->buffer); | ||
| 117 | commit->buffer = NULL; | ||
| 118 | free_commit_list(commit->parents); | ||
| 119 | commit->parents = NULL; | ||
| 120 | } | ||
| 121 | |||
| 122 | for (i = 0; i < cnt && (commit = get_revision(&rev)) != NULL; i++) { | ||
| 112 | cgit_print_commit_shortlog(commit); | 123 | cgit_print_commit_shortlog(commit); | 
| 113 | free(commit->buffer); | 124 | free(commit->buffer); | 
| 114 | commit->buffer = NULL; | 125 | commit->buffer = NULL; | 
| @@ -116,5 +127,21 @@ void cgit_print_log(const char *tip, int ofs, int cnt) | |||
| 116 | commit->parents = NULL; | 127 | commit->parents = NULL; | 
| 117 | } | 128 | } | 
| 118 | html("</table>\n"); | 129 | html("</table>\n"); | 
| 130 | |||
| 131 | html("<div class='pager'>"); | ||
| 132 | if (ofs > 0) { | ||
| 133 | html(" <a href='"); | ||
| 134 | html(cgit_pageurl(cgit_query_repo, cgit_query_page, | ||
| 135 | fmt("h=%s&ofs=%d", tip, ofs-cnt))); | ||
| 136 | html("'>[prev]</a> "); | ||
| 137 | } | ||
| 138 | |||
| 139 | if ((commit = get_revision(&rev)) != NULL) { | ||
| 140 | html(" <a href='"); | ||
| 141 | html(cgit_pageurl(cgit_query_repo, "log", | ||
| 142 | fmt("h=%s&ofs=%d", tip, ofs+cnt))); | ||
| 143 | html("'>[next]</a> "); | ||
| 144 | } | ||
| 145 | html("</div>"); | ||
| 119 | } | 146 | } | 
| 120 | 147 | ||
