X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;ds=sidebyside;f=src%2Fsettings.c;h=5a0dd2a1a0cb1e7b10bde95bc28940e5d054e338;hb=d5ffc2f6e667c1d849bf7579add8435664e678c5;hp=f602843201eacab241072a560713087d95aa06a5;hpb=541b55d47e25948f632382f7b96f1fffad00ca7f;p=pazpar2-moved-to-github.git diff --git a/src/settings.c b/src/settings.c index f602843..5a0dd2a 100644 --- a/src/settings.c +++ b/src/settings.c @@ -1,4 +1,4 @@ -/* $Id: settings.c,v 1.22 2007-05-18 19:52:52 quinn 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. @@ -59,6 +59,8 @@ static char *hard_settings[] = { "pz:name", "pz:queryencoding", "pz:ip", + "pz:zproxy", + "pz:apdulog", 0 }; @@ -351,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 @@ -364,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. @@ -384,6 +410,7 @@ void init_settings(void) memset(new, 0, sizeof(*new)); initialize_hard_settings(new); dictionary = new; + initialize_soft_settings(); } /*