X-Git-Url: http://mj.ucw.cz/gitweb/?a=blobdiff_plain;f=lib%2Fconf.h;h=b58224d34bb97ba4afe5d8afa5af6763014d3191;hb=6d3f0167feb4d66ace66963200726439cb4a3914;hp=b01cba3bd9207b5d9bd498243b45c3b71c9e24c9;hpb=08d04bc5ad1096069facbea143c8172243ba2eba;p=libucw.git diff --git a/lib/conf.h b/lib/conf.h index b01cba3b..b58224d3 100644 --- a/lib/conf.h +++ b/lib/conf.h @@ -4,6 +4,9 @@ * (c) 2001 Robert Spalek */ +#ifndef _LIB_CONF_H +#define _LIB_CONF_H + #include /* @@ -19,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; @@ -47,6 +53,13 @@ void cf_read(byte *filename); /* * When using cf_getopt, you must prefix your own short/long options by the * CF_(SHORT|LONG)_OPTS. + * + * cfdeffile contains filename of config file automatically loaded before a + * first --set option is executed. If none --set option occures, it will be + * loaded after getopt returns -1 (at the end of configuration options). It + * will be ignored, if another config file is set by --config option at first. + * Its initial value is DEFAULT_CONFIG from config.h, but you can override it + * manually. */ #define CF_SHORT_OPTS "S:C:" @@ -54,8 +67,14 @@ void cf_read(byte *filename); {"set", 1, 0, 'S'},\ {"config", 1, 0, 'C'}, #define CF_NO_LONG_OPTS (const struct option []){ CF_LONG_OPTS { NULL, 0, 0, 0 } } +#define CF_USAGE \ +"-S, --set sec.item=val\tManual setting of a configuration item\n\ +-C, --config filename\tOverwrite default config filename\n" + +extern byte *cfdeffile; int cf_getopt(int argc,char * const argv[], const char *shortopts,const struct option *longopts, int *longindex); +#endif