1/*
2 * Another stupid program, this one parsing the headers of an
3 * email to figure out authorship and subject
4 */
5#include "cache.h"
6#include "builtin.h"
7#include "utf8.h"
8#include "strbuf.h"
9#include "mailinfo.h"
10
11static const char mailinfo_usage[] =
12 "git mailinfo [-k | -b] [-m | --message-id] [-u | --encoding=<encoding> | -n] [--scissors | --no-scissors] <msg> <patch> < mail >info";
13
14int cmd_mailinfo(int argc, const char **argv, const char *prefix)
15{
16 const char *def_charset;
17 struct mailinfo mi;
18 int status;
19
20 /* NEEDSWORK: might want to do the optional .git/ directory
21 * discovery
22 */
23 setup_mailinfo(&mi);
24
25 def_charset = get_commit_output_encoding();
26 mi.metainfo_charset = def_charset;
27
28 while (1 < argc && argv[1][0] == '-') {
29 if (!strcmp(argv[1], "-k"))
30 mi.keep_subject = 1;
31 else if (!strcmp(argv[1], "-b"))
32 mi.keep_non_patch_brackets_in_subject = 1;
33 else if (!strcmp(argv[1], "-m") || !strcmp(argv[1], "--message-id"))
34 mi.add_message_id = 1;
35 else if (!strcmp(argv[1], "-u"))
36 mi.metainfo_charset = def_charset;
37 else if (!strcmp(argv[1], "-n"))
38 mi.metainfo_charset = NULL;
39 else if (starts_with(argv[1], "--encoding="))
40 mi.metainfo_charset = argv[1] + 11;
41 else if (!strcmp(argv[1], "--scissors"))
42 mi.use_scissors = 1;
43 else if (!strcmp(argv[1], "--no-scissors"))
44 mi.use_scissors = 0;
45 else if (!strcmp(argv[1], "--no-inbody-headers"))
46 mi.use_inbody_headers = 0;
47 else
48 usage(mailinfo_usage);
49 argc--; argv++;
50 }
51
52 if (argc != 3)
53 usage(mailinfo_usage);
54
55 mi.input = stdin;
56 mi.output = stdout;
57 status = !!mailinfo(&mi, argv[1], argv[2]);
58 clear_mailinfo(&mi);
59
60 return status;
61}