]> diplodocus.org Git - nmh/blobdiff - sbr/context_del.c
Added m_str() and m_strn() functions to convert int to string.
[nmh] / sbr / context_del.c
index e55d683be335d8be9b2db307c7167132fa77fc80..efe5e41051ebea4573b2fe0da0a2de7633594d10 100644 (file)
@@ -1,8 +1,4 @@
-
-/*
- * context_del.c -- delete an entry from the context/profile list
- *
- * $Id$
+/* context_del.c -- delete an entry from 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
@@ -10,6 +6,7 @@
  */
 
 #include <h/mh.h>
  */
 
 #include <h/mh.h>
+#include <h/utils.h>
 
 /*
  * Delete a key/value pair from the context/profile list.
 
 /*
  * Delete a key/value pair from the context/profile list.
 int
 context_del (char *key)
 {
 int
 context_del (char *key)
 {
-    register struct node *np, *pp;
-
-    /* sanity check - check that context has been read */
-    if (defpath == NULL)
-       adios (NULL, "oops, context hasn't been read yet");
+    struct node *np, *pp;
 
     for (np = m_defs, pp = NULL; np; pp = np, np = np->n_next) {
 
     for (np = m_defs, pp = NULL; np; pp = np, np = np->n_next) {
-       if (!strcasecmp (np->n_name, key)) {
+       if (!strcasecmp (FENDNULL(np->n_name), FENDNULL(key))) {
            if (!np->n_context)
            if (!np->n_context)
-               admonish (NULL, "bug: context_del(key=\"%s\")", np->n_name);
+               inform("bug: context_del(key=\"%s\"), continuing...", np->n_name);
            if (pp)
                pp->n_next = np->n_next;
            else
                m_defs = np->n_next;
            free (np->n_name);
            if (pp)
                pp->n_next = np->n_next;
            else
                m_defs = np->n_next;
            free (np->n_name);
-           if (np->n_field)
-               free (np->n_field);
-           free ((char *) np);
+            mh_xfree(np->n_field);
+           free(np);
            ctxflags |= CTXMOD;
            return 0;
        }
            ctxflags |= CTXMOD;
            return 0;
        }