diff options
| author | 2007-11-06 08:38:18 (JST) | |
|---|---|---|
| committer | 2007-11-06 08:38:18 (JST) | |
| commit | 55ac326ecb01161bf62865ae3350acf85db97d63 (patch) | |
| tree | e37bcd8fef5523aa627ec9fdcd3401105f8e579d | |
| parent | d04c4734bcf40b1d17c55b18fba2aa8344678e8f (diff) | |
| parent | a2ebbd6948da96172108db5e9c02c141923ad05c (diff) | |
| download | cgit-55ac326ecb01161bf62865ae3350acf85db97d63.zip cgit-55ac326ecb01161bf62865ae3350acf85db97d63.tar.gz | |
Merge branch 'iconv-rebased' of http://x2a.org/pub/git/cgit
* 'iconv-rebased' of http://x2a.org/pub/git/cgit:
Use utf8::reencode_string from git
Convert subject and message with iconv_msg.
Add iconv_msg function.
Set msg_encoding according to the header.
Add commit->msg_encoding, allocate msg dynamicly.
| -rw-r--r-- | cgit.h | 7 | ||||
| -rw-r--r-- | parsing.c | 25 | ||||
| -rw-r--r-- | shared.c | 2 | ||||
| -rw-r--r-- | ui-shared.c | 2 |
4 files changed, 35 insertions, 1 deletions
| @@ -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 | ||
| @@ -265,6 +265,8 @@ void *cgit_free_commitinfo(struct commitinfo *info) | |||
| 265 | free(info->committer); | 265 | free(info->committer); |
| 266 | free(info->committer_email); | 266 | free(info->committer_email); |
| 267 | free(info->subject); | 267 | free(info->subject); |
| 268 | free(info->msg); | ||
| 269 | free(info->msg_encoding); | ||
| 268 | free(info); | 270 | free(info); |
| 269 | return NULL; | 271 | return NULL; |
| 270 | } | 272 | } |
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))); |
