From: Fredrik Tolf Date: Sun, 29 Aug 2010 14:40:33 +0000 (+0200) Subject: Try to add default charset for text/* types in sendfile. X-Git-Tag: 0.1~64 X-Git-Url: http://dolda2000.com/gitweb/?p=ashd.git;a=commitdiff_plain;h=cc828cb983a024b5df467a83c12e594b38b10f1e Try to add default charset for text/* types in sendfile. --- diff --git a/src/sendfile.c b/src/sendfile.c index ce422e2..fbf5f1b 100644 --- a/src/sendfile.c +++ b/src/sendfile.c @@ -26,6 +26,8 @@ #include #include #include +#include +#include #ifdef HAVE_CONFIG_H #include @@ -108,6 +110,15 @@ static const char *getmimetype(char *file, struct stat *sb) return("application/octet-stream"); } +/* XXX: This could be made far better and check for other attributes + * and stuff, but not now. */ +static const char *ckctype(const char *ctype) +{ + if(!strncmp(ctype, "text/", 5) && (strchr(ctype, ';') == NULL)) + return(sprintf2("%s; charset=%s", ctype, nl_langinfo(CODESET))); + return(ctype); +} + static void checkcache(char *file, struct stat *sb) { char *hdr; @@ -136,6 +147,7 @@ int main(int argc, char **argv) int fd; const char *contype; + setlocale(LC_ALL, ""); contype = NULL; while((c = getopt(argc, argv, "c:")) >= 0) { switch(c) { @@ -167,6 +179,7 @@ int main(int argc, char **argv) } if(contype == NULL) contype = getmimetype(file, &sb); + contype = ckctype(contype); checkcache(file, &sb);