summary refs log tree commit diff
diff options
context:
space:
mode:
authorJune McEnroe <june@causal.agency>2020-04-17 11:00:28 -0400
committerJune McEnroe <june@causal.agency>2020-04-17 11:00:28 -0400
commita4b9f643b801f82b64addf39ccf16283d633703d (patch)
tree6a34a35442bf124246780b9c6eed43732e9bd071
parentSkip invalid characters in base64 (diff)
downloadbubger-a4b9f643b801f82b64addf39ccf16283d633703d.tar.gz
bubger-a4b9f643b801f82b64addf39ccf16283d633703d.zip
Add decodeToFile
Diffstat (limited to '')
-rw-r--r--archive.h1
-rw-r--r--decode.c18
2 files changed, 16 insertions, 3 deletions
diff --git a/archive.h b/archive.h
index a7377ab..d0bc00d 100644
--- a/archive.h
+++ b/archive.h
@@ -154,6 +154,7 @@ char *templateURL(const char *template, const struct Variable vars[]);
 
 char *decodeHeader(const char *header);
 char *decodeToString(const struct BodyPart *part, const char *content);
+int decodeToFile(FILE *file, const struct BodyPart *part, const char *content);
 
 static inline const char *pathUID(uint32_t uid, const char *type) {
 	static char buf[PATH_MAX];
diff --git a/decode.c b/decode.c
index 24de9d3..35e6dfd 100644
--- a/decode.c
+++ b/decode.c
@@ -244,14 +244,26 @@ char *decodeHeader(const char *header) {
 	return bufferString(&buf);
 }
 
-char *decodeToString(const struct BodyPart *part, const char *src) {
-	struct Buffer dst = bufferAlloc(strlen(src) + 1);
+static const char *partCharset(const struct BodyPart *part) {
 	const char *charset = NULL;
 	for (size_t i = 0; i + 1 < part->params.len; i += 2) {
 		const char *key = dataCheck(part->params.ptr[i], String).string;
 		if (strcasecmp(key, "charset")) continue;
 		charset = dataCheck(part->params.ptr[i + 1], String).string;
 	}
-	decode(&dst, part->encoding, charset, src);
+	return charset;
+}
+
+char *decodeToString(const struct BodyPart *part, const char *src) {
+	struct Buffer dst = bufferAlloc(strlen(src) + 1);
+	decode(&dst, part->encoding, partCharset(part), src);
 	return bufferString(&dst);
 }
+
+int decodeToFile(FILE *file, const struct BodyPart *part, const char *src) {
+	struct Buffer dst = bufferAlloc(strlen(src));
+	decode(&dst, part->encoding, partCharset(part), src);
+	size_t n = fwrite(dst.ptr, dst.len, 1, file);
+	free(dst.ptr);
+	return (n ? 0 : -1);
+}