X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=libraries%2Flibldap%2Ffree.c;h=8da55be83bb9b62581c0da8d58d151b2e67a0789;hb=4a2b9b21951cb9966f98cd49064e856f6ff7e6a4;hp=cfccba3e53851b53154fb4e36e1e454aca9d21cb;hpb=4d2761a6a64eaa1c4d5f7949277ecfe25b42ca83;p=openldap diff --git a/libraries/libldap/free.c b/libraries/libldap/free.c index cfccba3e53..8da55be83b 100644 --- a/libraries/libldap/free.c +++ b/libraries/libldap/free.c @@ -1,5 +1,6 @@ +/* $OpenLDAP$ */ /* - * Copyright 1998-1999 The OpenLDAP Foundation, All Rights Reserved. + * Copyright 1998-2002 The OpenLDAP Foundation, All Rights Reserved. * COPYING RESTRICTIONS APPLY, see COPYRIGHT file */ /* Portions @@ -13,9 +14,8 @@ #include "portable.h" #include -#include +#include -#include #include #include @@ -27,9 +27,37 @@ void ldap_memfree( void *p ) { - if(p != NULL) { - free( p ); - } + LDAP_FREE( p ); +} + +void +ldap_memvfree( void **v ) +{ + LDAP_VFREE( v ); +} + +void * +ldap_memalloc( ber_len_t s ) +{ + return LDAP_MALLOC( s ); +} + +void * +ldap_memcalloc( ber_len_t n, ber_len_t s ) +{ + return LDAP_CALLOC( n, s ); +} + +void * +ldap_memrealloc( void* p, ber_len_t s ) +{ + return LDAP_REALLOC( p, s ); +} + +char * +ldap_strdup( LDAP_CONST char *p ) +{ + return LDAP_STRDUP( p ); } void @@ -41,31 +69,31 @@ ldap_getfilter_free( LDAPFiltDesc *lfdp ) for ( flp = lfdp->lfd_filtlist; flp != NULL; flp = nextflp ) { for ( fip = flp->lfl_ilist; fip != NULL; fip = nextfip ) { nextfip = fip->lfi_next; - free( fip->lfi_filter ); - free( fip->lfi_desc ); - free( fip ); + LDAP_FREE( fip->lfi_filter ); + LDAP_FREE( fip->lfi_desc ); + LDAP_FREE( fip ); } nextflp = flp->lfl_next; - free( flp->lfl_pattern ); - free( flp->lfl_delims ); - free( flp->lfl_tag ); - free( flp ); + LDAP_FREE( flp->lfl_pattern ); + LDAP_FREE( flp->lfl_delims ); + LDAP_FREE( flp->lfl_tag ); + LDAP_FREE( flp ); } if ( lfdp->lfd_curvalcopy != NULL ) { - free( lfdp->lfd_curvalcopy ); + LDAP_FREE( lfdp->lfd_curvalcopy ); } if ( lfdp->lfd_curvalwords != NULL ) { - free( lfdp->lfd_curvalwords ); + LDAP_FREE( lfdp->lfd_curvalwords ); } if ( lfdp->lfd_filtprefix != NULL ) { - free( lfdp->lfd_filtprefix ); + LDAP_FREE( lfdp->lfd_filtprefix ); } if ( lfdp->lfd_filtsuffix != NULL ) { - free( lfdp->lfd_filtsuffix ); + LDAP_FREE( lfdp->lfd_filtsuffix ); } - free( lfdp ); + LDAP_FREE( lfdp ); } /* @@ -84,13 +112,21 @@ ldap_mods_free( LDAPMod **mods, int freemods ) for ( i = 0; mods[i] != NULL; i++ ) { if ( mods[i]->mod_op & LDAP_MOD_BVALUES ) { - ber_bvecfree( mods[i]->mod_bvalues ); - } else { - ldap_value_free( mods[i]->mod_values ); + if( mods[i]->mod_bvalues != NULL ) + ber_bvecfree( mods[i]->mod_bvalues ); + + } else if( mods[i]->mod_values != NULL ) { + LDAP_VFREE( mods[i]->mod_values ); + } + + if ( mods[i]->mod_type != NULL ) { + LDAP_FREE( mods[i]->mod_type ); } - free( (char *) mods[i] ); + + LDAP_FREE( (char *) mods[i] ); } - if ( freemods ) - free( (char *) mods ); + if ( freemods ) { + LDAP_FREE( (char *) mods ); + } }