]> mj.ucw.cz Git - libucw.git/commitdiff
Added CT_INCOMPLETE_SECTION which is equivalent to CT_SECTION except
authorMartin Mares <mj@ucw.cz>
Fri, 29 Mar 2002 11:06:19 +0000 (11:06 +0000)
committerMartin Mares <mj@ucw.cz>
Fri, 29 Mar 2002 11:06:19 +0000 (11:06 +0000)
that unknown variables in such sections are not reported as errors.

lib/conf.c
lib/conf.h

index 98c34b56b16d62eadaf222c04c618bf69c6a2a9d..c37bb98b81b7982d4409c77f4d1f962e4875f8ae 100644 (file)
@@ -49,8 +49,8 @@ cfg_stralloc(byte *s)
 
 void cf_register(struct cfitem *items)
 {
-       if(items[0].type!=CT_SECTION)
-               die("Invalid configuration section, first item must be of type CT_SECTION");
+       if(items[0].type!=CT_SECTION && items[0].type!=CT_INCOMPLETE_SECTION)
+               die("cf_register: Invalid section type");
        items[0].var=cfsection;
        cfsection=items;
 }
@@ -67,15 +67,18 @@ int cf_item_count(void)
 
 struct cfitem *cf_get_item(byte *sect, byte *name)
 {
-       struct cfitem *item;
+       struct cfitem *item, *section;
 
        item=cfsection;
        while(item && strcasecmp(item->name,sect))
                item=item->var;
        if(!item)       /* unknown section */
                return NULL;
+       section = item;
 
        for(item++; item->type && strcasecmp(item->name,name); item++);
+       if (!item->type && section->type == CT_INCOMPLETE_SECTION)
+               return NULL;
 
        return item;    /* item->type == 0 if not found */
 }
index b225053cf21e513cd82bd2e4ecb1d66d2b30fb04..b58224d34bb97ba4afe5d8afa5af6763014d3191 100644 (file)
@@ -22,11 +22,14 @@ byte *cfg_stralloc(byte *s);
  * the name of the section.  The configuration sections are registered by
  * calling cf_register().
  *
+ * CT_INCOMPLETE_SECTION is identical to CT_SECTION, but when an unknown variable
+ * is spotted, we ignore it instead of bailing out with an error message.
+ *
  * item->var is a pointer to the destination variable or to the special parsing
  * function.
  */
 
-enum cftype { CT_STOP, CT_SECTION, CT_INT, CT_STRING, CT_FUNCTION };
+enum cftype { CT_STOP, CT_SECTION, CT_INCOMPLETE_SECTION, CT_INT, CT_STRING, CT_FUNCTION };
 
 struct cfitem {
        byte *name;