1
0
mirror of https://github.com/samba-team/samba.git synced 2025-01-11 05:18:09 +03:00
samba-mirror/source3/param/loadparm_ctx.c
Andreas Schneider d7a6488da8 lib:param: Set a memory context for the globals if not initialized yet
Typically once the smb.conf starts to be loaded,
loadparm_s3_init_globals() will be called and a memory context for
strings on the static Globals will be created.  But we might call
lpcfg_set_cmdline() before we load the smb.conf file, so we (via a
helper pointer) call loadparm_s3_init_globals() to get that
initialisation done earlier, ensuring that all allocations on Globals is
done on a memory context that we can later TALLOC_FREE() before exit().

Signed-off-by: Andreas Schneider <asn@samba.org>
Reviewed-by: Andrew Bartlett <abartlet@samba.org>
2023-10-25 22:23:37 +00:00

83 lines
2.1 KiB
C

/*
Unix SMB/CIFS implementation.
Parameter loading functions
Copyright (C) Andrew Bartlett 2011
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 3 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#include "includes.h"
#include "lib/param/s3_param.h"
static struct loadparm_service *lp_service_for_s4_ctx(const char *servicename)
{
TALLOC_CTX *mem_ctx;
struct loadparm_service *service;
mem_ctx = talloc_stackframe();
service = lp_service(servicename);
talloc_free(mem_ctx);
return service;
}
static struct loadparm_service *lp_servicebynum_for_s4_ctx(int servicenum)
{
TALLOC_CTX *mem_ctx;
struct loadparm_service *service;
mem_ctx = talloc_stackframe();
service = lp_servicebynum(servicenum);
talloc_free(mem_ctx);
return service;
}
static bool lp_load_for_s4_ctx(const char *filename)
{
TALLOC_CTX *mem_ctx;
bool status;
mem_ctx = talloc_stackframe();
status = lp_load_no_reinit(filename);
talloc_free(mem_ctx);
return status;
}
static struct loadparm_s3_helpers s3_fns =
{
.get_parm_ptr = lp_parm_ptr,
.get_service = lp_service_for_s4_ctx,
.get_servicebynum = lp_servicebynum_for_s4_ctx,
.getservicebyname = getservicebyname,
.get_numservices = lp_numservices,
.load = lp_load_for_s4_ctx,
.store_cmdline = store_lp_set_cmdline,
.dump = lp_dump,
.lp_include = lp_include,
.init_ldap_debugging = init_ldap_debugging,
.do_section = lp_do_section,
.init_globals = loadparm_s3_init_globals,
};
const struct loadparm_s3_helpers *loadparm_s3_helpers(void)
{
struct loadparm_s3_helpers *helpers;
helpers = &s3_fns;
helpers->globals = get_globals();
helpers->flags = get_flags();
return helpers;
}