X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=src%2Fpazpar2_config.c;h=959bfcb28f6e8512be9decda26f39ab81c98495f;hb=3123b48786d777f60276d7011b974a0977698b32;hp=dfb4509d63f903f26360e9b367010196155a8a09;hpb=f7247294488509fca6dc8e0d32f63cd8ae51b555;p=pazpar2-moved-to-github.git diff --git a/src/pazpar2_config.c b/src/pazpar2_config.c index dfb4509..959bfcb 100644 --- a/src/pazpar2_config.c +++ b/src/pazpar2_config.c @@ -114,7 +114,7 @@ static void conf_sortkey_assign(NMEM nmem, } -static struct conf_service *service_init(struct conf_config *config, +static struct conf_service *service_init(struct conf_server *server, int num_metadata, int num_sortkeys, const char *service_id) { @@ -122,12 +122,13 @@ static struct conf_service *service_init(struct conf_config *config, NMEM nmem = nmem_create(); service = nmem_malloc(nmem, sizeof(struct conf_service)); + service->ref_count = 1; service->nmem = nmem; service->next = 0; service->settings = 0; service->databases = 0; service->targetprofiles = 0; - service->config = config; + service->server = server; service->session_timeout = 60; /* default session timeout */ service->z3950_session_timeout = 180; service->z3950_connect_timeout = 15; @@ -244,17 +245,27 @@ static void conf_dir_path(struct conf_config *config, WRBUF w, const char *src) wrbuf_puts(w, src); } -static void service_destroy(struct conf_service *service) +void service_destroy(struct conf_service *service) { if (service) { - pp2_charset_destroy(service->relevance_pct); - pp2_charset_destroy(service->sort_pct); - pp2_charset_destroy(service->mergekey_pct); - nmem_destroy(service->nmem); + assert(service->ref_count > 0); + service->ref_count--; + if (service->ref_count == 0) + { + pp2_charset_destroy(service->relevance_pct); + pp2_charset_destroy(service->sort_pct); + pp2_charset_destroy(service->mergekey_pct); + nmem_destroy(service->nmem); + } } } +void service_incref(struct conf_service *service) +{ + service->ref_count++; +} + static int parse_metadata(struct conf_service *service, xmlNode *n, int *md_node, int *sk_node) { @@ -426,9 +437,9 @@ static int parse_metadata(struct conf_service *service, xmlNode *n, return 0; } -static struct conf_service *service_create(struct conf_config *config, - xmlNode *node, - const char *service_id) +static struct conf_service *service_create_static(struct conf_server *server, + xmlNode *node, + const char *service_id) { xmlNode *n; int md_node = 0; @@ -451,7 +462,7 @@ static struct conf_service *service_create(struct conf_config *config, xmlFree(sortkey); } - service = service_init(config, num_metadata, num_sortkeys, service_id); + service = service_init(server, num_metadata, num_sortkeys, service_id); for (n = node->children; n; n = n->next) { @@ -576,7 +587,7 @@ static struct conf_service *service_create(struct conf_config *config, if (src) { WRBUF w = wrbuf_alloc(); - conf_dir_path(config, w, (const char *) src); + conf_dir_path(server->config, w, (const char *) src); settings_read_file(service, wrbuf_cstr(w), pass); wrbuf_destroy(w); xmlFree(src); @@ -614,65 +625,75 @@ static char *parse_settings(struct conf_config *config, return r; } -static void inherit_server_settings(struct conf_server *server) +static void inherit_server_settings(struct conf_service *s) { - struct conf_service *s; - for (s = server->service; s; s = s->next) + struct conf_server *server = s->server; + if (!s->dictionary) /* service has no config settings ? */ { - if (!s->dictionary) /* service has no config settings ? */ + if (server->server_settings) { - if (server->server_settings) - { - /* inherit settings from server */ - init_settings(s); - settings_read_file(s, server->server_settings, 1); - settings_read_file(s, server->server_settings, 2); - } - else - { - yaz_log(YLOG_WARN, "service '%s' has no settings", - s->id ? s->id : "unnamed"); - init_settings(s); - } + /* inherit settings from server */ + init_settings(s); + settings_read_file(s, server->server_settings, 1); + settings_read_file(s, server->server_settings, 2); } - - /* use relevance/sort/mergekey from server if not defined - for this service.. */ - if (!s->relevance_pct) + else { - if (server->relevance_pct) - { - s->relevance_pct = server->relevance_pct; - pp2_charset_incref(s->relevance_pct); - } - else - s->relevance_pct = pp2_charset_create(0); + yaz_log(YLOG_WARN, "service '%s' has no settings", + s->id ? s->id : "unnamed"); + init_settings(s); } - - if (!s->sort_pct) + } + + /* use relevance/sort/mergekey from server if not defined + for this service.. */ + if (!s->relevance_pct) + { + if (server->relevance_pct) { - if (server->sort_pct) - { - s->sort_pct = server->sort_pct; - pp2_charset_incref(s->sort_pct); - } - else - s->sort_pct = pp2_charset_create(0); + s->relevance_pct = server->relevance_pct; + pp2_charset_incref(s->relevance_pct); } - - if (!s->mergekey_pct) + else + s->relevance_pct = pp2_charset_create(0); + } + + if (!s->sort_pct) + { + if (server->sort_pct) { - if (server->mergekey_pct) - { - s->mergekey_pct = server->mergekey_pct; - pp2_charset_incref(s->mergekey_pct); - } - else - s->mergekey_pct = pp2_charset_create(0); + s->sort_pct = server->sort_pct; + pp2_charset_incref(s->sort_pct); } + else + s->sort_pct = pp2_charset_create(0); + } + + if (!s->mergekey_pct) + { + if (server->mergekey_pct) + { + s->mergekey_pct = server->mergekey_pct; + pp2_charset_incref(s->mergekey_pct); + } + else + s->mergekey_pct = pp2_charset_create(0); } } +struct conf_service *service_create(struct conf_server *server, + xmlNode *node) +{ + struct conf_service *service = service_create_static(server, + node, 0); + if (service) + { + inherit_server_settings(service); + resolve_databases(service); + } + return service; +} + static struct conf_server *server_create(struct conf_config *config, NMEM nmem, xmlNode *node) { @@ -686,6 +707,7 @@ static struct conf_server *server_create(struct conf_config *config, server->myurl = 0; server->proxy_addr = 0; server->service = 0; + server->config = config; server->next = 0; server->relevance_pct = 0; server->sort_pct = 0; @@ -777,8 +799,8 @@ static struct conf_server *server_create(struct conf_config *config, } else { - struct conf_service *s = service_create(config, n, - service_id); + struct conf_service *s = service_create_static(server, n, + service_id); xmlFree(service_id); if (!s) return 0; @@ -791,13 +813,19 @@ static struct conf_server *server_create(struct conf_config *config, return 0; } } - inherit_server_settings(server); + if (server->service) + { + struct conf_service *s; + for (s = server->service; s; s = s->next) + inherit_server_settings(s); + } return server; } -xsltStylesheet *conf_load_stylesheet(struct conf_config *config, +xsltStylesheet *conf_load_stylesheet(struct conf_service *service, const char *fname) { + struct conf_config *config = service->server->config; WRBUF w = wrbuf_alloc(); xsltStylesheet *s;