X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=src%2Fsettings.c;h=5a0dd2a1a0cb1e7b10bde95bc28940e5d054e338;hb=0ff1a97b2a69905755b9adb24a474d30f1c52150;hp=8cc5e6c02433d48076f0cb18d66c7ef173f7e99b;hpb=dc9f59ce5f4bedc6cd1cc68e0309b74d241f434d;p=pazpar2-moved-to-github.git diff --git a/src/settings.c b/src/settings.c index 8cc5e6c..5a0dd2a 100644 --- a/src/settings.c +++ b/src/settings.c @@ -1,4 +1,4 @@ -/* $Id: settings.c,v 1.23 2007-06-06 11:49:48 marc Exp $ +/* $Id: settings.c,v 1.26 2007-07-30 23:16:33 quinn Exp $ Copyright (c) 2006-2007, Index Data. This file is part of Pazpar2. @@ -60,6 +60,7 @@ static char *hard_settings[] = { "pz:queryencoding", "pz:ip", "pz:zproxy", + "pz:apdulog", 0 }; @@ -352,7 +353,7 @@ static void update_database(void *context, struct database *db) // This is used in pass 2 to assign name/value pairs to databases static void update_databases(struct setting *set) { - grep_databases(set, 0, update_database); + predef_grep_databases(set, 0, update_database); } // This simply copies the 'hard' (application-specific) settings @@ -365,6 +366,30 @@ static void initialize_hard_settings(struct setting_dictionary *dict) dict->num = dict->size; } +// Read any settings names introduced in service definition (config) and add to dictionary +// This is done now to avoid errors if user settings are declared in session overrides +static void initialize_soft_settings() +{ + struct conf_service *service = config->servers->service; + int i; + + for (i = 0; i < service->num_metadata; i++) + { + struct setting set; + struct conf_metadata *md = &service->metadata[i]; + + if (md->setting == Metadata_setting_no) + continue; + + set.precedence = 0; + set.target = ""; + set.name = md->name; + set.value = ""; + set.next = 0; + prepare_dictionary(&set); + } +} + // If we ever decide we need to be able to specify multiple settings directories, // the two calls to read_settings must be split -- so the dictionary is prepared // for the contents of every directory before the databases are updated. @@ -385,6 +410,7 @@ void init_settings(void) memset(new, 0, sizeof(*new)); initialize_hard_settings(new); dictionary = new; + initialize_soft_settings(); } /*