Commit 3739dcd6 authored by Kusanagi Kouichi's avatar Kusanagi Kouichi Committed by Alexandre Julliard

winex11.drv: Simplify X11DRV_ImmSetInternalString.

parent af088286
...@@ -58,112 +58,45 @@ static XIMStyle ximStyle = 0; ...@@ -58,112 +58,45 @@ static XIMStyle ximStyle = 0;
static XIMStyle ximStyleRoot = 0; static XIMStyle ximStyleRoot = 0;
static XIMStyle ximStyleRequest = STYLE_CALLBACK; static XIMStyle ximStyleRequest = STYLE_CALLBACK;
static BOOL X11DRV_ImmSetInternalString(DWORD dwIndex, DWORD dwOffset, static void X11DRV_ImmSetInternalString(DWORD dwOffset,
DWORD selLength, LPWSTR lpComp, DWORD dwCompLen) DWORD selLength, LPWSTR lpComp, DWORD dwCompLen)
{ {
/* Composition strings are edited in chunks */ /* Composition strings are edited in chunks */
unsigned int byte_length = dwCompLen * sizeof(WCHAR); unsigned int byte_length = dwCompLen * sizeof(WCHAR);
unsigned int byte_offset = dwOffset * sizeof(WCHAR); unsigned int byte_offset = dwOffset * sizeof(WCHAR);
unsigned int byte_selection = selLength * sizeof(WCHAR); unsigned int byte_selection = selLength * sizeof(WCHAR);
BOOL rc = FALSE; int byte_expansion = byte_length - byte_selection;
LPBYTE ptr_new;
TRACE("( %i, %i, %d, %p, %d):\n", dwOffset, selLength, dwIndex, lpComp, dwCompLen ); TRACE("( %i, %i, %p, %d):\n", dwOffset, selLength, lpComp, dwCompLen );
if (dwIndex == GCS_COMPSTR) if (byte_expansion + dwCompStringLength >= dwCompStringSize)
{ {
unsigned int i,j; if (CompositionString)
LPBYTE ptr_new; ptr_new = HeapReAlloc(GetProcessHeap(), 0, CompositionString,
LPBYTE ptr_old; dwCompStringSize + byte_expansion);
if ((dwCompLen == 0) && (selLength == 0))
{
/* DO Nothing */
}
/* deletion occurred */
else if ((dwCompLen== 0) && (selLength != 0))
{
if (dwCompStringLength)
{
for (i = 0; i < byte_selection; i++)
{
if (byte_offset+byte_selection+i <
dwCompStringLength)
{
CompositionString[byte_offset + i] =
CompositionString[byte_offset + byte_selection + i];
}
else
CompositionString[byte_offset + i] = 0;
}
/* clean up the end */
dwCompStringLength -= byte_selection;
i = dwCompStringLength;
while (i < dwCompStringSize)
{
CompositionString[i++] = 0;
}
}
}
else else
{ ptr_new = HeapAlloc(GetProcessHeap(), 0,
int byte_expansion = byte_length - byte_selection; dwCompStringSize + byte_expansion);
if (byte_expansion + dwCompStringLength >= dwCompStringSize)
{
if (CompositionString)
CompositionString =
HeapReAlloc(GetProcessHeap(), 0,
CompositionString,
dwCompStringSize +
byte_expansion);
else
CompositionString =
HeapAlloc(GetProcessHeap(), 0, dwCompStringSize +
byte_expansion);
memset(&(CompositionString[dwCompStringSize]), 0,
byte_expansion);
dwCompStringSize += byte_expansion;
}
ptr_new = ((LPBYTE)lpComp);
ptr_old = CompositionString + byte_offset + byte_selection;
dwCompStringLength += byte_expansion;
for (j=0,i = byte_offset; i < dwCompStringSize; i++) if (ptr_new == NULL)
{ {
if (j < byte_length) ERR("Couldn't expand composition string buffer\n");
{ return;
CompositionString[i] = ptr_new[j++];
}
else
{
if (ptr_old < CompositionString + dwCompStringSize)
{
CompositionString[i] = *ptr_old;
ptr_old++;
}
else
CompositionString[i] = 0;
}
}
} }
rc = IME_SetCompositionString(SCS_SETSTR, CompositionString, CompositionString = ptr_new;
dwCompStringLength, NULL, 0); dwCompStringSize += byte_expansion;
} }
else if ((dwIndex == GCS_RESULTSTR) && (lpComp) && (dwCompLen))
{
rc = IME_SetCompositionString(SCS_SETSTR, lpComp,
byte_length, NULL, 0);
IME_NotifyIME( NI_COMPOSITIONSTR, CPS_COMPLETE, 0); ptr_new = CompositionString + byte_offset;
} memmove(ptr_new + byte_length, ptr_new + byte_selection,
dwCompStringLength - byte_offset - byte_selection);
memcpy(ptr_new, lpComp, byte_length);
dwCompStringLength += byte_expansion;
return rc; IME_SetCompositionString(SCS_SETSTR, CompositionString,
dwCompStringLength, NULL, 0);
} }
void X11DRV_XIMLookupChars( const char *str, DWORD count ) void X11DRV_XIMLookupChars( const char *str, DWORD count )
...@@ -172,6 +105,8 @@ void X11DRV_XIMLookupChars( const char *str, DWORD count ) ...@@ -172,6 +105,8 @@ void X11DRV_XIMLookupChars( const char *str, DWORD count )
WCHAR *wcOutput; WCHAR *wcOutput;
HWND focus; HWND focus;
TRACE("%p %u\n", str, count);
dwOutput = MultiByteToWideChar(CP_UNIXCP, 0, str, count, NULL, 0); dwOutput = MultiByteToWideChar(CP_UNIXCP, 0, str, count, NULL, 0);
wcOutput = HeapAlloc(GetProcessHeap(), 0, sizeof(WCHAR) * dwOutput); wcOutput = HeapAlloc(GetProcessHeap(), 0, sizeof(WCHAR) * dwOutput);
if (wcOutput == NULL) if (wcOutput == NULL)
...@@ -181,7 +116,9 @@ void X11DRV_XIMLookupChars( const char *str, DWORD count ) ...@@ -181,7 +116,9 @@ void X11DRV_XIMLookupChars( const char *str, DWORD count )
if ((focus = GetFocus())) if ((focus = GetFocus()))
IME_UpdateAssociation(focus); IME_UpdateAssociation(focus);
X11DRV_ImmSetInternalString(GCS_RESULTSTR,0,0,wcOutput,dwOutput); IME_SetCompositionString(SCS_SETSTR, wcOutput,
sizeof (WCHAR) * dwOutput, NULL, 0);
IME_NotifyIME(NI_COMPOSITIONSTR, CPS_COMPLETE, 0);
HeapFree(GetProcessHeap(), 0, wcOutput); HeapFree(GetProcessHeap(), 0, wcOutput);
} }
...@@ -244,20 +181,20 @@ static void XIMPreEditDrawCallback(XIM ic, XPointer client_data, ...@@ -244,20 +181,20 @@ static void XIMPreEditDrawCallback(XIM ic, XPointer client_data,
/* ignore null */ /* ignore null */
dwOutput --; dwOutput --;
X11DRV_ImmSetInternalString (GCS_COMPSTR, sel, len, wcOutput, dwOutput); X11DRV_ImmSetInternalString (sel, len, wcOutput, dwOutput);
HeapFree(GetProcessHeap(), 0, wcOutput); HeapFree(GetProcessHeap(), 0, wcOutput);
} }
} }
else else
{ {
FIXME("wchar PROBIBILY WRONG\n"); FIXME("wchar PROBIBILY WRONG\n");
X11DRV_ImmSetInternalString (GCS_COMPSTR, sel, len, X11DRV_ImmSetInternalString (sel, len,
(LPWSTR)P_DR->text->string.wide_char, (LPWSTR)P_DR->text->string.wide_char,
P_DR->text->length); P_DR->text->length);
} }
} }
else else
X11DRV_ImmSetInternalString (GCS_COMPSTR, sel, len, NULL, 0); X11DRV_ImmSetInternalString (sel, len, NULL, 0);
IME_SetCursorPos(P_DR->caret); IME_SetCursorPos(P_DR->caret);
} }
TRACE("Finished\n"); TRACE("Finished\n");
......
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