- free (cp);
-
- if (!makedir (nd))
- adios (NULL, "unable to create", nd);
- }
-
- else if ((st.st_mode & S_IFDIR) == 0)
- adios ((char *)0, "`%s' is not a directory", nd);
-
- /*
- * Open and read user's context file. The name of the context file comes from the
- * profile unless overridden by the MHCONTEXT environment variable.
- */
-
- if ((cp = getenv ("MHCONTEXT")) == (char *)0 || *cp == '\0')
- cp = context;
+ if (*cp != '/')
+ (void)snprintf(nd = buf, sizeof(buf), "%s/%s", mypath, cp);
+ else
+ nd = cp;
+
+ if (stat(nd, &st) == -1) {
+ if (errno != ENOENT)
+ adios(nd, "error opening");
+ cp = concat("Your MH-directory \"", nd, "\" doesn't exist; Create it? ", NULL);
+ if (!getanswer(cp))
+ adios(NULL, "unable to access MH-directory \"%s\"", nd);
+ free(cp);
+ if (!makedir(nd))
+ adios(NULL, "unable to create %s", nd);
+ } else if ((st.st_mode & S_IFDIR) == 0)
+ adios((char *)0, "`%s' is not a directory", nd);
+
+ /*
+ ** Open and read user's context file. The name of the context
+ ** file comes from the profile unless overridden by the MHCONTEXT
+ ** environment variable.
+ */
+
+ if ((cp = getenv("MHCONTEXT")) == (char *)0 || *cp == '\0')
+ cp = context;
+
+ /*
+ ** context is NULL if context_foil() was called to disable use
+ ** of context We also support users setting explicitly setting
+ ** MHCONTEXT to /dev/null. (if this wasn't specialcased then the
+ ** locking would be liable to fail)
+ */
+ if (!cp || (strcmp(cp,"/dev/null") == 0)) {
+ ctxpath = NULL;
+ return;
+ }
+
+ ctxpath = getcpy(m_maildir(cp));
+
+ if ((ib = lkfopen(ctxpath, "r"))) {
+ readconfig((struct node **) 0, ib, cp, 1);
+ lkfclose(ib, ctxpath);
+ }