X-Git-Url: https://gitweb.ps.run/ps-cgit/blobdiff_plain/e87e89633383b8b75c68c98be3e0c14212109de2..fbe091a716447be496519ce439451d36d5b9fc24:/html.c diff --git a/html.c b/html.c index 98ffaf9..66ba65d 100644 --- a/html.c +++ b/html.c @@ -11,6 +11,7 @@ #include #include #include +#include int htmlfd = STDOUT_FILENO; @@ -34,6 +35,11 @@ char *fmt(const char *format, ...) return buf[bufidx]; } +void html_raw(const char *data, size_t size) +{ + write(htmlfd, data, size); +} + void html(const char *txt) { write(htmlfd, txt, strlen(txt)); @@ -50,15 +56,20 @@ void htmlf(const char *format, ...) html(buf); } +void html_status(int code, const char *msg, int more_headers) +{ + htmlf("Status: %d %s\n", code, msg); + if (!more_headers) + html("\n"); +} + void html_txt(char *txt) { char *t = txt; while(t && *t){ int c = *t; if (c=='<' || c=='>' || c=='&') { - *t = '\0'; - html(txt); - *t = c; + write(htmlfd, txt, t - txt); if (c=='>') html(">"); else if (c=='<') @@ -79,9 +90,7 @@ void html_ntxt(int len, char *txt) while(t && *t && len--){ int c = *t; if (c=='<' || c=='>' || c=='&') { - *t = '\0'; - html(txt); - *t = c; + write(htmlfd, txt, t - txt); if (c=='>') html(">"); else if (c=='<') @@ -92,12 +101,8 @@ void html_ntxt(int len, char *txt) } t++; } - if (t!=txt) { - char c = *t; - *t = '\0'; - html(txt); - *t = c; - } + if (t!=txt) + write(htmlfd, txt, t - txt); if (len<0) html("..."); } @@ -107,16 +112,48 @@ void html_attr(char *txt) char *t = txt; while(t && *t){ int c = *t; - if (c=='<' || c=='>' || c=='\'') { - *t = '\0'; - html(txt); - *t = c; + if (c=='<' || c=='>' || c=='\'' || c=='\"') { + write(htmlfd, txt, t - txt); if (c=='>') html(">"); else if (c=='<') html("<"); else if (c=='\'') - html(""e;"); + html("'"); + else if (c=='"') + html("""); + txt = t+1; + } + t++; + } + if (t!=txt) + html(txt); +} + +void html_url_path(char *txt) +{ + char *t = txt; + while(t && *t){ + int c = *t; + if (c=='"' || c=='#' || c=='\'' || c=='?') { + write(htmlfd, txt, t - txt); + write(htmlfd, fmt("%%%2x", c), 3); + txt = t+1; + } + t++; + } + if (t!=txt) + html(txt); +} + +void html_url_arg(char *txt) +{ + char *t = txt; + while(t && *t){ + int c = *t; + if (c=='"' || c=='#' || c=='%' || c=='&' || c=='\'' || c=='+' || c=='?') { + write(htmlfd, txt, t - txt); + write(htmlfd, fmt("%%%2x", c), 3); txt = t+1; } t++; @@ -178,8 +215,11 @@ int html_include(const char *filename) char buf[4096]; size_t len; - if (!(f = fopen(filename, "r"))) + if (!(f = fopen(filename, "r"))) { + fprintf(stderr, "[cgit] Failed to include file %s: %s (%d).\n", + filename, strerror(errno), errno); return -1; + } while((len = fread(buf, 1, 4096, f)) > 0) write(htmlfd, buf, len); fclose(f);