]> diplodocus.org Git - nmh/blob - uip/mhpath.c
Use va_copy() to get a copy of va_list, instead of using original.
[nmh] / uip / mhpath.c
1 /* mhpath.c -- print full pathnames of nmh messages and folders
2 *
3 * This code is Copyright (c) 2002, by the authors of nmh. See the
4 * COPYRIGHT file in the root directory of the nmh distribution for
5 * complete copyright information.
6 */
7
8 #include <h/mh.h>
9 #include "h/done.h"
10 #include <h/utils.h>
11 #include "sbr/m_maildir.h"
12
13 #define MHPATH_SWITCHES \
14 X("version", 0, VERSIONSW) \
15 X("help", 0, HELPSW) \
16
17 #define X(sw, minchars, id) id,
18 DEFINE_SWITCH_ENUM(MHPATH);
19 #undef X
20
21 #define X(sw, minchars, id) { sw, minchars, id },
22 DEFINE_SWITCH_ARRAY(MHPATH, switches);
23 #undef X
24
25 int
26 main(int argc, char **argv)
27 {
28 int i;
29 char *cp, *maildir, *folder = NULL;
30 char **argp;
31 char **arguments, buf[BUFSIZ];
32 struct msgs_array msgs = { 0, 0, NULL };
33 struct msgs *mp;
34
35 if (nmh_init(argv[0], true, false)) { return 1; }
36
37 arguments = getarguments (invo_name, argc, argv, 1);
38 argp = arguments;
39
40 /*
41 * Parse arguments
42 */
43 while ((cp = *argp++)) {
44 if (*cp == '-') {
45 switch (smatch (++cp, switches)) {
46 case AMBIGSW:
47 ambigsw (cp, switches);
48 done (1);
49 case UNKWNSW:
50 die("-%s unknown", cp);
51
52 case HELPSW:
53 snprintf (buf, sizeof(buf), "%s [+folder] [msgs] [switches]",
54 invo_name);
55 print_help (buf, switches, 1);
56 done (0);
57 case VERSIONSW:
58 print_version(invo_name);
59 done (0);
60 }
61 }
62 if (*cp == '+' || *cp == '@') {
63 if (folder)
64 die("only one folder at a time!");
65 folder = pluspath (cp);
66 } else
67 app_msgarg(&msgs, cp);
68 }
69
70 if (!context_find ("path"))
71 free (path ("./", TFOLDER));
72
73 if (!folder)
74 folder = getfolder (1);
75 maildir = m_maildir (folder);
76
77 /* If no messages are given, print folder pathname */
78 if (!msgs.size) {
79 puts(maildir);
80 done (0);
81 }
82
83 if (chdir (maildir) == NOTOK)
84 adios (maildir, "unable to change directory to");
85
86 /* read folder and create message structure */
87 if (!(mp = folder_read (folder, 1)))
88 die("unable to read folder %s", folder);
89
90 /*
91 * We need to make sure there is message status space
92 * for all the message numbers from 1 to "new" since
93 * mhpath can select empty slots. If we are adding
94 * space at the end, we go ahead and add 10 slots.
95 */
96 if (mp->hghmsg >= mp->hghoff) {
97 if (!(mp = folder_realloc (mp, 1, mp->hghmsg + 10)))
98 die("unable to allocate folder storage");
99 } else if (mp->lowoff > 1) {
100 if (!(mp = folder_realloc (mp, 1, mp->hghoff)))
101 die("unable to allocate folder storage");
102 }
103
104 mp->msgflags |= ALLOW_NEW; /* allow the "new" sequence */
105
106 /* parse all the message ranges/sequences and set SELECTED */
107 for (i = 0; i < msgs.size; i++)
108 if (!m_convert (mp, msgs.msgs[i]))
109 done (1);
110
111 seq_setprev (mp); /* set the previous-sequence */
112
113 /* print the path of all selected messages */
114 for (i = mp->lowsel; i <= mp->hghsel; i++)
115 if (is_selected (mp, i))
116 printf ("%s/%s\n", mp->foldpath, m_name (i));
117
118 seq_save (mp); /* synchronize message sequences */
119 context_save (); /* save the context file */
120 folder_free (mp); /* free folder/message structure */
121 done (0);
122 return 1;
123 }