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
ca97db75
Commit
ca97db75
authored
Mar 27, 2023
by
Rémi Bernon
Committed by
Alexandre Julliard
Mar 28, 2023
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
imm32/tests: Check current keyboard layout during ime calls.
parent
db5cf9a5
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
48 additions
and
17 deletions
+48
-17
imm32.c
dlls/imm32/tests/imm32.c
+48
-17
No files found.
dlls/imm32/tests/imm32.c
View file @
ca97db75
...
@@ -2489,6 +2489,11 @@ static BOOL todo_IME_DLL_PROCESS_DETACH;
...
@@ -2489,6 +2489,11 @@ static BOOL todo_IME_DLL_PROCESS_DETACH;
DEFINE_EXPECT
(
IME_DLL_PROCESS_DETACH
);
DEFINE_EXPECT
(
IME_DLL_PROCESS_DETACH
);
static
IMEINFO
ime_info
;
static
IMEINFO
ime_info
;
static
UINT
ime_count
;
static
WCHAR
ime_path
[
MAX_PATH
];
static
HIMC
default_himc
;
static
HKL
default_hkl
;
static
HKL
expect_ime
=
(
HKL
)(
int
)
0xe020047f
;
enum
ime_function
enum
ime_function
{
{
...
@@ -2498,8 +2503,9 @@ enum ime_function
...
@@ -2498,8 +2503,9 @@ enum ime_function
struct
ime_call
struct
ime_call
{
{
enum
ime_function
func
;
HKL
hkl
;
HIMC
himc
;
HIMC
himc
;
enum
ime_function
func
;
union
union
{
{
...
@@ -2526,6 +2532,7 @@ static void ok_call_( const char *file, int line, const struct ime_call *expecte
...
@@ -2526,6 +2532,7 @@ static void ok_call_( const char *file, int line, const struct ime_call *expecte
if
((
ret
=
expected
->
func
-
received
->
func
))
goto
done
;
if
((
ret
=
expected
->
func
-
received
->
func
))
goto
done
;
if
((
ret
=
(
UINT_PTR
)
expected
->
himc
-
(
UINT_PTR
)
received
->
himc
))
goto
done
;
if
((
ret
=
(
UINT_PTR
)
expected
->
himc
-
(
UINT_PTR
)
received
->
himc
))
goto
done
;
if
((
ret
=
(
UINT
)(
UINT_PTR
)
expected
->
hkl
-
(
UINT
)(
UINT_PTR
)
received
->
hkl
))
goto
done
;
switch
(
expected
->
func
)
switch
(
expected
->
func
)
{
{
case
IME_SELECT
:
case
IME_SELECT
:
...
@@ -2543,12 +2550,12 @@ done:
...
@@ -2543,12 +2550,12 @@ done:
{
{
case
IME_SELECT
:
case
IME_SELECT
:
todo_wine_if
(
expected
->
todo
)
todo_wine_if
(
expected
->
todo
)
ok_
(
file
,
line
)(
!
ret
,
"got
IME_SELECT himc %p, select %u
\n
"
,
received
->
himc
,
received
->
select
);
ok_
(
file
,
line
)(
!
ret
,
"got
hkl %p, himc %p, IME_SELECT select %u
\n
"
,
received
->
hkl
,
received
->
himc
,
received
->
select
);
return
;
return
;
case
IME_NOTIFY
:
case
IME_NOTIFY
:
todo_wine_if
(
expected
->
todo
)
todo_wine_if
(
expected
->
todo
)
ok_
(
file
,
line
)(
!
ret
,
"got
IME_NOTIFY himc %p,
action %#x, index %#x, value %#x
\n
"
,
ok_
(
file
,
line
)(
!
ret
,
"got
hkl %p, himc %p, IME_NOTIFY
action %#x, index %#x, value %#x
\n
"
,
received
->
himc
,
received
->
notify
.
action
,
received
->
notify
.
index
,
received
->
h
kl
,
received
->
h
imc
,
received
->
notify
.
action
,
received
->
notify
.
index
,
received
->
notify
.
value
);
received
->
notify
.
value
);
return
;
return
;
}
}
...
@@ -2557,12 +2564,12 @@ done:
...
@@ -2557,12 +2564,12 @@ done:
{
{
case
IME_SELECT
:
case
IME_SELECT
:
todo_wine_if
(
expected
->
todo
)
todo_wine_if
(
expected
->
todo
)
ok_
(
file
,
line
)(
!
ret
,
"
IME_SELECT himc %p, select %u
\n
"
,
expected
->
himc
,
expected
->
select
);
ok_
(
file
,
line
)(
!
ret
,
"
hkl %p, himc %p, IME_SELECT select %u
\n
"
,
expected
->
hkl
,
expected
->
himc
,
expected
->
select
);
break
;
break
;
case
IME_NOTIFY
:
case
IME_NOTIFY
:
todo_wine_if
(
expected
->
todo
)
todo_wine_if
(
expected
->
todo
)
ok_
(
file
,
line
)(
!
ret
,
"
IME_NOTIFY himc %p,
action %#x, index %#x, value %#x
\n
"
,
ok_
(
file
,
line
)(
!
ret
,
"
hkl %p, himc %p, IME_NOTIFY
action %#x, index %#x, value %#x
\n
"
,
expected
->
himc
,
expected
->
notify
.
action
,
expected
->
notify
.
index
,
expected
->
h
kl
,
expected
->
h
imc
,
expected
->
notify
.
action
,
expected
->
notify
.
index
,
expected
->
notify
.
value
);
expected
->
notify
.
value
);
break
;
break
;
}
}
...
@@ -2638,6 +2645,7 @@ static UINT WINAPI ime_ImeEnumRegisterWord( REGISTERWORDENUMPROCW proc, const WC
...
@@ -2638,6 +2645,7 @@ static UINT WINAPI ime_ImeEnumRegisterWord( REGISTERWORDENUMPROCW proc, const WC
ime_trace
(
"proc %p, reading %s, style %lu, string %s, data %p
\n
"
,
ime_trace
(
"proc %p, reading %s, style %lu, string %s, data %p
\n
"
,
proc
,
debugstr_w
(
reading
),
style
,
debugstr_w
(
string
),
data
);
proc
,
debugstr_w
(
reading
),
style
,
debugstr_w
(
string
),
data
);
ok_eq
(
default_hkl
,
GetKeyboardLayout
(
0
),
HKL
,
"%p"
);
CHECK_EXPECT
(
ImeEnumRegisterWord
);
CHECK_EXPECT
(
ImeEnumRegisterWord
);
if
(
!
style
)
if
(
!
style
)
...
@@ -2666,6 +2674,7 @@ static LRESULT WINAPI ime_ImeEscape( HIMC himc, UINT escape, void *data )
...
@@ -2666,6 +2674,7 @@ static LRESULT WINAPI ime_ImeEscape( HIMC himc, UINT escape, void *data )
{
{
ime_trace
(
"himc %p, escape %#x, data %p
\n
"
,
himc
,
escape
,
data
);
ime_trace
(
"himc %p, escape %#x, data %p
\n
"
,
himc
,
escape
,
data
);
ok_eq
(
default_hkl
,
GetKeyboardLayout
(
0
),
HKL
,
"%p"
);
CHECK_EXPECT
(
ImeEscape
);
CHECK_EXPECT
(
ImeEscape
);
switch
(
escape
)
switch
(
escape
)
...
@@ -2709,6 +2718,7 @@ static UINT WINAPI ime_ImeGetRegisterWordStyle( UINT item, STYLEBUFW *style )
...
@@ -2709,6 +2718,7 @@ static UINT WINAPI ime_ImeGetRegisterWordStyle( UINT item, STYLEBUFW *style )
{
{
ime_trace
(
"item %u, style %p
\n
"
,
item
,
style
);
ime_trace
(
"item %u, style %p
\n
"
,
item
,
style
);
ok_eq
(
default_hkl
,
GetKeyboardLayout
(
0
),
HKL
,
"%p"
);
CHECK_EXPECT
(
ImeGetRegisterWordStyle
);
CHECK_EXPECT
(
ImeGetRegisterWordStyle
);
if
(
!
style
)
if
(
!
style
)
...
@@ -2755,6 +2765,7 @@ static BOOL WINAPI ime_ImeProcessKey( HIMC himc, UINT vkey, LPARAM key_data, BYT
...
@@ -2755,6 +2765,7 @@ static BOOL WINAPI ime_ImeProcessKey( HIMC himc, UINT vkey, LPARAM key_data, BYT
{
{
ime_trace
(
"himc %p, vkey %u, key_data %#Ix, key_state %p
\n
"
,
ime_trace
(
"himc %p, vkey %u, key_data %#Ix, key_state %p
\n
"
,
himc
,
vkey
,
key_data
,
key_state
);
himc
,
vkey
,
key_data
,
key_state
);
ok_eq
(
default_hkl
,
GetKeyboardLayout
(
0
),
HKL
,
"%p"
);
ok
(
0
,
"unexpected call
\n
"
);
ok
(
0
,
"unexpected call
\n
"
);
return
FALSE
;
return
FALSE
;
}
}
...
@@ -2763,6 +2774,7 @@ static BOOL WINAPI ime_ImeRegisterWord( const WCHAR *reading, DWORD style, const
...
@@ -2763,6 +2774,7 @@ static BOOL WINAPI ime_ImeRegisterWord( const WCHAR *reading, DWORD style, const
{
{
ime_trace
(
"reading %s, style %lu, string %s
\n
"
,
debugstr_w
(
reading
),
style
,
debugstr_w
(
string
)
);
ime_trace
(
"reading %s, style %lu, string %s
\n
"
,
debugstr_w
(
reading
),
style
,
debugstr_w
(
string
)
);
ok_eq
(
default_hkl
,
GetKeyboardLayout
(
0
),
HKL
,
"%p"
);
CHECK_EXPECT
(
ImeRegisterWord
);
CHECK_EXPECT
(
ImeRegisterWord
);
if
(
style
)
ok_eq
(
0xdeadbeef
,
style
,
UINT
,
"%#x"
);
if
(
style
)
ok_eq
(
0xdeadbeef
,
style
,
UINT
,
"%#x"
);
...
@@ -2782,7 +2794,11 @@ static BOOL WINAPI ime_ImeRegisterWord( const WCHAR *reading, DWORD style, const
...
@@ -2782,7 +2794,11 @@ static BOOL WINAPI ime_ImeRegisterWord( const WCHAR *reading, DWORD style, const
static
BOOL
WINAPI
ime_ImeSelect
(
HIMC
himc
,
BOOL
select
)
static
BOOL
WINAPI
ime_ImeSelect
(
HIMC
himc
,
BOOL
select
)
{
{
struct
ime_call
call
=
{.
func
=
IME_SELECT
,
.
himc
=
himc
,
.
select
=
select
};
struct
ime_call
call
=
{
.
hkl
=
GetKeyboardLayout
(
0
),
.
himc
=
himc
,
.
func
=
IME_SELECT
,
.
select
=
select
};
ime_trace
(
"himc %p, select %d
\n
"
,
himc
,
select
);
ime_trace
(
"himc %p, select %d
\n
"
,
himc
,
select
);
ime_calls
[
ime_call_count
++
]
=
call
;
ime_calls
[
ime_call_count
++
]
=
call
;
return
TRUE
;
return
TRUE
;
...
@@ -2816,6 +2832,7 @@ static BOOL WINAPI ime_ImeUnregisterWord( const WCHAR *reading, DWORD style, con
...
@@ -2816,6 +2832,7 @@ static BOOL WINAPI ime_ImeUnregisterWord( const WCHAR *reading, DWORD style, con
{
{
ime_trace
(
"reading %s, style %lu, string %s
\n
"
,
debugstr_w
(
reading
),
style
,
debugstr_w
(
string
)
);
ime_trace
(
"reading %s, style %lu, string %s
\n
"
,
debugstr_w
(
reading
),
style
,
debugstr_w
(
string
)
);
ok_eq
(
default_hkl
,
GetKeyboardLayout
(
0
),
HKL
,
"%p"
);
CHECK_EXPECT
(
ImeUnregisterWord
);
CHECK_EXPECT
(
ImeUnregisterWord
);
if
(
style
)
ok_eq
(
0xdeadbeef
,
style
,
UINT
,
"%#x"
);
if
(
style
)
ok_eq
(
0xdeadbeef
,
style
,
UINT
,
"%#x"
);
...
@@ -2835,7 +2852,11 @@ static BOOL WINAPI ime_ImeUnregisterWord( const WCHAR *reading, DWORD style, con
...
@@ -2835,7 +2852,11 @@ static BOOL WINAPI ime_ImeUnregisterWord( const WCHAR *reading, DWORD style, con
static
BOOL
WINAPI
ime_NotifyIME
(
HIMC
himc
,
DWORD
action
,
DWORD
index
,
DWORD
value
)
static
BOOL
WINAPI
ime_NotifyIME
(
HIMC
himc
,
DWORD
action
,
DWORD
index
,
DWORD
value
)
{
{
struct
ime_call
call
=
{.
func
=
IME_NOTIFY
,
.
himc
=
himc
,
.
notify
=
{.
action
=
action
,
.
index
=
index
,
.
value
=
value
}};
struct
ime_call
call
=
{
.
hkl
=
GetKeyboardLayout
(
0
),
.
himc
=
himc
,
.
func
=
IME_NOTIFY
,
.
notify
=
{.
action
=
action
,
.
index
=
index
,
.
value
=
value
}
};
ime_trace
(
"himc %p, action %#lx, index %lu, value %lu
\n
"
,
himc
,
action
,
index
,
value
);
ime_trace
(
"himc %p, action %#lx, index %lu, value %lu
\n
"
,
himc
,
action
,
index
,
value
);
ime_calls
[
ime_call_count
++
]
=
call
;
ime_calls
[
ime_call_count
++
]
=
call
;
return
FALSE
;
return
FALSE
;
...
@@ -2886,10 +2907,6 @@ static struct ime_functions ime_functions =
...
@@ -2886,10 +2907,6 @@ static struct ime_functions ime_functions =
ime_DllMain
,
ime_DllMain
,
};
};
static
UINT
ime_count
;
static
WCHAR
ime_path
[
MAX_PATH
];
static
HIMC
default_himc
;
static
HKL
ime_install
(
void
)
static
HKL
ime_install
(
void
)
{
{
WCHAR
buffer
[
MAX_PATH
];
WCHAR
buffer
[
MAX_PATH
];
...
@@ -2930,7 +2947,7 @@ static HKL ime_install(void)
...
@@ -2930,7 +2947,7 @@ static HKL ime_install(void)
"MoveFileW failed, error %lu
\n
"
,
GetLastError
()
);
"MoveFileW failed, error %lu
\n
"
,
GetLastError
()
);
hkl
=
ImmInstallIMEW
(
ime_path
,
L"WineTest IME"
);
hkl
=
ImmInstallIMEW
(
ime_path
,
L"WineTest IME"
);
ok
(
hkl
==
(
HKL
)(
int
)
0xe020047f
,
"ImmInstallIMEW returned %p, error %lu
\n
"
,
hkl
,
GetLastError
()
);
ok
(
hkl
==
expect_ime
,
"ImmInstallIMEW returned %p, error %lu
\n
"
,
hkl
,
GetLastError
()
);
swprintf
(
buffer
,
ARRAY_SIZE
(
buffer
),
L"System
\\
CurrentControlSet
\\
Control
\\
Keyboard Layouts
\\
%08x"
,
hkl
);
swprintf
(
buffer
,
ARRAY_SIZE
(
buffer
),
L"System
\\
CurrentControlSet
\\
Control
\\
Keyboard Layouts
\\
%08x"
,
hkl
);
ret
=
RegOpenKeyW
(
HKEY_LOCAL_MACHINE
,
buffer
,
&
hkey
);
ret
=
RegOpenKeyW
(
HKEY_LOCAL_MACHINE
,
buffer
,
&
hkey
);
...
@@ -3776,13 +3793,25 @@ static void test_ImmActivateLayout(void)
...
@@ -3776,13 +3793,25 @@ static void test_ImmActivateLayout(void)
{
{
const
struct
ime_call
activate_seq
[]
=
const
struct
ime_call
activate_seq
[]
=
{
{
{.
func
=
IME_SELECT
,
.
himc
=
default_himc
,
.
select
=
1
,
.
todo
=
TRUE
},
{
.
hkl
=
expect_ime
,
.
himc
=
default_himc
,
.
func
=
IME_SELECT
,
.
select
=
1
,
.
todo
=
TRUE
,
},
{
0
},
{
0
},
};
};
const
struct
ime_call
deactivate_seq
[]
=
const
struct
ime_call
deactivate_seq
[]
=
{
{
{.
func
=
IME_NOTIFY
,
.
himc
=
default_himc
,
.
notify
=
{.
action
=
NI_COMPOSITIONSTR
,
.
index
=
CPS_CANCEL
,
.
value
=
0
},
.
todo
=
TRUE
},
{
{.
func
=
IME_SELECT
,
.
himc
=
default_himc
,
.
select
=
0
,
.
todo
=
TRUE
},
.
hkl
=
expect_ime
,
.
himc
=
default_himc
,
.
func
=
IME_NOTIFY
,
.
notify
=
{.
action
=
NI_COMPOSITIONSTR
,
.
index
=
CPS_CANCEL
,
.
value
=
0
},
.
todo
=
TRUE
,
},
{
.
hkl
=
default_hkl
,
.
himc
=
default_himc
,
.
func
=
IME_SELECT
,
.
select
=
0
,
.
todo
=
TRUE
,
},
{
0
},
{
0
},
};
};
HKL
hkl
,
old_hkl
=
GetKeyboardLayout
(
0
);
HKL
hkl
,
old_hkl
=
GetKeyboardLayout
(
0
);
...
@@ -3846,6 +3875,8 @@ cleanup:
...
@@ -3846,6 +3875,8 @@ cleanup:
START_TEST
(
imm32
)
START_TEST
(
imm32
)
{
{
default_hkl
=
GetKeyboardLayout
(
0
);
if
(
!
is_ime_enabled
())
if
(
!
is_ime_enabled
())
{
{
win_skip
(
"IME support not implemented
\n
"
);
win_skip
(
"IME support not implemented
\n
"
);
...
...
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