X-Git-Url: https://gitweb.ps.run/ps-cgit/blobdiff_plain/732d68d240b95dc428c92fc94bce9adb8912094e..5ec6e02bd1cc0c05b7cfd0d53371e7d176daec39:/ui-log.c diff --git a/ui-log.c b/ui-log.c index c353b2a..6d5509b 100644 --- a/ui-log.c +++ b/ui-log.c @@ -8,6 +8,20 @@ #include "cgit.h" +int files, lines; + +void count_lines(char *line, int size) +{ + if (size>0 && (line[0] == '+' || line[0] == '-')) + lines++; +} + +void inspect_files(struct diff_filepair *pair) +{ + files++; + cgit_diff_files(pair->one->sha1, pair->two->sha1, count_lines); +} + void print_commit(struct commit *commit) { char buf[32]; @@ -17,14 +31,21 @@ void print_commit(struct commit *commit) info = cgit_parse_commit(commit); time = gmtime(&commit->date); html(""); - strftime(buf, sizeof(buf), "%Y-%m-%d %H:%M:%S", time); + strftime(buf, sizeof(buf), "%Y-%m-%d %H:%M", time); html_txt(buf); html(""); char *qry = fmt("id=%s", sha1_to_hex(commit->object.sha1)); char *url = cgit_pageurl(cgit_query_repo, "commit", qry); html_link_open(url, NULL, NULL); - html_ntxt(80, info->subject); + html_ntxt(cgit_max_msg_len, info->subject); html_link_close(); + files = 0; + lines = 0; + cgit_diff_commit(commit, inspect_files); + html(""); + htmlf("%d", files); + html(""); + htmlf("%d", lines); html(""); html_txt(info->author); html("\n"); @@ -32,16 +53,20 @@ void print_commit(struct commit *commit) } -void cgit_print_log(const char *tip, int ofs, int cnt, char *grep) +void cgit_print_log(const char *tip, int ofs, int cnt, char *grep, char *path) { struct rev_info rev; struct commit *commit; - const char *argv[3] = {NULL, tip, NULL}; + const char *argv[] = {NULL, tip, NULL, NULL, NULL}; int argc = 2; int i; - + if (grep) argv[argc++] = fmt("--grep=%s", grep); + if (path) { + argv[argc++] = "--"; + argv[argc++] = path; + } init_revisions(&rev, NULL); rev.abbrev = DEFAULT_ABBREV; rev.commit_format = CMIT_FMT_DEFAULT; @@ -54,10 +79,11 @@ void cgit_print_log(const char *tip, int ofs, int cnt, char *grep) } prepare_revision_walk(&rev); - html("

Log

"); html(""); - html("" + html("" "" + "" + "" "\n"); if (ofs<0)
Date
DateMessageFilesLinesAuthor