From 2330f1466dd071ba728c9384a7cd9dab20bc3aa5 Mon Sep 17 00:00:00 2001
From: Hallvard Furuseth <hallvard@openldap.org>
Date: Fri, 27 Aug 1999 03:21:43 +0000
Subject: [PATCH] Plug memory leaks (free output from ldif_parse_line)

---
 servers/slurpd/re.c | 21 ++++++++++++++++++++-
 1 file changed, 20 insertions(+), 1 deletion(-)

diff --git a/servers/slurpd/re.c b/servers/slurpd/re.c
index fa171ca159..4d6ee77a65 100644
--- a/servers/slurpd/re.c
+++ b/servers/slurpd/re.c
@@ -192,9 +192,15 @@ Re_parse(
 		Debug( LDAP_DEBUG_ANY,
 			"Error: Re_parse: bad type <%s>\n",
 			type, 0, 0 );
+		free( type );
+		if ( value != NULL )
+			free( value );
 		return -1;
 	    }
 	}
+	free( type );
+	if ( value != NULL )
+		free( value );
     }
 
     if ( state != GOT_ALL ) {
@@ -205,12 +211,14 @@ Re_parse(
     }
 
     for (;;) {
+	char *const dash = "-";
+
 	if (( buf = ldif_getline( &rp )) == NULL ) {
 	    break;
 	}
 	buflen = strlen( buf );
 	if (( buflen == 1 ) && ( buf[ 0 ] == '-' )) {
-	    type = "-";
+	    type  = dash;
 	    value = NULL;
 	} else {
 	    if ( ldif_parse_line( buf, &type, &value, &len ) < 0 ) {
@@ -235,6 +243,11 @@ Re_parse(
 	re->re_mods[ nml + 1 ].mi_type = NULL;
 	re->re_mods[ nml + 1 ].mi_val = NULL;
 	nml++;
+
+	if ( type != dash )
+		free( type );
+	if ( value != NULL )
+		free( value );
     }
     return 0;
 }
@@ -314,8 +327,11 @@ get_repl_hosts(
 		break;
 	    }
 	}
+	free( type );
 	if ( !repl_ok ) {
 	    warn_unknown_replica( value, port );
+	    if ( value != NULL )
+		free( value );
 	    continue;
 	}
 
@@ -328,6 +344,9 @@ get_repl_hosts(
 	rh[ nreplicas ].rh_hostname = strdup( value );
 	rh[ nreplicas ].rh_port = port;
 	nreplicas++;
+
+	if ( value != NULL )
+		free( value );
     }
 
     if ( nreplicas == 0 ) {
-- 
GitLab