Commit 2ea559b8 authored by Aric Stewart's avatar Aric Stewart Committed by Alexandre Julliard

imm32: Have both ImmInternalPostIMEMessage and ImmInternalSendIMENotify receive…

imm32: Have both ImmInternalPostIMEMessage and ImmInternalSendIMENotify receive an InputContextData parameter instead of relaying on root_context.
parent 9e021cff
...@@ -82,7 +82,7 @@ static UINT WM_MSIME_DOCUMENTFEED; ...@@ -82,7 +82,7 @@ static UINT WM_MSIME_DOCUMENTFEED;
static LRESULT WINAPI IME_WindowProc(HWND hwnd, UINT uMsg, WPARAM wParam, static LRESULT WINAPI IME_WindowProc(HWND hwnd, UINT uMsg, WPARAM wParam,
LPARAM lParam); LPARAM lParam);
static void UpdateDataInDefaultIMEWindow(HWND hwnd, BOOL showable); static void UpdateDataInDefaultIMEWindow(HWND hwnd, BOOL showable);
static void ImmInternalPostIMEMessage(UINT, WPARAM, LPARAM); static void ImmInternalPostIMEMessage(InputContextData*, UINT, WPARAM, LPARAM);
static void ImmInternalSetOpenStatus(BOOL fOpen); static void ImmInternalSetOpenStatus(BOOL fOpen);
static HIMCC updateResultStr(HIMCC old, LPWSTR resultstr, DWORD len); static HIMCC updateResultStr(HIMCC old, LPWSTR resultstr, DWORD len);
...@@ -100,7 +100,7 @@ static VOID IMM_PostResult(InputContextData *data) ...@@ -100,7 +100,7 @@ static VOID IMM_PostResult(InputContextData *data)
ResultStr = (LPWSTR)(compdata + compstr->dwResultStrOffset); ResultStr = (LPWSTR)(compdata + compstr->dwResultStrOffset);
for (i = 0; i < compstr->dwResultStrLen; i++) for (i = 0; i < compstr->dwResultStrLen; i++)
ImmInternalPostIMEMessage (WM_IME_CHAR, ResultStr[i], 1); ImmInternalPostIMEMessage (root_context, WM_IME_CHAR, ResultStr[i], 1);
ImmUnlockIMCC(root_context->IMC.hCompStr); ImmUnlockIMCC(root_context->IMC.hCompStr);
...@@ -173,20 +173,20 @@ BOOL WINAPI DllMain(HINSTANCE hInstDLL, DWORD fdwReason, LPVOID lpReserved) ...@@ -173,20 +173,20 @@ BOOL WINAPI DllMain(HINSTANCE hInstDLL, DWORD fdwReason, LPVOID lpReserved)
} }
/* for posting messages as the IME */ /* for posting messages as the IME */
static void ImmInternalPostIMEMessage(UINT msg, WPARAM wParam, LPARAM lParam) static void ImmInternalPostIMEMessage(InputContextData *data, UINT msg, WPARAM wParam, LPARAM lParam)
{ {
HWND target = GetFocus(); HWND target = GetFocus();
if (!target) if (!target)
PostMessageW(root_context->IMC.hWnd,msg,wParam,lParam); PostMessageW(data->IMC.hWnd,msg,wParam,lParam);
else else
PostMessageW(target, msg, wParam, lParam); PostMessageW(target, msg, wParam, lParam);
} }
static LRESULT ImmInternalSendIMENotify(WPARAM notify, LPARAM lParam) static LRESULT ImmInternalSendIMENotify(InputContextData *data, WPARAM notify, LPARAM lParam)
{ {
HWND target; HWND target;
target = root_context->IMC.hWnd; target = data->IMC.hWnd;
if (!target) target = GetFocus(); if (!target) target = GetFocus();
if (target) if (target)
...@@ -221,7 +221,7 @@ static void ImmInternalSetOpenStatus(BOOL fOpen) ...@@ -221,7 +221,7 @@ static void ImmInternalSetOpenStatus(BOOL fOpen)
root_context->IMC.fOpen = fOpen; root_context->IMC.fOpen = fOpen;
root_context->bInternalState = fOpen; root_context->bInternalState = fOpen;
ImmInternalSendIMENotify(IMN_SETOPENSTATUS, 0); ImmInternalSendIMENotify(root_context, IMN_SETOPENSTATUS, 0);
} }
static int updateField(DWORD origLen, DWORD origOffset, DWORD currentOffset, static int updateField(DWORD origLen, DWORD origOffset, DWORD currentOffset,
...@@ -1501,7 +1501,7 @@ BOOL WINAPI ImmNotifyIME( ...@@ -1501,7 +1501,7 @@ BOOL WINAPI ImmNotifyIME(
root_context->IMC.hCompStr = ImmCreateBlankCompStr(); root_context->IMC.hCompStr = ImmCreateBlankCompStr();
if (send) if (send)
ImmInternalPostIMEMessage(WM_IME_COMPOSITION, 0, ImmInternalPostIMEMessage(root_context, WM_IME_COMPOSITION, 0,
GCS_COMPSTR); GCS_COMPSTR);
rc = TRUE; rc = TRUE;
} }
...@@ -1542,15 +1542,15 @@ BOOL WINAPI ImmNotifyIME( ...@@ -1542,15 +1542,15 @@ BOOL WINAPI ImmNotifyIME(
root_context->bRead = FALSE; root_context->bRead = FALSE;
ImmInternalPostIMEMessage(WM_IME_COMPOSITION, 0, ImmInternalPostIMEMessage(root_context, WM_IME_COMPOSITION, 0,
GCS_COMPSTR); GCS_COMPSTR);
ImmInternalPostIMEMessage(WM_IME_COMPOSITION, ImmInternalPostIMEMessage(root_context, WM_IME_COMPOSITION,
param, param,
GCS_RESULTSTR|GCS_RESULTCLAUSE); GCS_RESULTSTR|GCS_RESULTCLAUSE);
} }
ImmInternalPostIMEMessage(WM_IME_ENDCOMPOSITION, 0, 0); ImmInternalPostIMEMessage(root_context, WM_IME_ENDCOMPOSITION, 0, 0);
root_context->bInComposition = FALSE; root_context->bInComposition = FALSE;
} }
break; break;
...@@ -1653,7 +1653,7 @@ BOOL WINAPI ImmSetCompositionFontA(HIMC hIMC, LPLOGFONTA lplf) ...@@ -1653,7 +1653,7 @@ BOOL WINAPI ImmSetCompositionFontA(HIMC hIMC, LPLOGFONTA lplf)
MultiByteToWideChar(CP_ACP, 0, lplf->lfFaceName, -1, data->IMC.lfFont.W.lfFaceName, MultiByteToWideChar(CP_ACP, 0, lplf->lfFaceName, -1, data->IMC.lfFont.W.lfFaceName,
LF_FACESIZE); LF_FACESIZE);
ImmInternalSendIMENotify(IMN_SETCOMPOSITIONFONT, 0); ImmInternalSendIMENotify(data, IMN_SETCOMPOSITIONFONT, 0);
if (data->textfont) if (data->textfont)
{ {
...@@ -1677,7 +1677,7 @@ BOOL WINAPI ImmSetCompositionFontW(HIMC hIMC, LPLOGFONTW lplf) ...@@ -1677,7 +1677,7 @@ BOOL WINAPI ImmSetCompositionFontW(HIMC hIMC, LPLOGFONTW lplf)
return FALSE; return FALSE;
data->IMC.lfFont.W = *lplf; data->IMC.lfFont.W = *lplf;
ImmInternalSendIMENotify(IMN_SETCOMPOSITIONFONT, 0); ImmInternalSendIMENotify(data, IMN_SETCOMPOSITIONFONT, 0);
if (data->textfont) if (data->textfont)
{ {
...@@ -1766,7 +1766,7 @@ BOOL WINAPI ImmSetCompositionStringW( ...@@ -1766,7 +1766,7 @@ BOOL WINAPI ImmSetCompositionStringW(
HIMCC newCompStr; HIMCC newCompStr;
if (!root_context->bInComposition) if (!root_context->bInComposition)
{ {
ImmInternalPostIMEMessage(WM_IME_STARTCOMPOSITION, 0, 0); ImmInternalPostIMEMessage(root_context, WM_IME_STARTCOMPOSITION, 0, 0);
root_context->bInComposition = TRUE; root_context->bInComposition = TRUE;
} }
...@@ -1791,7 +1791,7 @@ BOOL WINAPI ImmSetCompositionStringW( ...@@ -1791,7 +1791,7 @@ BOOL WINAPI ImmSetCompositionStringW(
UpdateDataInDefaultIMEWindow(hwndDefault,FALSE); UpdateDataInDefaultIMEWindow(hwndDefault,FALSE);
ImmInternalPostIMEMessage(WM_IME_COMPOSITION, wParam, flags); ImmInternalPostIMEMessage(root_context, WM_IME_COMPOSITION, wParam, flags);
return TRUE; return TRUE;
} }
...@@ -1826,7 +1826,7 @@ BOOL WINAPI ImmSetCompositionWindow( ...@@ -1826,7 +1826,7 @@ BOOL WINAPI ImmSetCompositionWindow(
if (reshow) if (reshow)
ShowWindow(hwndDefault,SW_SHOWNOACTIVATE); ShowWindow(hwndDefault,SW_SHOWNOACTIVATE);
ImmInternalSendIMENotify(IMN_SETCOMPOSITIONWINDOW, 0); ImmInternalSendIMENotify(data, IMN_SETCOMPOSITIONWINDOW, 0);
return TRUE; return TRUE;
} }
...@@ -1860,7 +1860,7 @@ BOOL WINAPI ImmSetOpenStatus(HIMC hIMC, BOOL fOpen) ...@@ -1860,7 +1860,7 @@ BOOL WINAPI ImmSetOpenStatus(HIMC hIMC, BOOL fOpen)
if (hIMC == (HIMC)FROM_IME) if (hIMC == (HIMC)FROM_IME)
{ {
ImmInternalSetOpenStatus(fOpen); ImmInternalSetOpenStatus(fOpen);
ImmInternalSendIMENotify(IMN_SETOPENSTATUS, 0); ImmInternalSendIMENotify(data, IMN_SETOPENSTATUS, 0);
return TRUE; return TRUE;
} }
...@@ -1873,17 +1873,17 @@ BOOL WINAPI ImmSetOpenStatus(HIMC hIMC, BOOL fOpen) ...@@ -1873,17 +1873,17 @@ BOOL WINAPI ImmSetOpenStatus(HIMC hIMC, BOOL fOpen)
pX11DRV_ForceXIMReset(data->IMC.hWnd); pX11DRV_ForceXIMReset(data->IMC.hWnd);
if (fOpen == FALSE) if (fOpen == FALSE)
ImmInternalPostIMEMessage(WM_IME_ENDCOMPOSITION,0,0); ImmInternalPostIMEMessage(data, WM_IME_ENDCOMPOSITION,0,0);
else else
ImmInternalPostIMEMessage(WM_IME_STARTCOMPOSITION,0,0); ImmInternalPostIMEMessage(data, WM_IME_STARTCOMPOSITION,0,0);
ImmInternalSetOpenStatus(fOpen); ImmInternalSetOpenStatus(fOpen);
ImmInternalSetOpenStatus(!fOpen); ImmInternalSetOpenStatus(!fOpen);
if (data->IMC.fOpen == FALSE) if (data->IMC.fOpen == FALSE)
ImmInternalPostIMEMessage(WM_IME_ENDCOMPOSITION,0,0); ImmInternalPostIMEMessage(data, WM_IME_ENDCOMPOSITION,0,0);
else else
ImmInternalPostIMEMessage(WM_IME_STARTCOMPOSITION,0,0); ImmInternalPostIMEMessage(data, WM_IME_STARTCOMPOSITION,0,0);
return FALSE; return FALSE;
} }
...@@ -2094,7 +2094,7 @@ BOOL WINAPI ImmGenerateMessage(HIMC hIMC) ...@@ -2094,7 +2094,7 @@ BOOL WINAPI ImmGenerateMessage(HIMC hIMC)
lpTransMsg = (LPTRANSMSG)ImmLockIMCC(data->IMC.hMsgBuf); lpTransMsg = (LPTRANSMSG)ImmLockIMCC(data->IMC.hMsgBuf);
for (i = 0; i < data->IMC.dwNumMsgBuf; i++) for (i = 0; i < data->IMC.dwNumMsgBuf; i++)
ImmInternalPostIMEMessage(lpTransMsg[i].message, lpTransMsg[i].wParam, lpTransMsg[i].lParam); ImmInternalPostIMEMessage(data, lpTransMsg[i].message, lpTransMsg[i].wParam, lpTransMsg[i].lParam);
ImmUnlockIMCC(data->IMC.hMsgBuf); ImmUnlockIMCC(data->IMC.hMsgBuf);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment