aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorrussell <russell@f38db490-d61c-443f-a65b-d21fe96a405b>2005-09-24 21:19:42 +0000
committerrussell <russell@f38db490-d61c-443f-a65b-d21fe96a405b>2005-09-24 21:19:42 +0000
commit72e95dbce1c067a6adad5dcf527f56b252131966 (patch)
treeabc7346df5850b434f6985f2630ee46752c265a5
parent62b973408d966bc154a77a8f4ddb2acf235e515c (diff)
Fix CLI memory leak (issue #5035)
git-svn-id: http://svn.digium.com/svn/asterisk/branches/v1-0@6636 f38db490-d61c-443f-a65b-d21fe96a405b
-rwxr-xr-xcli.c13
1 files changed, 7 insertions, 6 deletions
diff --git a/cli.c b/cli.c
index d6100b84a..11edf1faf 100755
--- a/cli.c
+++ b/cli.c
@@ -1004,14 +1004,15 @@ int ast_cli_generatornummatches(char *text, char *word)
int matches = 0, i = 0;
char *buf = NULL, *oldbuf = NULL;
- while ( (buf = ast_cli_generator(text, word, i)) ) {
- if (++i > 1 && strcmp(buf,oldbuf) == 0) {
- continue;
- }
+ while ( (buf = ast_cli_generator(text, word, i++)) ) {
+ if (!oldbuf || strcmp(buf,oldbuf))
+ matches++;
+ if (oldbuf)
+ free(oldbuf);
oldbuf = buf;
- matches++;
}
-
+ if (oldbuf)
+ free(oldbuf);
return matches;
}