summaryrefslogtreecommitdiff
path: root/plugins/TranslitSwitcher/Src/Layoutproc.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/TranslitSwitcher/Src/Layoutproc.cpp')
-rw-r--r--plugins/TranslitSwitcher/Src/Layoutproc.cpp945
1 files changed, 945 insertions, 0 deletions
diff --git a/plugins/TranslitSwitcher/Src/Layoutproc.cpp b/plugins/TranslitSwitcher/Src/Layoutproc.cpp
new file mode 100644
index 0000000000..ff77523d6c
--- /dev/null
+++ b/plugins/TranslitSwitcher/Src/Layoutproc.cpp
@@ -0,0 +1,945 @@
+/*
+Copyright (C) 2007 Dmitry Titkov (C) 2010 tico-tico, Mataes
+
+This is free software; you can redistribute it and/or
+modify it under the terms of the GNU Library General Public
+License as published by the Free Software Foundation; either
+version 2 of the License, or (at your option) any later version.
+
+This is distributed in the hope that it will be useful,
+but WITHOUT ANY WARRANTY; without even the implied warranty of
+MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+Library General Public License for more details.
+
+You should have received a copy of the GNU Library General Public
+License along with this file; see the file license.txt. If
+not, write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
+Boston, MA 02111-1307, USA.
+*/
+
+#include "TranslitSwitcher.h"
+
+SMADD_BATCHPARSE2 smgp;
+SMADD_BATCHPARSERES *smileyPrs = NULL;
+
+BOOL isItSmiley(unsigned int position)
+{
+ unsigned int j;
+
+ if (smileyPrs == NULL)
+ return FALSE;
+
+ for (j = 0; j < smgp.numSmileys; j++)
+ {
+ if (position >= smileyPrs[j].startChar && position < (smileyPrs[j].startChar + smileyPrs[j].size))
+ return TRUE;
+ }
+
+ return FALSE;
+}
+
+static DWORD CALLBACK StreamOutCallback(DWORD_PTR dwCookie, LPBYTE pbBuff, LONG cb, LONG * pcb)
+{
+ static int sendBufferSize;
+ char ** ppText = (char **) dwCookie;
+
+ if (*ppText == NULL)
+ sendBufferSize = 0;
+
+ *ppText = (char *)mir_realloc(*ppText, sendBufferSize + cb + 2);
+ memcpy (*ppText + sendBufferSize, pbBuff, cb);
+ sendBufferSize += cb;
+ *((TCHAR *)(*ppText + sendBufferSize)) = '\0';
+ *pcb = cb;
+ return 0;
+}
+
+TCHAR* Message_GetFromStream(HWND hwndRtf, DWORD dwPassedFlags)
+{
+ EDITSTREAM stream = {0};
+ TCHAR *pszText = NULL;
+
+ if (hwndRtf == 0)
+ return NULL;
+
+ stream.pfnCallback = StreamOutCallback;
+ stream.dwCookie = (DWORD_PTR) & pszText;
+ SendMessage(hwndRtf, EM_STREAMOUT, (WPARAM)dwPassedFlags, (LPARAM) & stream);
+
+ return pszText;
+}
+
+VOID Transliterate(TCHAR*& str)
+{
+ TCHAR* newStr = (TCHAR*)mir_alloc(sizeof(TCHAR)*lstrlen(str)*3+1);
+ newStr[0] = 0;
+ for (; *str != 0; str++)
+ {
+ switch (str[0])
+ {
+ case _T('à'): _tcscat(newStr, _T("a")); break;
+ case _T('á'): _tcscat(newStr, _T("b")); break;
+ case _T('â'): _tcscat(newStr, _T("v")); break;
+ case _T('ã'): _tcscat(newStr, _T("g")); break;
+ case _T('ä'): _tcscat(newStr, _T("d")); break;
+ case _T('å'): _tcscat(newStr, _T("e")); break;
+ case _T('¸'): _tcscat(newStr, _T("ye")); break;
+ case _T('æ'): _tcscat(newStr, _T("zh")); break;
+ case _T('ç'): _tcscat(newStr, _T("z")); break;
+ case _T('è'): _tcscat(newStr, _T("i")); break;
+ case _T('é'): _tcscat(newStr, _T("y")); break;
+ case _T('ê'): _tcscat(newStr, _T("k")); break;
+ case _T('ë'): _tcscat(newStr, _T("l")); break;
+ case _T('ì'): _tcscat(newStr, _T("m")); break;
+ case _T('í'): _tcscat(newStr, _T("n")); break;
+ case _T('î'): _tcscat(newStr, _T("o")); break;
+ case _T('ï'): _tcscat(newStr, _T("p")); break;
+ case _T('ð'): _tcscat(newStr, _T("r")); break;
+ case _T('ñ'): _tcscat(newStr, _T("s")); break;
+ case _T('ò'): _tcscat(newStr, _T("t")); break;
+ case _T('ó'): _tcscat(newStr, _T("u")); break;
+ case _T('ô'): _tcscat(newStr, _T("f")); break;
+ case _T('õ'): _tcscat(newStr, _T("kh")); break;
+ case _T('ö'): _tcscat(newStr, _T("ts")); break;
+ case _T('÷'): _tcscat(newStr, _T("ch")); break;
+ case _T('ø'): _tcscat(newStr, _T("sh")); break;
+ case _T('ù'): _tcscat(newStr, _T("sch")); break;
+ case _T('ú'): _tcscat(newStr, _T("'")); break;
+ case _T('û'): _tcscat(newStr, _T("yi")); break;
+ case _T('ü'): _tcscat(newStr, _T("")); break;
+ case _T('ý'): _tcscat(newStr, _T("e")); break;
+ case _T('þ'): _tcscat(newStr, _T("yu")); break;
+ case _T('ÿ'): _tcscat(newStr, _T("ya")); break;
+ case _T('À'): _tcscat(newStr, _T("A")); break;
+ case _T('Á'): _tcscat(newStr, _T("B")); break;
+ case _T('Â'): _tcscat(newStr, _T("V")); break;
+ case _T('Ã'): _tcscat(newStr, _T("G")); break;
+ case _T('Ä'): _tcscat(newStr, _T("D")); break;
+ case _T('Å'): _tcscat(newStr, _T("E")); break;
+ case _T('¨'): _tcscat(newStr, _T("Ye")); break;
+ case _T('Æ'): _tcscat(newStr, _T("Zh")); break;
+ case _T('Ç'): _tcscat(newStr, _T("Z")); break;
+ case _T('È'): _tcscat(newStr, _T("I")); break;
+ case _T('É'): _tcscat(newStr, _T("Y")); break;
+ case _T('Ê'): _tcscat(newStr, _T("K")); break;
+ case _T('Ë'): _tcscat(newStr, _T("L")); break;
+ case _T('Ì'): _tcscat(newStr, _T("M")); break;
+ case _T('Í'): _tcscat(newStr, _T("N")); break;
+ case _T('Î'): _tcscat(newStr, _T("O")); break;
+ case _T('Ï'): _tcscat(newStr, _T("P")); break;
+ case _T('Ð'): _tcscat(newStr, _T("R")); break;
+ case _T('Ñ'): _tcscat(newStr, _T("S")); break;
+ case _T('Ò'): _tcscat(newStr, _T("T")); break;
+ case _T('Ó'): _tcscat(newStr, _T("U")); break;
+ case _T('Ô'): _tcscat(newStr, _T("F")); break;
+ case _T('Õ'): _tcscat(newStr, _T("Kh")); break;
+ case _T('Ö'): _tcscat(newStr, _T("Ts")); break;
+ case _T('×'): _tcscat(newStr, _T("Ch")); break;
+ case _T('Ø'): _tcscat(newStr, _T("Sh")); break;
+ case _T('Ù'): _tcscat(newStr, _T("Sch")); break;
+ case _T('Ú'): _tcscat(newStr, _T("'")); break;
+ case _T('Û'): _tcscat(newStr, _T("Yi")); break;
+ case _T('Ü'): _tcscat(newStr, _T("")); break;
+ case _T('Ý'): _tcscat(newStr, _T("E")); break;
+ case _T('Þ'): _tcscat(newStr, _T("Yu")); break;
+ case _T('ß'): _tcscat(newStr, _T("Ya")); break;
+
+ case _T('a'): _tcscat(newStr, _T("à")); break;
+ case _T('b'): _tcscat(newStr, _T("á")); break;
+ case _T('v'): _tcscat(newStr, _T("â")); break;
+ case _T('g'): _tcscat(newStr, _T("ã")); break;
+ case _T('d'): _tcscat(newStr, _T("ä")); break;
+ case _T('e'): _tcscat(newStr, _T("å")); break;
+ case _T('z'):
+ {
+ if (str[1] == _T('h'))
+ {
+ _tcscat(newStr, _T("æ"));
+ str++;
+ break;
+ }
+ else
+ {
+ _tcscat(newStr, _T("ç"));
+ break;
+ }
+ }
+ case _T('i'): _tcscat(newStr, _T("è")); break;
+ case _T('y'):
+ {
+ if (str[1] == _T('a'))
+ {
+ _tcscat(newStr, _T("ÿ"));
+ str++;
+ break;
+ }
+ else if (str[1] == _T('e'))
+ {
+ _tcscat(newStr, _T("¸"));
+ str++;
+ break;
+ }
+ else if (str[1] == _T('u'))
+ {
+ _tcscat(newStr, _T("þ"));
+ str++;
+ break;
+ }
+ else if (str[1] == _T('i'))
+ {
+ _tcscat(newStr, _T("û"));
+ str++;
+ break;
+ }
+ else
+ {
+ _tcscat(newStr, _T("é"));
+ break;
+ }
+ }
+ case _T('k'):
+ {
+ if (str[1] == _T('h'))
+ {
+ _tcscat(newStr, _T("õ"));
+ str++;
+ break;
+ }
+ else
+ {
+ _tcscat(newStr, _T("ê"));
+ break;
+ }
+ }
+ case _T('l'): _tcscat(newStr, _T("ë")); break;
+ case _T('m'): _tcscat(newStr, _T("ì")); break;
+ case _T('n'): _tcscat(newStr, _T("í")); break;
+ case _T('o'): _tcscat(newStr, _T("î")); break;
+ case _T('p'): _tcscat(newStr, _T("ï")); break;
+ case _T('r'): _tcscat(newStr, _T("ð")); break;
+ case _T('s'):
+ {
+ if (str[1] == _T('h'))
+ {
+ _tcscat(newStr, _T("ø"));
+ str++;
+ break;
+ }
+ else if (str[1] == _T('c') && str[2] == _T('h'))
+ {
+ _tcscat(newStr, _T("ù"));
+ str+=2;
+ break;
+ }
+ else
+ {
+ _tcscat(newStr, _T("ñ"));
+ break;
+ }
+ }
+ case _T('t'):
+ {
+ if (str[1] == _T('s'))
+ {
+ _tcscat(newStr, _T("ö"));
+ str++;
+ break;
+ }
+ else
+ {
+ _tcscat(newStr, _T("ò"));
+ break;
+ }
+ }
+ case _T('u'): _tcscat(newStr, _T("ó")); break;
+ case _T('f'): _tcscat(newStr, _T("ô")); break;
+ case _T('c'):
+ {
+ if (str[1] == _T('h'))
+ {
+ _tcscat(newStr, _T("÷"));
+ str++;
+ break;
+ }
+ }
+ case _T('A'): _tcscat(newStr, _T("À")); break;
+ case _T('B'): _tcscat(newStr, _T("Á")); break;
+ case _T('V'): _tcscat(newStr, _T("Â")); break;
+ case _T('G'): _tcscat(newStr, _T("Ã")); break;
+ case _T('D'): _tcscat(newStr, _T("Ä")); break;
+ case _T('E'): _tcscat(newStr, _T("Å")); break;
+ case _T('Y'):
+ {
+ if (str[1] == _T('a'))
+ {
+ _tcscat(newStr, _T("ß"));
+ str++;
+ break;
+ }
+ else if (str[1] == _T('e'))
+ {
+ _tcscat(newStr, _T("¨"));
+ str++;
+ break;
+ }
+ else if (str[1] == _T('u'))
+ {
+ _tcscat(newStr, _T("Þ"));
+ str++;
+ break;
+ }
+ else if (str[1] == _T('i'))
+ {
+ _tcscat(newStr, _T("Û"));
+ str++;
+ break;
+ }
+ else
+ {
+ _tcscat(newStr, _T("É"));
+ break;
+ }
+ }
+ case _T('Z'):
+ {
+ if (str[1] == _T('h'))
+ {
+ _tcscat(newStr, _T("Æ"));
+ str++;
+ break;
+ }
+ else
+ {
+ _tcscat(newStr, _T("Ç"));
+ break;
+ }
+ }
+ case _T('I'): _tcscat(newStr, _T("È")); break;
+ case _T('K'):
+ {
+ if (str[1] == _T('h'))
+ {
+ _tcscat(newStr, _T("Õ"));
+ str++;
+ break;
+ }
+ else
+ {
+ _tcscat(newStr, _T("Ê"));
+ break;
+ }
+ }
+ case _T('L'): _tcscat(newStr, _T("Ë")); break;
+ case _T('M'): _tcscat(newStr, _T("Ì")); break;
+ case _T('N'): _tcscat(newStr, _T("Í")); break;
+ case _T('O'): _tcscat(newStr, _T("Î")); break;
+ case _T('P'): _tcscat(newStr, _T("Ï")); break;
+ case _T('R'): _tcscat(newStr, _T("Ð")); break;
+ case _T('S'):
+ {
+ if (str[1] == _T('h'))
+ {
+ _tcscat(newStr, _T("Ø"));
+ str++;
+ break;
+ }
+ else if (str[1] == _T('c') && str[2] == _T('h'))
+ {
+ _tcscat(newStr, _T("Ù"));
+ str+=2;
+ break;
+ }
+ else
+ {
+ _tcscat(newStr, _T("Ñ"));
+ break;
+ }
+ }
+ case _T('T'):
+ {
+ if (str[1] == _T('s'))
+ {
+ _tcscat(newStr, _T("Ö"));
+ str++;
+ break;
+ }
+ else
+ {
+ _tcscat(newStr, _T("Ò"));
+ break;
+ }
+ }
+ case _T('U'): _tcscat(newStr, _T("Ó")); break;
+ case _T('F'): _tcscat(newStr, _T("Ô")); break;
+ case _T('C'):
+ {
+ if (str[1] == _T('h'))
+ {
+ _tcscat(newStr, _T("×"));
+ str++;
+ break;
+ }
+ }
+ case _T('\''): _tcscat(newStr, _T("ú")); break;
+
+ default: { TCHAR Temp[2] = { str[0], 0} ; _tcscat(newStr, &Temp[0]); }
+ }
+ }
+ int len = lstrlen(newStr);
+ str = (TCHAR*)mir_alloc((len+1)*sizeof(TCHAR));
+ str[0] = 0;
+ _tcscpy(str, newStr);
+ mir_free(newStr);
+}
+
+VOID Invert(TCHAR *str)
+{
+ while(*str)
+ {
+ if(IsCharUpper(*str))
+ {
+ *str = (TCHAR)CharLower((LPTSTR)*str);
+ }
+ else if(IsCharLower(*str))
+ *str = (TCHAR)CharUpper((LPTSTR)*str);
+ str++;
+ }
+ keybd_event(VK_CAPITAL,0x45,KEYEVENTF_EXTENDEDKEY|0,0);
+ keybd_event(VK_CAPITAL,0x45,KEYEVENTF_EXTENDEDKEY|KEYEVENTF_KEYUP,0);
+}
+
+VOID SwitchLayout(BOOL lastword)
+{
+ HWND hwnd = GetForegroundWindow();
+
+ if(hwnd != NULL)
+ {
+ DWORD dwProcessID;
+ DWORD dwThreadID = GetWindowThreadProcessId(hwnd, &dwProcessID);
+ HWND hwnd2 = GetFocus();
+
+ if(hwnd2 != NULL)
+ {
+ TCHAR szClassName[MAX_PATH];
+
+ GetClassName(hwnd2, szClassName, SIZEOF(szClassName));
+ if((lstrcmp(szClassName, _T("THppRichEdit.UnicodeClass")) == 0 || lstrcmp(szClassName, _T("THistoryGrid.UnicodeClass")) == 0 || lstrcmp(szClassName, _T("TExtHistoryGrid.UnicodeClass")) == 0 || lstrcmp(szClassName, _T("Internet Explorer_Server")) == 0) && ServiceExists(MS_POPUP_SHOWMESSAGE)) // make popup here
+ {
+ TCHAR buf[2048];
+
+ if (lstrcmp(szClassName, _T("Internet Explorer_Server")) == 0)
+ {
+ TCHAR *selected = 0;
+ IEVIEWEVENT event;
+ HWND hwnd3 = GetParent(GetParent(hwnd2));
+ ZeroMemory((void *)&event, sizeof(event));
+ event.cbSize = sizeof(IEVIEWEVENT);
+ event.hContact = 0;
+ event.dwFlags = 0;
+ event.iType = IEE_GET_SELECTION;
+ event.hwnd = hwnd3;
+ selected = (TCHAR *)CallService(MS_IEVIEW_EVENT, 0, (LPARAM) & event);
+ lstrcpy(buf, selected);
+ }
+ else
+ SendMessage(hwnd2, WM_GETTEXT, SIZEOF(buf), (LPARAM)buf); // gimme, gimme, gimme...
+
+ int slen = lstrlen(buf);
+ if (slen != 0)
+ {
+ HKL hkl;
+ ActivateKeyboardLayout((HKL)HKL_NEXT, KLF_ACTIVATE); // go to next layout before....
+ hkl = GetKeyboardLayout(dwThreadID);
+ ActivateKeyboardLayout((HKL)HKL_PREV, KLF_ACTIVATE); // return to prev layout
+
+ if (ServiceExists(MS_SMILEYADD_BATCHPARSE))
+ {
+ ZeroMemory(&smgp, sizeof(smgp));
+ smgp.cbSize = sizeof(smgp);
+ smgp.str = buf;
+ smgp.flag = SAFL_TCHAR;
+ smileyPrs = (SMADD_BATCHPARSERES *)CallService(MS_SMILEYADD_BATCHPARSE, 0, (LPARAM)&smgp);
+ }
+
+ for(int i = 0; i < slen; i++)
+ {
+ SHORT vks;
+ BYTE keys[256] = {0};
+
+ vks = VkKeyScanEx(buf[i], hkl);
+
+ keys[VK_SHIFT] = (HIBYTE(vks) & 1) ? 0xFF : 0x00; // shift
+ keys[VK_CONTROL] = (HIBYTE(vks) & 2) ? 0xFF : 0x00; // ctrl
+ keys[VK_MENU] = (HIBYTE(vks) & 4) ? 0xFF : 0x00; // alt
+
+ if (!isItSmiley(i))
+ {
+ TCHAR tchr;
+ if(ToUnicodeEx(LOBYTE(vks), 0, keys, &tchr, 1, 0, GetKeyboardLayout(dwThreadID)) == 1)
+ buf[i] = tchr;
+ }
+ }
+
+ if (smileyPrs != NULL)
+ CallService(MS_SMILEYADD_BATCHFREE, 0, (LPARAM)smileyPrs);
+
+ POPUPDATAT_V2 pd;
+ ZeroMemory(&pd, sizeof(pd));
+ pd.cbSize = sizeof(POPUPDATAT_V2);
+ pd.lchContact = NULL; //(HANDLE)wParam;
+ pd.lchIcon = (HICON)CallService(MS_SKIN2_GETICON, 0, (LPARAM) "SwitchLayout and Send");
+ lstrcpyn(pd.lptzText, buf, SIZEOF(pd.lptzText));
+ lstrcpyn(pd.lptzContactName, TranslateT("TranslitSwitcher"), SIZEOF(pd.lptzContactName));
+ pd.colorBack = pd.colorText = 0;
+ pd.iSeconds = 0;
+ CallService(MS_POPUP_ADDPOPUPT, (WPARAM) &pd, 0);
+
+ //PUShowMessageT(buf, SM_NOTIFY);
+ }
+ }
+ else
+ if(lstrcmp(szClassName, _T("RichEdit20W")) == 0)
+ {
+ DWORD dwStart, dwEnd;
+ int i, slen, start = 0, end = 0;
+ TCHAR *sel, tchr;
+ BOOL somethingIsSelected = TRUE;
+ SHORT vks;
+ BYTE keys[256] = {0};
+ HKL hkl = GetKeyboardLayout(dwThreadID);
+
+ SendMessage(hwnd2, EM_GETSEL, (WPARAM)&dwStart, (LPARAM)&dwEnd);
+
+ if (dwStart == dwEnd)
+ somethingIsSelected = FALSE;
+
+ if (somethingIsSelected)
+ sel = Message_GetFromStream(hwnd2, SF_TEXT|SF_UNICODE|SFF_SELECTION);
+ else
+ sel = Message_GetFromStream(hwnd2, SF_TEXT|SF_UNICODE);
+
+ slen = lstrlen(sel);
+
+ if (slen != 0)
+ {
+ if (ServiceExists(MS_SMILEYADD_BATCHPARSE))
+ {
+ ZeroMemory(&smgp, sizeof(smgp));
+ smgp.cbSize = sizeof(smgp);
+ smgp.str = sel;
+ smgp.flag = SAFL_TCHAR;
+ smileyPrs = (SMADD_BATCHPARSERES *)CallService(MS_SMILEYADD_BATCHPARSE, 0, (LPARAM)&smgp);
+ }
+
+ end = slen;
+ if (lastword && !somethingIsSelected)
+ {
+ end = dwStart;
+ while (end < slen)
+ {
+ if (_istspace(sel[end]) || isItSmiley(end))
+ break;
+ end++;
+ }
+ start = dwStart-1;
+ while (start > 0 && start < (int)dwStart)
+ {
+ if ((_istspace(sel[start]) && !_istspace(sel[start+1])) || isItSmiley(start))
+ break;
+ start--;
+ }
+ }
+
+ ActivateKeyboardLayout((HKL)HKL_PREV, KLF_ACTIVATE);
+
+ for(i = start; i < end; i++)
+ {
+ vks = VkKeyScanEx(sel[i], hkl);
+
+ keys[VK_SHIFT] = (HIBYTE(vks) & 1) ? 0xFF : 0x00; // shift
+ keys[VK_CONTROL] = (HIBYTE(vks) & 2) ? 0xFF : 0x00; // ctrl
+ keys[VK_MENU] = (HIBYTE(vks) & 4) ? 0xFF : 0x00; // alt
+
+ if (!isItSmiley(i))
+ {
+ if(ToUnicodeEx(LOBYTE(vks), 0, keys, &tchr, 1, 0, GetKeyboardLayout(dwThreadID)) == 1)
+ sel[i] = tchr;
+ }
+ }
+
+ if (smileyPrs != NULL)
+ CallService(MS_SMILEYADD_BATCHFREE, 0, (LPARAM)smileyPrs);
+
+ if (somethingIsSelected)
+ SendMessage(hwnd2, EM_REPLACESEL, FALSE, (LPARAM)sel);
+ else
+ SendMessage(hwnd2, WM_SETTEXT, 0, (LPARAM)sel);
+
+ SendMessage(hwnd2, EM_SETSEL, dwStart, dwEnd);
+ }
+ mir_free(sel);
+ }
+ }
+ }
+}
+
+void TranslitLayout(BOOL lastword)
+{
+ HWND hwnd = GetForegroundWindow();
+
+ if(hwnd != NULL)
+ {
+ DWORD dwProcessID;
+ DWORD dwThreadID = GetWindowThreadProcessId(hwnd, &dwProcessID);
+ HWND hwnd2 = GetFocus();
+
+ if(hwnd2 != NULL)
+ {
+ TCHAR szClassName[16];
+
+ GetClassName(hwnd2, szClassName, SIZEOF(szClassName));
+
+ if(lstrcmp(szClassName, _T("RichEdit20W")) == 0)
+ {
+ DWORD dwStart, dwEnd;
+ int slen, start = 0, end = 0;
+ TCHAR *sel, *boo;
+ BOOL somethingIsSelected = TRUE;
+
+ SendMessage(hwnd2, EM_GETSEL, (WPARAM)&dwStart, (LPARAM)&dwEnd);
+
+ if (dwStart == dwEnd)
+ somethingIsSelected = FALSE;
+
+ if (somethingIsSelected)
+ sel = Message_GetFromStream(hwnd2, SF_TEXT|SF_UNICODE|SFF_SELECTION);
+ else
+ sel = Message_GetFromStream(hwnd2, SF_TEXT|SF_UNICODE);
+
+ slen = lstrlen(sel);
+
+ if (slen != 0)
+ {
+ end = slen;
+ if (lastword && !somethingIsSelected)
+ {
+ end = dwStart;
+ while (end < slen)
+ {
+ if (_istspace(sel[end]) || isItSmiley(end))
+ break;
+ end++;
+ }
+ start = dwStart-1;
+ while (start > 0 && start < (int)dwStart)
+ {
+ if ((_istspace(sel[start]) && (end-start>2)) || isItSmiley(start))
+ break;
+ start--;
+ }
+ boo = (TCHAR*)mir_alloc((end-start+1 ) * sizeof(TCHAR));
+ _tcsncpy(boo, sel+start, end-start);
+ boo[end-start] = 0;
+ }
+ else
+ {
+ boo = (TCHAR*)mir_alloc((slen+1 ) * sizeof(TCHAR));
+ _tcscpy(boo, sel);
+ }
+
+ Transliterate(boo);
+
+ if (somethingIsSelected)
+ SendMessage(hwnd2, EM_REPLACESEL, FALSE, (LPARAM)boo);
+ else
+ {
+ TCHAR* NewText = (TCHAR*)mir_alloc((start+_tcslen(boo)+(slen-start)+1)* sizeof(TCHAR));
+ NewText[0] = 0;
+ _tcsncat(NewText, sel, start);
+ _tcscat(NewText, boo);
+ _tcsncat(NewText, sel+end, slen-end);
+ SendMessage(hwnd2, WM_SETTEXT, 0, (LPARAM)NewText);
+ mir_free(NewText);
+ }
+
+ SendMessage(hwnd2, EM_SETSEL, dwStart, dwEnd);
+ }
+ mir_free(sel);
+ mir_free(boo);
+ }
+ }
+ }
+}
+
+void InvertCase(BOOL lastword)
+{
+ HWND hwnd = GetForegroundWindow();
+
+ if(hwnd != NULL)
+ {
+ DWORD dwProcessID;
+ DWORD dwThreadID = GetWindowThreadProcessId(hwnd, &dwProcessID);
+ HWND hwnd2 = GetFocus();
+
+ if(hwnd2 != NULL)
+ {
+ TCHAR szClassName[16];
+
+ GetClassName(hwnd2, szClassName, SIZEOF(szClassName));
+
+ if(lstrcmp(szClassName, _T("RichEdit20W")) == 0)
+ {
+ DWORD dwStart, dwEnd;
+ int slen, start = 0, end = 0;
+ TCHAR *sel, *boo;
+ BOOL somethingIsSelected = TRUE;
+
+ SendMessage(hwnd2, EM_GETSEL, (WPARAM)&dwStart, (LPARAM)&dwEnd);
+
+ if (dwStart == dwEnd)
+ somethingIsSelected = FALSE;
+
+ if (somethingIsSelected)
+ sel = Message_GetFromStream(hwnd2, SF_TEXT|SF_UNICODE|SFF_SELECTION);
+ else
+ sel = Message_GetFromStream(hwnd2, SF_TEXT|SF_UNICODE);
+
+ slen = lstrlen(sel);
+
+ if (slen != 0)
+ {
+ end = slen;
+ if (lastword && !somethingIsSelected)
+ {
+ end = dwStart;
+ while (end < slen)
+ {
+ if (_istspace(sel[end]) || isItSmiley(end))
+ break;
+ end++;
+ }
+ start = dwStart-1;
+ while (start > 0 && start < (int)dwStart)
+ {
+ if ((_istspace(sel[start]) && (end-start>2)) || isItSmiley(start))
+ break;
+ start--;
+ }
+ boo = (TCHAR*)mir_alloc((end-start+1 ) * sizeof(TCHAR));
+ _tcsncpy(boo, sel+start, end-start);
+ boo[end-start] = 0;
+ }
+ else
+ {
+ boo = (TCHAR*)mir_alloc((slen+1 ) * sizeof(TCHAR));
+ _tcscpy(boo, sel);
+ }
+
+ Invert(boo);
+
+ if (somethingIsSelected)
+ SendMessage(hwnd2, EM_REPLACESEL, FALSE, (LPARAM)boo);
+ else
+ {
+ TCHAR* NewText = (TCHAR*)mir_alloc((start+_tcslen(boo)+(slen-start)+1)* sizeof(TCHAR));
+ NewText[0] = 0;
+ _tcsncat(NewText, sel, start);
+ _tcscat(NewText, boo);
+ _tcsncat(NewText, sel+end, slen-end);
+ SendMessage(hwnd2, WM_SETTEXT, 0, (LPARAM)NewText);
+ mir_free(NewText);
+ }
+
+ SendMessage(hwnd2, EM_SETSEL, dwStart, dwEnd);
+ }
+ mir_free(sel);
+ mir_free(boo);
+ }
+ }
+ }
+}
+
+int OnButtonPressed(WPARAM wParam, LPARAM lParam)
+{
+ CustomButtonClickData *cbcd = (CustomButtonClickData *)lParam;
+ if (lstrcmpA(cbcd->pszModule, "SwitchLayout and Send") == 0)
+ {
+ HWND hEdit = GetDlgItem(cbcd->hwndFrom, IDC_MESSAGE);
+ if (!hEdit) hEdit = GetDlgItem(cbcd->hwndFrom, IDC_CHATMESSAGE);
+
+ BYTE byKeybState[256];
+ GetKeyboardState(byKeybState);
+ byKeybState[VK_CONTROL] = 128;
+ SetKeyboardState(byKeybState);
+ SendMessage(hEdit, WM_KEYDOWN, VK_UP, 0);
+ byKeybState[VK_CONTROL] = 0;
+ SetKeyboardState(byKeybState);
+
+ DWORD dwProcessID;
+ DWORD dwThreadID = GetWindowThreadProcessId(cbcd->hwndFrom, &dwProcessID);
+ HKL hkl = GetKeyboardLayout(dwThreadID);
+
+ TCHAR *sel = Message_GetFromStream(hEdit, SF_TEXT|SF_UNICODE);
+ int slen = lstrlen(sel);
+
+ if (slen != 0)
+ {
+ ZeroMemory(&smgp, sizeof(smgp));
+ smgp.cbSize = sizeof(smgp);
+ smgp.str = sel;
+ smgp.flag = SAFL_TCHAR;
+
+ if (ServiceExists(MS_SMILEYADD_BATCHPARSE))
+ smileyPrs = (SMADD_BATCHPARSERES *)CallService(MS_SMILEYADD_BATCHPARSE, 0, (LPARAM)&smgp);
+
+ ActivateKeyboardLayout((HKL)HKL_PREV, KLF_ACTIVATE);
+
+ for(int i = 0; i < slen; i++)
+ {
+ TCHAR tchr;
+ BYTE keys[256] = {0};
+ SHORT vks = VkKeyScanEx(sel[i], hkl);
+
+ keys[VK_SHIFT] = (HIBYTE(vks) & 1) ? 0xFF : 0x00; // shift
+ keys[VK_CONTROL] = (HIBYTE(vks) & 2) ? 0xFF : 0x00; // ctrl
+ keys[VK_MENU] = (HIBYTE(vks) & 4) ? 0xFF : 0x00; // alt
+
+ if (!isItSmiley(i))
+ {
+ if(ToUnicodeEx(LOBYTE(vks), 0, keys, &tchr, 1, 0, GetKeyboardLayout(dwThreadID)) == 1)
+ sel[i] = tchr;
+ }
+ }
+ if (smileyPrs != NULL)
+ CallService(MS_SMILEYADD_BATCHFREE, 0, (LPARAM)smileyPrs);
+
+ DBVARIANT dbv = {0};
+ DBGetContactSettingTString(NULL, "TranslitSwitcher", "ResendSymbol", &dbv);
+ if (lstrcmp(dbv.ptszVal, NULL) == 0)
+ {
+ DBFreeVariant(&dbv);
+ SendMessage(hEdit, WM_SETTEXT, 0, (LPARAM)sel);
+ SendMessage(hEdit, EM_SETSEL, 0, slen);
+ SendMessage(cbcd->hwndFrom, WM_COMMAND, IDOK, 0);
+ }
+ else
+ {
+ if (_tcsncmp(sel, dbv.ptszVal, _tcslen(dbv.ptszVal)) == 0)
+ {
+ SendMessage(hEdit, WM_SETTEXT, 0, (LPARAM)sel);
+ SendMessage(hEdit, EM_SETSEL, 0, slen);
+ SendMessage(cbcd->hwndFrom, WM_COMMAND, IDOK, 0);
+ }
+ else
+ {
+ int FinalLen = slen + SIZEOF(dbv.ptszVal) + 1;
+ TCHAR* FinalString = (TCHAR*)mir_alloc((FinalLen+1)*sizeof(TCHAR));
+ mir_sntprintf(FinalString, FinalLen, _T("%s %s"), dbv.ptszVal, sel);
+ SendMessage(hEdit, WM_SETTEXT, 0, (LPARAM)FinalString);
+ SendMessage(hEdit, EM_SETSEL, 0, FinalLen);
+ SendMessage(cbcd->hwndFrom, WM_COMMAND, IDOK, 0);
+ mir_free(FinalString);
+ }
+ }
+ }
+ mir_free(sel);
+ return 1;
+ }
+ if (lstrcmpA(cbcd->pszModule, "Translit and Send") == 0)
+ {
+ HWND hEdit = GetDlgItem(cbcd->hwndFrom, IDC_MESSAGE);
+ if (!hEdit) hEdit = GetDlgItem(cbcd->hwndFrom, IDC_CHATMESSAGE);
+
+ BYTE byKeybState[256];
+ GetKeyboardState(byKeybState);
+ byKeybState[VK_CONTROL] = 128;
+ SetKeyboardState(byKeybState);
+ SendMessage(hEdit, WM_KEYDOWN, VK_UP, 0);
+ byKeybState[VK_CONTROL] = 0;
+ SetKeyboardState(byKeybState);
+
+ TCHAR *sel = Message_GetFromStream(hEdit, SF_TEXT|SF_UNICODE);
+ int slen = lstrlen(sel);
+ if (slen != 0)
+ Transliterate(sel);
+ DBVARIANT dbv = {0};
+ DBGetContactSettingTString(NULL, "TranslitSwitcher", "ResendSymbol", &dbv);
+ if (lstrcmp(dbv.ptszVal, NULL) == 0)
+ {
+ DBFreeVariant(&dbv);
+ SendMessage(hEdit, WM_SETTEXT, 0, (LPARAM)sel);
+ SendMessage(hEdit, EM_SETSEL, 0, slen);
+ SendMessage(cbcd->hwndFrom, WM_COMMAND, IDOK, 0);
+ }
+ else
+ {
+ if (_tcsncmp(sel, dbv.ptszVal, _tcslen(dbv.ptszVal)) == 0)
+ {
+ SendMessage(hEdit, WM_SETTEXT, 0, (LPARAM)sel);
+ SendMessage(hEdit, EM_SETSEL, 0, slen);
+ SendMessage(cbcd->hwndFrom, WM_COMMAND, IDOK, 0);
+ }
+ else
+ {
+ int FinalLen = lstrlen(sel) + SIZEOF(dbv.ptszVal) + 1;
+ TCHAR* FinalString = (TCHAR*)mir_alloc((FinalLen+1)*sizeof(TCHAR));
+ mir_sntprintf(FinalString, FinalLen, _T("%s %s"), dbv.ptszVal, sel);
+ SendMessage(hEdit, WM_SETTEXT, 0, (LPARAM)FinalString);
+ SendMessage(hEdit, EM_SETSEL, 0, FinalLen);
+ SendMessage(cbcd->hwndFrom, WM_COMMAND, IDOK, 0);
+ mir_free(FinalString);
+ }
+ }
+ mir_free(sel);
+ return 1;
+ }
+ if (lstrcmpA(cbcd->pszModule, "Invert Case and Send") == 0)
+ {
+ HWND hEdit = GetDlgItem(cbcd->hwndFrom, IDC_MESSAGE);
+ if (!hEdit) hEdit = GetDlgItem(cbcd->hwndFrom, IDC_CHATMESSAGE);
+
+ BYTE byKeybState[256];
+ GetKeyboardState(byKeybState);
+ byKeybState[VK_CONTROL] = 128;
+ SetKeyboardState(byKeybState);
+ SendMessage(hEdit, WM_KEYDOWN, VK_UP, 0);
+ byKeybState[VK_CONTROL] = 0;
+ SetKeyboardState(byKeybState);
+
+ TCHAR *sel = Message_GetFromStream(hEdit, SF_TEXT|SF_UNICODE);
+ int slen = lstrlen(sel);
+ if (slen != 0)
+ Invert(sel);
+ DBVARIANT dbv = {0};
+ DBGetContactSettingTString(NULL, "TranslitSwitcher", "ResendSymbol", &dbv);
+ if (lstrcmp(dbv.ptszVal, NULL) == 0)
+ {
+ DBFreeVariant(&dbv);
+ SendMessage(hEdit, WM_SETTEXT, 0, (LPARAM)sel);
+ SendMessage(hEdit, EM_SETSEL, 0, slen);
+ SendMessage(cbcd->hwndFrom, WM_COMMAND, IDOK, 0);
+ }
+ else
+ {
+ if (_tcsncmp(sel, dbv.ptszVal, _tcslen(dbv.ptszVal)) == 0)
+ {
+ SendMessage(hEdit, WM_SETTEXT, 0, (LPARAM)sel);
+ SendMessage(hEdit, EM_SETSEL, 0, slen);
+ SendMessage(cbcd->hwndFrom, WM_COMMAND, IDOK, 0);
+ }
+ else
+ {
+ int FinalLen = slen + SIZEOF(dbv.ptszVal) + 1;
+ TCHAR* FinalString = (TCHAR*)mir_alloc((FinalLen+1)*sizeof(TCHAR));
+ mir_sntprintf(FinalString, FinalLen, _T("%s %s"), dbv.ptszVal, sel);
+ SendMessage(hEdit, WM_SETTEXT, 0, (LPARAM)FinalString);
+ SendMessage(hEdit, EM_SETSEL, 0, FinalLen);
+ SendMessage(cbcd->hwndFrom, WM_COMMAND, IDOK, 0);
+ mir_free(FinalString);
+ }
+ }
+ mir_free(sel);
+ return 1;
+ }
+ return 0;
+} \ No newline at end of file