summaryrefslogtreecommitdiffabout
Side-by-side diff
Diffstat (more/less context) (show whitespace changes)
-rw-r--r--cgit.h1
-rw-r--r--parsing.c64
2 files changed, 5 insertions, 60 deletions
diff --git a/cgit.h b/cgit.h
index 6c7a941..6291c58 100644
--- a/cgit.h
+++ b/cgit.h
@@ -18,2 +18,3 @@
#include <xdiff/xdiff.h>
+#include <utf8.h>
diff --git a/parsing.c b/parsing.c
index c731084..e8c7ab9 100644
--- a/parsing.c
+++ b/parsing.c
@@ -8,4 +8,2 @@
-#include <iconv.h>
-
#include "cgit.h"
@@ -180,58 +178,2 @@ void cgit_parse_url(const char *url)
-static char *iconv_msg(char *msg, const char *encoding)
-{
- iconv_t msg_conv = iconv_open(PAGE_ENCODING, encoding);
- size_t inlen = strlen(msg);
- char *in;
- char *out;
- size_t inleft;
- size_t outleft;
- char *buf;
- char *ret;
- size_t buf_sz;
- int again, fail;
-
- if(msg_conv == (iconv_t)-1)
- return NULL;
-
- buf_sz = inlen * 2;
- buf = xmalloc(buf_sz+1);
- do {
- in = msg;
- inleft = inlen;
-
- out = buf;
- outleft = buf_sz;
- iconv(msg_conv, &in, &inleft, &out, &outleft);
-
- if(inleft == 0) {
- fail = 0;
- again = 0;
- } else if(inleft != 0 && errno == E2BIG) {
- fail = 0;
- again = 1;
-
- buf_sz *= 2;
- free(buf);
- buf = xmalloc(buf_sz+1);
- } else {
- fail = 1;
- again = 0;
- }
- } while(again && !fail);
-
- if(fail) {
- free(buf);
- ret = NULL;
- } else {
- buf = xrealloc(buf, out - buf);
- *out = 0;
- ret = buf;
- }
-
- iconv_close(msg_conv);
-
- return ret;
-}
-
char *substr(const char *head, const char *tail)
@@ -323,3 +265,4 @@ struct commitinfo *cgit_parse_commit(struct commit *commit)
if(strcmp(ret->msg_encoding, PAGE_ENCODING)) {
- t = iconv_msg(ret->subject, ret->msg_encoding);
+ t = reencode_string(ret->subject, PAGE_ENCODING,
+ ret->msg_encoding);
if(t) {
@@ -329,3 +272,4 @@ struct commitinfo *cgit_parse_commit(struct commit *commit)
- t = iconv_msg(ret->msg, ret->msg_encoding);
+ t = reencode_string(ret->msg, PAGE_ENCODING,
+ ret->msg_encoding);
if(t) {