]> diplodocus.org Git - nmh/blobdiff - sbr/context_replace.c
Both f_typestr(): Rebuild switch from FT_* to string from scratch.
[nmh] / sbr / context_replace.c
index 0e9e11467d10d007a3ab13a078b5939f3e0d7370..1027dcf6f9d925e1b4990098649620b13e23e3f8 100644 (file)
@@ -1,6 +1,4 @@
-
-/*
- * context_replace.c -- add/replace an entry in the context/profile list
+/* context_replace.c -- add/replace an entry in the context/profile list
  *
  * This code is Copyright (c) 2002, by the authors of nmh.  See the
  * COPYRIGHT file in the root directory of the nmh distribution for
  *
  * This code is Copyright (c) 2002, by the authors of nmh.  See the
  * COPYRIGHT file in the root directory of the nmh distribution for
@@ -14,7 +12,7 @@
 void
 context_replace (char *key, char *value)
 {
 void
 context_replace (char *key, char *value)
 {
-    register struct node *np;
+    struct node *np;
 
     /*
      * If list is empty, allocate head of profile/context list.
 
     /*
      * If list is empty, allocate head of profile/context list.
@@ -35,13 +33,12 @@ context_replace (char *key, char *value)
      * this key, and replace its value if found.
      */
     for (np = m_defs;; np = np->n_next) {
      * this key, and replace its value if found.
      */
     for (np = m_defs;; np = np->n_next) {
-       if (!strcasecmp (np->n_name ? np->n_name : "", key ? key : "")) {
+       if (!strcasecmp (FENDNULL(np->n_name), FENDNULL(key))) {
            if (strcmp (value, np->n_field)) {
                if (!np->n_context)
            if (strcmp (value, np->n_field)) {
                if (!np->n_context)
-                   admonish (NULL, "bug: context_replace(key=\"%s\",value=\"%s\")", key, value);
-               if (np->n_field)
-                   free (np->n_field);
-               np->n_field = getcpy (value);
+                   inform("bug: context_replace(key=\"%s\",value=\"%s\"), continuing...", key, value);
+                mh_xfree(np->n_field);
+               np->n_field = mh_xstrdup(value);
                ctxflags |= CTXMOD;
            }
            return;
                ctxflags |= CTXMOD;
            }
            return;