diff options
author | Jelmer Vernooij <jelmer@samba.org> | 2002-10-25 02:37:11 +0000 |
---|---|---|
committer | Jelmer Vernooij <jelmer@samba.org> | 2002-10-25 02:37:11 +0000 |
commit | 06362586cb754bd6bc89b50b966737958286ca2e (patch) | |
tree | 0c9eae53ff4d0d8759814409ba0297cdaf9faa9b /source/passdb/pdb_nisplus.c | |
parent | 9efa98b4a65a38df922ce3b83f5fde631cb70844 (diff) | |
download | samba-06362586cb754bd6bc89b50b966737958286ca2e.tar.gz samba-06362586cb754bd6bc89b50b966737958286ca2e.tar.xz samba-06362586cb754bd6bc89b50b966737958286ca2e.zip |
Fix memory leak (patch by Steve Langasek)
Diffstat (limited to 'source/passdb/pdb_nisplus.c')
-rw-r--r-- | source/passdb/pdb_nisplus.c | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/source/passdb/pdb_nisplus.c b/source/passdb/pdb_nisplus.c index 80e55454efe..0a42c36ea02 100644 --- a/source/passdb/pdb_nisplus.c +++ b/source/passdb/pdb_nisplus.c @@ -1508,6 +1508,19 @@ static nis_result *nisp_get_nis_list (const char *nisname, unsigned int flags) return result; } +static void free_private_data(void **vp) +{ + struct nisplus_private_info **private = (struct nisplus_private_info **)vp; + + if ((*private)->result) { + nis_freeresult ((*private)->result); + } + + free(*private); + + /* No need to free any further, as it is talloc()ed */ +} + NTSTATUS pdb_init_nisplussam (PDB_CONTEXT * pdb_context, PDB_METHODS ** pdb_method, const char *location) { @@ -1536,6 +1549,7 @@ NTSTATUS pdb_init_nisplussam (PDB_CONTEXT * pdb_context, (*pdb_method)->add_sam_account = nisplussam_add_sam_account; (*pdb_method)->update_sam_account = nisplussam_update_sam_account; (*pdb_method)->delete_sam_account = nisplussam_delete_sam_account; + (*pdb_method)->free_private_data = free_private_data; (*pdb_method)->private_data = private; return NT_STATUS_OK; |