+ /*
+ ** check if message is coming from file
+ */
+ if (file) {
+ if (!(cts = (CT *) calloc((size_t) 2, sizeof(*cts))))
+ adios(NULL, "out of memory");
+ ctp = cts;
+
+ if ((ct = parse_mime(file)));
+ *ctp++ = ct;
+ } else {
+ /*
+ ** message(s) are coming from a folder
+ */
+ if (!msgs.size)
+ app_msgarg(&msgs, "cur");
+ if (!folder)
+ folder = getfolder(1);
+ maildir = m_maildir(folder);
+
+ if (chdir(maildir) == NOTOK)
+ adios(maildir, "unable to change directory to");
+
+ /* read folder and create message structure */
+ if (!(mp = folder_read(folder)))
+ adios(NULL, "unable to read folder %s", folder);
+
+ /* check for empty folder */
+ if (mp->nummsg == 0)
+ adios(NULL, "no messages in %s", folder);
+
+ /* parse all the message ranges/sequences and set SELECTED */
+ for (msgnum = 0; msgnum < msgs.size; msgnum++)
+ if (!m_convert(mp, msgs.msgs[msgnum]))
+ done(1);
+ seq_setprev(mp); /* set the previous-sequence */
+
+ if (!(cts = (CT *) calloc((size_t) (mp->numsel + 1),
+ sizeof(*cts))))
+ adios(NULL, "out of memory");
+ ctp = cts;
+
+ for (msgnum = mp->lowsel; msgnum <= mp->hghsel; msgnum++) {
+ if (is_selected(mp, msgnum)) {
+ char *msgnam;
+
+ msgnam = m_name(msgnum);
+ if ((ct = parse_mime(msgnam)))
+ *ctp++ = ct;
+ }
+ }
+ }
+
+ if (!*cts)
+ done(1);
+
+ userrs = 1;
+ SIGNAL(SIGQUIT, quitser);
+ SIGNAL(SIGPIPE, pipeser);
+
+ /*
+ ** Get the associated umask for the relevant contents.
+ */
+ for (ctp = cts; *ctp; ctp++) {
+ struct stat st;
+
+ ct = *ctp;
+ if (type_ok(ct, 1) && !ct->c_umask) {
+ if (stat(ct->c_file, &st) != NOTOK)
+ ct->c_umask = ~(st.st_mode & 0777);
+ else
+ ct->c_umask = ~m_gmprot();
+ }
+ }
+
+ /*
+ ** Store the message content
+ */
+ store_all_messages(cts);
+
+ /* Now free all the structures for the content */
+ for (ctp = cts; *ctp; ctp++)
+ free_content(*ctp);
+
+ free((char *) cts);
+ cts = NULL;
+
+ /* If reading from a folder, do some updating */
+ if (mp) {
+ context_replace(pfolder, folder); /* update current folder */
+ seq_setcur(mp, mp->hghsel); /* update current message */
+ seq_save(mp); /* synchronize sequences */
+ context_save(); /* save the context file */
+ }
+
+ done(0);
+ return 1;