diff options
| -rw-r--r-- | Makefile | 5 | ||||
| -rw-r--r-- | cgit.h | 7 | ||||
| -rw-r--r-- | parsing.c | 25 | ||||
| -rw-r--r-- | shared.c | 2 | ||||
| -rw-r--r-- | ui-log.c | 21 | ||||
| -rw-r--r-- | ui-shared.c | 2 |
6 files changed, 54 insertions, 8 deletions
| @@ -19,6 +19,11 @@ OBJECTS = shared.o cache.o parsing.o html.o ui-shared.o ui-repolist.o \ | |||
| 19 | ui-snapshot.o ui-blob.o ui-tag.o ui-refs.o | 19 | ui-snapshot.o ui-blob.o ui-tag.o ui-refs.o |
| 20 | 20 | ||
| 21 | 21 | ||
| 22 | ifdef NEEDS_LIBICONV | ||
| 23 | EXTLIBS += -liconv | ||
| 24 | endif | ||
| 25 | |||
| 26 | |||
| 22 | .PHONY: all git install clean distclean force-version get-git | 27 | .PHONY: all git install clean distclean force-version get-git |
| 23 | 28 | ||
| 24 | all: cgit git | 29 | all: cgit git |
| @@ -16,6 +16,7 @@ | |||
| 16 | #include <log-tree.h> | 16 | #include <log-tree.h> |
| 17 | #include <archive.h> | 17 | #include <archive.h> |
| 18 | #include <xdiff/xdiff.h> | 18 | #include <xdiff/xdiff.h> |
| 19 | #include <utf8.h> | ||
| 19 | 20 | ||
| 20 | 21 | ||
| 21 | /* | 22 | /* |
| @@ -48,6 +49,11 @@ | |||
| 48 | #define TM_MONTH (TM_YEAR / 12.0) | 49 | #define TM_MONTH (TM_YEAR / 12.0) |
| 49 | 50 | ||
| 50 | 51 | ||
| 52 | /* | ||
| 53 | * Default encoding | ||
| 54 | */ | ||
| 55 | #define PAGE_ENCODING "UTF-8" | ||
| 56 | |||
| 51 | typedef void (*configfn)(const char *name, const char *value); | 57 | typedef void (*configfn)(const char *name, const char *value); |
| 52 | typedef void (*filepair_fn)(struct diff_filepair *pair); | 58 | typedef void (*filepair_fn)(struct diff_filepair *pair); |
| 53 | typedef void (*linediff_fn)(char *line, int len); | 59 | typedef void (*linediff_fn)(char *line, int len); |
| @@ -90,6 +96,7 @@ struct commitinfo { | |||
| 90 | unsigned long committer_date; | 96 | unsigned long committer_date; |
| 91 | char *subject; | 97 | char *subject; |
| 92 | char *msg; | 98 | char *msg; |
| 99 | char *msg_encoding; | ||
| 93 | }; | 100 | }; |
| 94 | 101 | ||
| 95 | struct taginfo { | 102 | struct taginfo { |
| @@ -199,6 +199,7 @@ struct commitinfo *cgit_parse_commit(struct commit *commit) | |||
| 199 | ret->committer_email = NULL; | 199 | ret->committer_email = NULL; |
| 200 | ret->subject = NULL; | 200 | ret->subject = NULL; |
| 201 | ret->msg = NULL; | 201 | ret->msg = NULL; |
| 202 | ret->msg_encoding = NULL; | ||
| 202 | 203 | ||
| 203 | if (p == NULL) | 204 | if (p == NULL) |
| 204 | return ret; | 205 | return ret; |
| @@ -233,6 +234,14 @@ struct commitinfo *cgit_parse_commit(struct commit *commit) | |||
| 233 | p = strchr(t, '\n') + 1; | 234 | p = strchr(t, '\n') + 1; |
| 234 | } | 235 | } |
| 235 | 236 | ||
| 237 | if (!strncmp(p, "encoding ", 9)) { | ||
| 238 | p += 9; | ||
| 239 | t = strchr(p, '\n') + 1; | ||
| 240 | ret->msg_encoding = substr(p, t); | ||
| 241 | p = t; | ||
| 242 | } else | ||
| 243 | ret->msg_encoding = xstrdup(PAGE_ENCODING); | ||
| 244 | |||
| 236 | while (*p && (*p != '\n')) | 245 | while (*p && (*p != '\n')) |
| 237 | p = strchr(p, '\n') + 1; // skip unknown header fields | 246 | p = strchr(p, '\n') + 1; // skip unknown header fields |
| 238 | 247 | ||
| @@ -253,6 +262,22 @@ struct commitinfo *cgit_parse_commit(struct commit *commit) | |||
| 253 | } else | 262 | } else |
| 254 | ret->subject = substr(p, p+strlen(p)); | 263 | ret->subject = substr(p, p+strlen(p)); |
| 255 | 264 | ||
| 265 | if(strcmp(ret->msg_encoding, PAGE_ENCODING)) { | ||
| 266 | t = reencode_string(ret->subject, PAGE_ENCODING, | ||
| 267 | ret->msg_encoding); | ||
| 268 | if(t) { | ||
| 269 | free(ret->subject); | ||
| 270 | ret->subject = t; | ||
| 271 | } | ||
| 272 | |||
| 273 | t = reencode_string(ret->msg, PAGE_ENCODING, | ||
| 274 | ret->msg_encoding); | ||
| 275 | if(t) { | ||
| 276 | free(ret->msg); | ||
| 277 | ret->msg = t; | ||
| 278 | } | ||
| 279 | } | ||
| 280 | |||
| 256 | return ret; | 281 | return ret; |
| 257 | } | 282 | } |
| 258 | 283 | ||
| @@ -267,6 +267,8 @@ void *cgit_free_commitinfo(struct commitinfo *info) | |||
| 267 | free(info->committer); | 267 | free(info->committer); |
| 268 | free(info->committer_email); | 268 | free(info->committer_email); |
| 269 | free(info->subject); | 269 | free(info->subject); |
| 270 | free(info->msg); | ||
| 271 | free(info->msg_encoding); | ||
| 270 | free(info); | 272 | free(info); |
| 271 | return NULL; | 273 | return NULL; |
| 272 | } | 274 | } |
| @@ -8,12 +8,18 @@ | |||
| 8 | 8 | ||
| 9 | #include "cgit.h" | 9 | #include "cgit.h" |
| 10 | 10 | ||
| 11 | int files, lines; | 11 | int files, add_lines, rem_lines; |
| 12 | 12 | ||
| 13 | void count_lines(char *line, int size) | 13 | void count_lines(char *line, int size) |
| 14 | { | 14 | { |
| 15 | if (size>0 && (line[0] == '+' || line[0] == '-')) | 15 | if (size <= 0) |
| 16 | lines++; | 16 | return; |
| 17 | |||
| 18 | if (line[0] == '+') | ||
| 19 | add_lines++; | ||
| 20 | |||
| 21 | else if (line[0] == '-') | ||
| 22 | rem_lines++; | ||
| 17 | } | 23 | } |
| 18 | 24 | ||
| 19 | void inspect_files(struct diff_filepair *pair) | 25 | void inspect_files(struct diff_filepair *pair) |
| @@ -35,13 +41,14 @@ void print_commit(struct commit *commit) | |||
| 35 | sha1_to_hex(commit->object.sha1)); | 41 | sha1_to_hex(commit->object.sha1)); |
| 36 | if (cgit_repo->enable_log_filecount) { | 42 | if (cgit_repo->enable_log_filecount) { |
| 37 | files = 0; | 43 | files = 0; |
| 38 | lines = 0; | 44 | add_lines = 0; |
| 45 | rem_lines = 0; | ||
| 39 | cgit_diff_commit(commit, inspect_files); | 46 | cgit_diff_commit(commit, inspect_files); |
| 40 | html("</td><td class='right'>"); | 47 | html("</td><td class='right'>"); |
| 41 | htmlf("%d", files); | 48 | htmlf("%d", files); |
| 42 | if (cgit_repo->enable_log_linecount) { | 49 | if (cgit_repo->enable_log_linecount) { |
| 43 | html("</td><td class='right'>"); | 50 | html("</td><td class='right'>"); |
| 44 | htmlf("%d", lines); | 51 | htmlf("-%d/+%d", rem_lines, add_lines); |
| 45 | } | 52 | } |
| 46 | } | 53 | } |
| 47 | html("</td><td>"); | 54 | html("</td><td>"); |
| @@ -88,9 +95,9 @@ void cgit_print_log(const char *tip, int ofs, int cnt, char *grep, char *pattern | |||
| 88 | "<th class='left'>Message</th>"); | 95 | "<th class='left'>Message</th>"); |
| 89 | 96 | ||
| 90 | if (cgit_repo->enable_log_filecount) { | 97 | if (cgit_repo->enable_log_filecount) { |
| 91 | html("<th class='left'>Files</th>"); | 98 | html("<th class='right'>Files</th>"); |
| 92 | if (cgit_repo->enable_log_linecount) | 99 | if (cgit_repo->enable_log_linecount) |
| 93 | html("<th class='left'>Lines</th>"); | 100 | html("<th class='right'>Lines</th>"); |
| 94 | } | 101 | } |
| 95 | html("<th class='left'>Author</th></tr>\n"); | 102 | html("<th class='left'>Author</th></tr>\n"); |
| 96 | 103 | ||
diff --git a/ui-shared.c b/ui-shared.c index 72a7b44..7c69f60 100644 --- a/ui-shared.c +++ b/ui-shared.c | |||
| @@ -352,7 +352,7 @@ void cgit_print_age(time_t t, time_t max_relative, char *format) | |||
| 352 | 352 | ||
| 353 | void cgit_print_docstart(char *title, struct cacheitem *item) | 353 | void cgit_print_docstart(char *title, struct cacheitem *item) |
| 354 | { | 354 | { |
| 355 | html("Content-Type: text/html; charset=utf-8\n"); | 355 | html("Content-Type: text/html; charset=" PAGE_ENCODING "\n"); |
| 356 | htmlf("Last-Modified: %s\n", http_date(item->st.st_mtime)); | 356 | htmlf("Last-Modified: %s\n", http_date(item->st.st_mtime)); |
| 357 | htmlf("Expires: %s\n", http_date(item->st.st_mtime + | 357 | htmlf("Expires: %s\n", http_date(item->st.st_mtime + |
| 358 | ttl_seconds(item->ttl))); | 358 | ttl_seconds(item->ttl))); |
