From 9d90969a37244c5e2ddb90daf5ac439cb33cdbf0 Mon Sep 17 00:00:00 2001 From: Garming Sam Date: Tue, 25 Feb 2014 16:58:21 +1300 Subject: [PATCH] param: copy parametric option helper to lib/param Signed-off-by: Garming Sam Reviewed-by: Andrew Bartlett Reviewed-by: Jeremy Allison --- lib/param/loadparm.c | 49 ++++++++++++++++++++++++++++++++++++++++ source3/param/loadparm.c | 10 ++++---- 2 files changed, 55 insertions(+), 4 deletions(-) diff --git a/lib/param/loadparm.c b/lib/param/loadparm.c index e8b0874d4fb..7728e6dd0c7 100644 --- a/lib/param/loadparm.c +++ b/lib/param/loadparm.c @@ -237,6 +237,55 @@ static bool do_section(const char *pszSectionName, void *); /* This is a helper function for parametrical options support. */ /* It returns a pointer to parametrical option value if it exists or NULL otherwise */ /* Actual parametrical functions are quite simple */ +struct parmlist_entry *get_parametric_helper(struct loadparm_service *service, + const char *type, const char *option, + struct parmlist_entry *global_opts) +{ + char* param_key; + struct parmlist_entry *data = NULL; + TALLOC_CTX *mem_ctx = talloc_stackframe(); + + param_key = talloc_asprintf(mem_ctx, "%s:%s", type, option); + if (param_key == NULL) { + DEBUG(0,("asprintf failed!\n")); + TALLOC_FREE(mem_ctx); + return NULL; + } + + /* + * Try to fetch the option from the data. + */ + if (service != NULL) { + data = service->param_opt; + while (data != NULL) { + if (strwicmp(data->key, param_key) == 0) { + TALLOC_FREE(mem_ctx); + return data; + } + data = data->next; + } + } + + /* + * Fall back to fetching from the globals. + */ + data = global_opts; + while (data != NULL) { + if (strwicmp(data->key, param_key) == 0) { + TALLOC_FREE(mem_ctx); + return data; + } + data = data->next; + } + + + TALLOC_FREE(mem_ctx); + + return NULL; + + +} + const char *lpcfg_get_parametric(struct loadparm_context *lp_ctx, struct loadparm_service *service, const char *type, const char *option) diff --git a/source3/param/loadparm.c b/source3/param/loadparm.c index 459528f2370..2a3a8cba069 100644 --- a/source3/param/loadparm.c +++ b/source3/param/loadparm.c @@ -1228,10 +1228,10 @@ static struct parmlist_entry *get_parametrics(int snum, const char *type, if (snum >= iNumServices) return NULL; if (snum < 0) { - return get_parametrics_by_service(NULL, type, option, Globals.param_opt); + return get_parametric_helper(NULL, type, option, Globals.param_opt); } else { - return get_parametrics_by_service(ServicePtrs[snum], - type, option, Globals.param_opt); + return get_parametric_helper(ServicePtrs[snum], + type, option, Globals.param_opt); } } @@ -1295,7 +1295,9 @@ const char *lp_parm_const_string_service(struct loadparm_service *service, const char *type, const char *option, const char *def) { - struct parmlist_entry *data = get_parametrics_by_service(service, type, option, Globals.param_opt); + struct parmlist_entry *data; + + data = get_parametric_helper(service, type, option, Globals.param_opt); if (data == NULL||data->value==NULL) return def;