add-patch: add NEEDSWORK about comparing commits
[git] / mailinfo.h
1 #ifndef MAILINFO_H
2 #define MAILINFO_H
3
4 #include "strbuf.h"
5
6 #define MAX_BOUNDARIES 5
7
8 struct mailinfo {
9         FILE *input;
10         FILE *output;
11         FILE *patchfile;
12
13         struct strbuf name;
14         struct strbuf email;
15         int keep_subject;
16         int keep_non_patch_brackets_in_subject;
17         int add_message_id;
18         int use_scissors;
19         int use_inbody_headers;
20         const char *metainfo_charset;
21
22         struct strbuf *content[MAX_BOUNDARIES];
23         struct strbuf **content_top;
24         struct strbuf charset;
25         unsigned int format_flowed:1;
26         unsigned int delsp:1;
27         char *message_id;
28         enum  {
29                 TE_DONTCARE, TE_QP, TE_BASE64
30         } transfer_encoding;
31         int patch_lines;
32         int filter_stage; /* still reading log or are we copying patch? */
33         int header_stage; /* still checking in-body headers? */
34         struct strbuf inbody_header_accum;
35         struct strbuf **p_hdr_data;
36         struct strbuf **s_hdr_data;
37
38         struct strbuf log_message;
39         int input_error;
40 };
41
42 void setup_mailinfo(struct mailinfo *);
43 int mailinfo(struct mailinfo *, const char *msg, const char *patch);
44 void clear_mailinfo(struct mailinfo *);
45
46 #endif /* MAILINFO_H */