From a385170fee2e406afe0387f99361eebe7ce2b3c8 Mon Sep 17 00:00:00 2001 From: Eric Leblond Date: Fri, 18 Jan 2013 19:41:19 +0100 Subject: conf: add flag to allow option setup tuning This patch adds a flag to the config_entry structure to be able to tune setup. First usage is to ask config parser not to update a key if it has been already set. --- include/ulogd/conffile.h | 4 ++++ src/conffile.c | 3 ++- 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/include/ulogd/conffile.h b/include/ulogd/conffile.h index 7431243..aa35809 100644 --- a/include/ulogd/conffile.h +++ b/include/ulogd/conffile.h @@ -41,11 +41,15 @@ enum { #define CONFIG_OPT_MANDATORY 0x0001 #define CONFIG_OPT_MULTI 0x0002 +/* valid flag part */ +#define CONFIG_FLAG_VAL_PROTECTED (1<<0) + struct config_entry { char key[CONFIG_KEY_LEN]; /* name of config directive */ u_int8_t type; /* type; see above */ u_int8_t options; /* options; see above */ u_int8_t hit; /* found? */ + u_int8_t flag; /* tune setup of option */ union { char string[CONFIG_VAL_STRING_LEN]; int value; diff --git a/src/conffile.c b/src/conffile.c index b27187e..8dbd726 100644 --- a/src/conffile.c +++ b/src/conffile.c @@ -167,7 +167,8 @@ int config_parse_file(const char *section, struct config_keyset *kset) for (i = 0; i < kset->num_ces; i++) { struct config_entry *ce = &kset->ces[i]; pr_debug("parse main loop, key: %s\n", ce->key); - if (strcmp(ce->key, (char *) &wordbuf)) { + if ((strcmp(ce->key, (char *) &wordbuf)) || + ce->flag & CONFIG_FLAG_VAL_PROTECTED) { continue; } -- cgit v1.2.3