From e2b50d04ad5eb5fa7c10b59cf5ba0cfe374ab240 Mon Sep 17 00:00:00 2001 From: Andrew Tridgell Date: Sat, 14 Mar 1998 11:24:01 +0000 Subject: if a local parameter is changed at the global level then propogate the change to all shares that are currently set to the default value. (This used to be commit b0e1183b2cbeb7a3150b7250cd19d14c9e5508b6) --- source3/web/swat.c | 24 +++++++++++++++++++++++- 1 file changed, 23 insertions(+), 1 deletion(-) (limited to 'source3/web/swat.c') diff --git a/source3/web/swat.c b/source3/web/swat.c index 323dfc5adf..650740428f 100644 --- a/source3/web/swat.c +++ b/source3/web/swat.c @@ -198,6 +198,27 @@ static int save_reload(void) +/* commit one parameter */ +static void commit_parameter(int snum, struct parm_struct *parm, char *v) +{ + int i; + char *s; + + if (snum < 0 && parm->class == P_LOCAL) { + /* this handles the case where we are changing a local + variable globally. We need to change the parameter in + all shares where it is currently set to the default */ + for (i=0;ilabel, v); + } + } + } + + lp_do_parameter(snum, parm->label, v); +} + /* commit a set of parameters for a service */ static void commit_parameters(int snum) { @@ -209,7 +230,8 @@ static void commit_parameters(int snum) while ((parm = lp_next_parameter(snum, &i, 1))) { sprintf(label, "parm_%s", parm->label); if ((v = cgi_variable(label))) { - lp_do_parameter(snum, parm->label, v); + if (parm->flags & FLAG_HIDE) continue; + commit_parameter(snum, parm, v); } } } -- cgit