diff options
author | George Hazan <george.hazan@gmail.com> | 2015-04-14 16:57:07 +0000 |
---|---|---|
committer | George Hazan <george.hazan@gmail.com> | 2015-04-14 16:57:07 +0000 |
commit | 4c0a9cfe95004f1fc934b69aa65cf2bd8a3f46ac (patch) | |
tree | c0f797d426c1adb622574d64cc7a6875b4c07d9a | |
parent | 657e6203b0435e74d91d1e756eb55dd9729f447e (diff) |
fix for two mem leaks in hunspell
git-svn-id: http://svn.miranda-ng.org/main/trunk@12820 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
-rw-r--r-- | plugins/SpellChecker/src/hunspell/affixmgr.cxx | 5 | ||||
-rw-r--r-- | plugins/SpellChecker/src/hunspell/csutil.cxx | 59 |
2 files changed, 35 insertions, 29 deletions
diff --git a/plugins/SpellChecker/src/hunspell/affixmgr.cxx b/plugins/SpellChecker/src/hunspell/affixmgr.cxx index bd998f6369..6f2ae6ccdd 100644 --- a/plugins/SpellChecker/src/hunspell/affixmgr.cxx +++ b/plugins/SpellChecker/src/hunspell/affixmgr.cxx @@ -312,7 +312,10 @@ int AffixMgr::parse_file(const char * affpath, const char * key) utf8 = 1; #ifndef OPENOFFICEORG #ifndef MOZILLA_CLIENT - if (initialize_utf_tbl()) return 1; + if (initialize_utf_tbl()) { + finishFileMgr(afflst); + return 1; + } #endif #endif } diff --git a/plugins/SpellChecker/src/hunspell/csutil.cxx b/plugins/SpellChecker/src/hunspell/csutil.cxx index ee78edbc40..86b75242ef 100644 --- a/plugins/SpellChecker/src/hunspell/csutil.cxx +++ b/plugins/SpellChecker/src/hunspell/csutil.cxx @@ -339,34 +339,37 @@ int line_tok(const char * text, char *** lines, char breakchar) { } // uniq line in place -char * line_uniq(char * text, char breakchar) { - char ** lines; - int linenum = line_tok(text, &lines, breakchar); - int i; - - if (linenum == 0) - return NULL; - strcpy(text, lines[0]); - for ( i = 1; i < linenum; i++ ) { - int dup = 0; - for (int j = 0; j < i; j++) { - if (strcmp(lines[i], lines[j]) == 0) { - dup = 1; - break; - } - } - if (!dup) { - if ((i > 1) || (*(lines[0]) != '\0')) { - sprintf(text + strlen(text), "%c", breakchar); - } - strcat(text, lines[i]); - } - } - for ( i = 0; i < linenum; i++ ) { - if (lines[i]) free(lines[i]); - } - if (lines) free(lines); - return text; +char * line_uniq(char * text, char breakchar) +{ + char **lines; + int linenum = line_tok(text, &lines, breakchar); + int i; + + if (linenum == 0) + text = NULL; + else { + strcpy(text, lines[0]); + for (i = 1; i < linenum; i++) { + int dup = 0; + for (int j = 0; j < i; j++) { + if (strcmp(lines[i], lines[j]) == 0) { + dup = 1; + break; + } + } + if (!dup) { + if ((i > 1) || (*(lines[0]) != '\0')) { + sprintf(text + strlen(text), "%c", breakchar); + } + strcat(text, lines[i]); + } + } + } + for (i = 0; i < linenum; i++) { + if (lines[i]) free(lines[i]); + } + if (lines) free(lines); + return text; } // uniq and boundary for compound analysis: "1\n\2\n\1" -> " ( \1 | \2 ) " |