From 3a46af398cf69b0e84147e2421e555f5c5c83856 Mon Sep 17 00:00:00 2001 From: Pierangelo Masarati Date: Mon, 12 Apr 2010 03:42:29 +0000 Subject: [PATCH] free LDIF handler in case of failure --- clients/tools/ldapmodify.c | 29 ++++++++++++++++++++++------- 1 file changed, 22 insertions(+), 7 deletions(-) diff --git a/clients/tools/ldapmodify.c b/clients/tools/ldapmodify.c index eadc936ebb..4e2a10f923 100644 --- a/clients/tools/ldapmodify.c +++ b/clients/tools/ldapmodify.c @@ -239,7 +239,8 @@ main( int argc, char **argv ) if ( rejfile != NULL ) { if (( rejfp = fopen( rejfile, "w" )) == NULL ) { perror( rejfile ); - return( EXIT_FAILURE ); + retval = EXIT_FAILURE; + goto fail; } } else { rejfp = NULL; @@ -248,7 +249,8 @@ main( int argc, char **argv ) if ( infile != NULL ) { if (( ldiffp = ldif_open( infile, "r" )) == NULL ) { perror( infile ); - return( EXIT_FAILURE ); + retval = EXIT_FAILURE; + goto fail; } } else { ldifdummy.fp = stdin; @@ -263,7 +265,10 @@ main( int argc, char **argv ) if ( pw_file || want_bindpw ) { if ( pw_file ) { rc = lutil_get_filed_password( pw_file, &passwd ); - if( rc ) return EXIT_FAILURE; + if ( rc ) { + retval = EXIT_FAILURE; + goto fail; + } } else { passwd.bv_val = getpassphrase( _("Enter LDAP Password: ") ); passwd.bv_len = passwd.bv_val ? strlen( passwd.bv_val ) : 0; @@ -278,7 +283,10 @@ main( int argc, char **argv ) rc = ldap_txn_start_s( ld, NULL, NULL, &txn_id ); if( rc != LDAP_SUCCESS ) { tool_perror( "ldap_txn_start_s", rc, NULL, NULL, NULL, NULL ); - if( txn > 1 ) return EXIT_FAILURE; + if( txn > 1 ) { + retval = EXIT_FAILURE; + goto fail; + } txn = 0; } } @@ -312,7 +320,8 @@ main( int argc, char **argv ) len = strlen( rbuf ); if (( rejbuf = (char *)ber_memalloc( len+1 )) == NULL ) { perror( "malloc" ); - exit( EXIT_FAILURE ); + retval = EXIT_FAILURE; + goto fail; } memcpy( rejbuf, rbuf, len+1 ); } @@ -367,15 +376,21 @@ main( int argc, char **argv ) } #endif - if ( !dont ) { + if ( !dont && ld != NULL ) { tool_unbind( ld ); } + tool_destroy(); + +fail:; if ( rejfp != NULL ) { fclose( rejfp ); } - tool_destroy(); + if ( ldiffp != NULL && ldiffp != &ldifdummy ) { + ldif_close( ldiffp ); + } + return( retval ); }