Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
904ddc7e
Commit
904ddc7e
authored
Apr 01, 2023
by
Rémi Bernon
Committed by
Alexandre Julliard
Apr 05, 2023
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
winex11: Add a helper to get COMPOSITIONSTRING text.
parent
b869270b
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
33 additions
and
27 deletions
+33
-27
ime.c
dlls/winex11.drv/ime.c
+33
-27
No files found.
dlls/winex11.drv/ime.c
View file @
904ddc7e
...
@@ -70,6 +70,27 @@ static UINT WM_MSIME_RECONVERT;
...
@@ -70,6 +70,27 @@ static UINT WM_MSIME_RECONVERT;
static
UINT
WM_MSIME_QUERYPOSITION
;
static
UINT
WM_MSIME_QUERYPOSITION
;
static
UINT
WM_MSIME_DOCUMENTFEED
;
static
UINT
WM_MSIME_DOCUMENTFEED
;
static
WCHAR
*
input_context_get_comp_str
(
INPUTCONTEXT
*
ctx
,
BOOL
result
,
UINT
*
length
)
{
COMPOSITIONSTRING
*
string
;
WCHAR
*
text
=
NULL
;
UINT
len
,
off
;
if
(
!
(
string
=
ImmLockIMCC
(
ctx
->
hCompStr
)))
return
NULL
;
len
=
result
?
string
->
dwResultStrLen
:
string
->
dwCompStrLen
;
off
=
result
?
string
->
dwResultStrOffset
:
string
->
dwCompStrOffset
;
if
(
len
&&
off
&&
(
text
=
malloc
(
(
len
+
1
)
*
sizeof
(
WCHAR
)
)))
{
memcpy
(
text
,
(
BYTE
*
)
string
+
off
,
len
*
sizeof
(
WCHAR
)
);
text
[
len
]
=
0
;
*
length
=
len
;
}
ImmUnlockIMCC
(
ctx
->
hCompStr
);
return
text
;
}
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
);
...
@@ -659,11 +680,9 @@ BOOL WINAPI NotifyIME(HIMC hIMC, DWORD dwAction, DWORD dwIndex, DWORD dwValue)
...
@@ -659,11 +680,9 @@ BOOL WINAPI NotifyIME(HIMC hIMC, DWORD dwAction, DWORD dwIndex, DWORD dwValue)
case
CPS_COMPLETE
:
case
CPS_COMPLETE
:
{
{
HIMCC
newCompStr
;
HIMCC
newCompStr
;
DWORD
cplen
=
0
;
LPWSTR
cpstr
;
LPCOMPOSITIONSTRING
cs
=
NULL
;
LPBYTE
cdata
=
NULL
;
LPIMEPRIVATE
myPrivate
;
LPIMEPRIVATE
myPrivate
;
WCHAR
*
str
;
UINT
len
;
TRACE
(
"CPS_COMPLETE
\n
"
);
TRACE
(
"CPS_COMPLETE
\n
"
);
...
@@ -673,20 +692,12 @@ BOOL WINAPI NotifyIME(HIMC hIMC, DWORD dwAction, DWORD dwIndex, DWORD dwValue)
...
@@ -673,20 +692,12 @@ BOOL WINAPI NotifyIME(HIMC hIMC, DWORD dwAction, DWORD dwIndex, DWORD dwValue)
ImmDestroyIMCC
(
lpIMC
->
hCompStr
);
ImmDestroyIMCC
(
lpIMC
->
hCompStr
);
lpIMC
->
hCompStr
=
newCompStr
;
lpIMC
->
hCompStr
=
newCompStr
;
if
(
lpIMC
->
hCompStr
)
{
cdata
=
ImmLockIMCC
(
lpIMC
->
hCompStr
);
cs
=
(
LPCOMPOSITIONSTRING
)
cdata
;
cplen
=
cs
->
dwCompStrLen
;
cpstr
=
(
LPWSTR
)
&
(
cdata
[
cs
->
dwCompStrOffset
]);
ImmUnlockIMCC
(
lpIMC
->
hCompStr
);
}
myPrivate
=
ImmLockIMCC
(
lpIMC
->
hPrivate
);
myPrivate
=
ImmLockIMCC
(
lpIMC
->
hPrivate
);
if
(
cplen
>
0
)
if
(
(
str
=
input_context_get_comp_str
(
lpIMC
,
FALSE
,
&
len
))
)
{
{
WCHAR
param
=
cp
str
[
0
];
WCHAR
param
=
str
[
0
];
newCompStr
=
updateResultStr
(
lpIMC
->
hCompStr
,
cpstr
,
cplen
);
newCompStr
=
updateResultStr
(
lpIMC
->
hCompStr
,
str
,
len
);
ImmDestroyIMCC
(
lpIMC
->
hCompStr
);
ImmDestroyIMCC
(
lpIMC
->
hCompStr
);
lpIMC
->
hCompStr
=
newCompStr
;
lpIMC
->
hCompStr
=
newCompStr
;
newCompStr
=
updateCompStr
(
lpIMC
->
hCompStr
,
NULL
,
0
);
newCompStr
=
updateCompStr
(
lpIMC
->
hCompStr
,
NULL
,
0
);
...
@@ -700,6 +711,7 @@ BOOL WINAPI NotifyIME(HIMC hIMC, DWORD dwAction, DWORD dwIndex, DWORD dwValue)
...
@@ -700,6 +711,7 @@ BOOL WINAPI NotifyIME(HIMC hIMC, DWORD dwAction, DWORD dwIndex, DWORD dwValue)
GCS_RESULTSTR
|
GCS_RESULTCLAUSE
);
GCS_RESULTSTR
|
GCS_RESULTCLAUSE
);
GenerateIMEMessage
(
hIMC
,
WM_IME_ENDCOMPOSITION
,
0
,
0
);
GenerateIMEMessage
(
hIMC
,
WM_IME_ENDCOMPOSITION
,
0
,
0
);
free
(
str
);
}
}
else
if
(
myPrivate
->
bInComposition
)
else
if
(
myPrivate
->
bInComposition
)
GenerateIMEMessage
(
hIMC
,
WM_IME_ENDCOMPOSITION
,
0
,
0
);
GenerateIMEMessage
(
hIMC
,
WM_IME_ENDCOMPOSITION
,
0
,
0
);
...
@@ -980,12 +992,12 @@ static void PaintDefaultIMEWnd(HIMC hIMC, HWND hwnd)
...
@@ -980,12 +992,12 @@ static void PaintDefaultIMEWnd(HIMC hIMC, HWND hwnd)
PAINTSTRUCT
ps
;
PAINTSTRUCT
ps
;
RECT
rect
;
RECT
rect
;
HDC
hdc
;
HDC
hdc
;
LPCOMPOSITIONSTRING
compstr
;
LPBYTE
compdata
=
NULL
;
HMONITOR
monitor
;
HMONITOR
monitor
;
MONITORINFO
mon_info
;
MONITORINFO
mon_info
;
INT
offX
=
0
,
offY
=
0
;
INT
offX
=
0
,
offY
=
0
;
LPINPUTCONTEXT
lpIMC
;
LPINPUTCONTEXT
lpIMC
;
WCHAR
*
str
;
UINT
len
;
lpIMC
=
ImmLockIMC
(
hIMC
);
lpIMC
=
ImmLockIMC
(
hIMC
);
if
(
lpIMC
==
NULL
)
if
(
lpIMC
==
NULL
)
...
@@ -996,18 +1008,13 @@ static void PaintDefaultIMEWnd(HIMC hIMC, HWND hwnd)
...
@@ -996,18 +1008,13 @@ static void PaintDefaultIMEWnd(HIMC hIMC, HWND hwnd)
GetClientRect
(
hwnd
,
&
rect
);
GetClientRect
(
hwnd
,
&
rect
);
FillRect
(
hdc
,
&
rect
,
(
HBRUSH
)(
COLOR_WINDOW
+
1
));
FillRect
(
hdc
,
&
rect
,
(
HBRUSH
)(
COLOR_WINDOW
+
1
));
compdata
=
ImmLockIMCC
(
lpIMC
->
hCompStr
);
if
((
str
=
input_context_get_comp_str
(
lpIMC
,
FALSE
,
&
len
)))
compstr
=
(
LPCOMPOSITIONSTRING
)
compdata
;
if
(
compstr
->
dwCompStrLen
&&
compstr
->
dwCompStrOffset
)
{
{
SIZE
size
;
SIZE
size
;
POINT
pt
;
POINT
pt
;
HFONT
oldfont
=
NULL
;
HFONT
oldfont
=
NULL
;
LPWSTR
CompString
;
LPIMEPRIVATE
myPrivate
;
LPIMEPRIVATE
myPrivate
;
CompString
=
(
LPWSTR
)(
compdata
+
compstr
->
dwCompStrOffset
);
myPrivate
=
ImmLockIMCC
(
lpIMC
->
hPrivate
);
myPrivate
=
ImmLockIMCC
(
lpIMC
->
hPrivate
);
if
(
myPrivate
->
textfont
)
if
(
myPrivate
->
textfont
)
...
@@ -1015,7 +1022,7 @@ static void PaintDefaultIMEWnd(HIMC hIMC, HWND hwnd)
...
@@ -1015,7 +1022,7 @@ static void PaintDefaultIMEWnd(HIMC hIMC, HWND hwnd)
ImmUnlockIMCC
(
lpIMC
->
hPrivate
);
ImmUnlockIMCC
(
lpIMC
->
hPrivate
);
GetTextExtentPoint32W
(
hdc
,
CompString
,
compstr
->
dwCompStrLen
,
&
size
);
GetTextExtentPoint32W
(
hdc
,
str
,
len
,
&
size
);
pt
.
x
=
size
.
cx
;
pt
.
x
=
size
.
cx
;
pt
.
y
=
size
.
cy
;
pt
.
y
=
size
.
cy
;
LPtoDP
(
hdc
,
&
pt
,
1
);
LPtoDP
(
hdc
,
&
pt
,
1
);
...
@@ -1092,14 +1099,13 @@ static void PaintDefaultIMEWnd(HIMC hIMC, HWND hwnd)
...
@@ -1092,14 +1099,13 @@ static void PaintDefaultIMEWnd(HIMC hIMC, HWND hwnd)
SetWindowPos
(
hwnd
,
HWND_TOPMOST
,
rect
.
left
,
rect
.
top
,
rect
.
right
-
rect
.
left
,
rect
.
bottom
-
rect
.
top
,
SWP_NOACTIVATE
);
SetWindowPos
(
hwnd
,
HWND_TOPMOST
,
rect
.
left
,
rect
.
top
,
rect
.
right
-
rect
.
left
,
rect
.
bottom
-
rect
.
top
,
SWP_NOACTIVATE
);
TextOutW
(
hdc
,
offX
,
offY
,
CompString
,
compstr
->
dwCompStrLen
);
TextOutW
(
hdc
,
offX
,
offY
,
str
,
len
);
if
(
oldfont
)
if
(
oldfont
)
SelectObject
(
hdc
,
oldfont
);
SelectObject
(
hdc
,
oldfont
);
free
(
str
);
}
}
ImmUnlockIMCC
(
lpIMC
->
hCompStr
);
EndPaint
(
hwnd
,
&
ps
);
EndPaint
(
hwnd
,
&
ps
);
ImmUnlockIMC
(
hIMC
);
ImmUnlockIMC
(
hIMC
);
}
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment