summaryrefslogtreecommitdiffstats
path: root/mailinfo.h
diff options
context:
space:
mode:
authorJunio C Hamano <gitster@pobox.com>2015-10-15 02:44:55 +0200
committerJunio C Hamano <gitster@pobox.com>2015-10-22 00:59:34 +0200
commitc6905e45f078530cda57690b0db6a7378dc1f794 (patch)
tree520e8dc5cfa3c23a9ab594346ee17fef1f30b86d /mailinfo.h
parentmailinfo: keep the parsed log message in a strbuf (diff)
downloadgit-c6905e45f078530cda57690b0db6a7378dc1f794.tar.xz
git-c6905e45f078530cda57690b0db6a7378dc1f794.zip
mailinfo: libify
Move the bulk of the code from builtin/mailinfo.c to mailinfo.c so that new callers can start calling mailinfo() directly. Note that a few calls to exit() and die() need to be cleaned up for the API to be truly useful, which will come in later steps. Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'mailinfo.h')
-rw-r--r--mailinfo.h40
1 files changed, 40 insertions, 0 deletions
diff --git a/mailinfo.h b/mailinfo.h
new file mode 100644
index 0000000000..1e97b737f3
--- /dev/null
+++ b/mailinfo.h
@@ -0,0 +1,40 @@
+#ifndef MAILINFO_H
+#define MAILINFO_H
+
+#define MAX_BOUNDARIES 5
+
+struct mailinfo {
+ FILE *input;
+ FILE *output;
+ FILE *patchfile;
+
+ struct strbuf name;
+ struct strbuf email;
+ int keep_subject;
+ int keep_non_patch_brackets_in_subject;
+ int add_message_id;
+ int use_scissors;
+ int use_inbody_headers;
+ const char *metainfo_charset;
+
+ struct strbuf *content[MAX_BOUNDARIES];
+ struct strbuf **content_top;
+ struct strbuf charset;
+ char *message_id;
+ enum {
+ TE_DONTCARE, TE_QP, TE_BASE64
+ } transfer_encoding;
+ int patch_lines;
+ int filter_stage; /* still reading log or are we copying patch? */
+ int header_stage; /* still checking in-body headers? */
+ struct strbuf **p_hdr_data;
+ struct strbuf **s_hdr_data;
+
+ struct strbuf log_message;
+};
+
+extern void setup_mailinfo(struct mailinfo *);
+extern int mailinfo(struct mailinfo *, const char *msg, const char *patch);
+extern void clear_mailinfo(struct mailinfo *);
+
+#endif /* MAILINFO_H */