summaryrefslogtreecommitdiff
path: root/plugins/SpellChecker/src/autoreplace.cpp
diff options
context:
space:
mode:
authorGeorge Hazan <ghazan@miranda.im>2018-01-18 23:42:33 +0300
committerGeorge Hazan <ghazan@miranda.im>2018-01-18 23:42:33 +0300
commit44a8248b1b19375130144a783d1758e1f83d3c88 (patch)
treec8e134b6c1d1a7a8ae463989116a38c055af0d2b /plugins/SpellChecker/src/autoreplace.cpp
parent61757497a901760271660c20390fc39aa6300a42 (diff)
SpellChecker:
- fix for a memory allocation zoo; - code cleaning; - version bump
Diffstat (limited to 'plugins/SpellChecker/src/autoreplace.cpp')
-rw-r--r--plugins/SpellChecker/src/autoreplace.cpp24
1 files changed, 13 insertions, 11 deletions
diff --git a/plugins/SpellChecker/src/autoreplace.cpp b/plugins/SpellChecker/src/autoreplace.cpp
index b111862c3b..e2db8efbae 100644
--- a/plugins/SpellChecker/src/autoreplace.cpp
+++ b/plugins/SpellChecker/src/autoreplace.cpp
@@ -127,20 +127,20 @@ BOOL AutoReplaceMap::isWordChar(wchar_t c)
}
-wchar_t* AutoReplaceMap::autoReplace(const wchar_t * word)
+CMStringW AutoReplaceMap::autoReplace(const wchar_t * word)
{
ptrW from(wcslwr(mir_wstrdup(word)));
if (m_replacements.find(from.get()) == m_replacements.end())
- return nullptr;
+ return CMStringW();
AutoReplacement &ar = m_replacements[from.get()];
- wchar_t *to;
+ CMStringW ret;
if (ar.useVariables)
- to = variables_parsedup((wchar_t *)ar.replace.c_str(), (wchar_t *)word, NULL);
+ ret = ptrW(variables_parsedup((wchar_t *)ar.replace.c_str(), (wchar_t *)word, NULL));
else
- to = mir_wstrdup(ar.replace.c_str());
+ ret = ar.replace.c_str();
// Wich case to use?
size_t len = mir_wstrlen(word);
@@ -150,18 +150,20 @@ wchar_t* AutoReplaceMap::autoReplace(const wchar_t * word)
break;
if (i <= 0) // All lower
- return to;
+ return ret;
- if (i >= len) // All upper
- return CharUpper(to);
+ if (i >= len) { // All upper
+ ret.MakeUpper();
+ return ret;
+ }
// First upper
wchar_t tmp[2];
- tmp[0] = to[0];
+ tmp[0] = ret[0];
tmp[1] = '\0';
CharUpper(tmp);
- to[0] = tmp[0];
- return to;
+ ret.SetAt(0, tmp[0]);
+ return ret;
}
wchar_t* AutoReplaceMap::filterText(const wchar_t *find)