diff options
| author | John Keeping <john@keeping.me.uk> | 2013-04-07 14:40:50 +0100 | 
|---|---|---|
| committer | Jason A. Donenfeld <Jason@zx2c4.com> | 2013-04-08 16:10:11 +0200 | 
| commit | fd00d2f9d6088223f57006949dc6ce7c36316a79 (patch) | |
| tree | 46092821a261964a35b36f0e22b924fdd144bf75 /html.c | |
| parent | Mark char* fields in struct cgit_page as const (diff) | |
| download | cgit-fd00d2f9d6088223f57006949dc6ce7c36316a79.tar.gz cgit-fd00d2f9d6088223f57006949dc6ce7c36316a79.tar.bz2 cgit-fd00d2f9d6088223f57006949dc6ce7c36316a79.zip | |
html.c: add various strbuf and varadic helpers
This adds the fmtalloc helper, html_txtf, html_vtxtf, and html_attrf.
These takes a printf style format string like htmlf but escapes the
resulting string.  The html_vtxtf variant takes a va_list whereas
html_txtf is variadic.
Signed-off-by: John Keeping <john@keeping.me.uk>
Diffstat (limited to '')
| -rw-r--r-- | html.c | 53 | 
1 files changed, 50 insertions, 3 deletions
| @@ -63,6 +63,18 @@ char *fmt(const char *format, ...)  	return buf[bufidx];  } +char *fmtalloc(const char *format, ...) +{ +	struct strbuf sb = STRBUF_INIT; +	va_list args; + +	va_start(args, format); +	strbuf_vaddf(&sb, format, args); +	va_end(args); + +	return strbuf_detach(&sb, NULL); +} +  void html_raw(const char *data, size_t size)  {  	if (write(htmlfd, data, size) != size) @@ -76,13 +88,35 @@ void html(const char *txt)  void htmlf(const char *format, ...)  { -	static char buf[65536]; +	va_list args; +	struct strbuf buf = STRBUF_INIT; + +	va_start(args, format); +	strbuf_vaddf(&buf, format, args); +	va_end(args); +	html(buf.buf); +	strbuf_release(&buf); +} + +void html_txtf(const char *format, ...) +{  	va_list args;  	va_start(args, format); -	vsnprintf(buf, sizeof(buf), format, args); +	html_vtxtf(format, args);  	va_end(args); -	html(buf); +} + +void html_vtxtf(const char *format, va_list ap) +{ +	va_list cp; +	struct strbuf buf = STRBUF_INIT; + +	va_copy(cp, ap); +	strbuf_vaddf(&buf, format, cp); +	va_end(cp); +	html_txt(buf.buf); +	strbuf_release(&buf);  }  void html_status(int code, const char *msg, int more_headers) @@ -136,6 +170,19 @@ void html_ntxt(int len, const char *txt)  		html("...");  } +void html_attrf(const char *fmt, ...) +{ +	va_list ap; +	struct strbuf sb = STRBUF_INIT; + +	va_start(ap, fmt); +	strbuf_vaddf(&sb, fmt, ap); +	va_end(ap); + +	html_attr(sb.buf); +	strbuf_release(&sb); +} +  void html_attr(const char *txt)  {  	const char *t = txt; | 
