Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
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-cw
Commits
a30b9465
Commit
a30b9465
authored
Apr 29, 2010
by
Alexandre Goujon
Committed by
Alexandre Julliard
May 04, 2010
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
winex11: Use XkbKeycodeToKeysym when using XKB.
parent
262869ce
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
15 additions
and
7 deletions
+15
-7
keyboard.c
dlls/winex11.drv/keyboard.c
+15
-7
No files found.
dlls/winex11.drv/keyboard.c
View file @
a30b9465
...
@@ -1107,6 +1107,14 @@ static const WORD xfree86_vendor_key_vkey[256] =
...
@@ -1107,6 +1107,14 @@ static const WORD xfree86_vendor_key_vkey[256] =
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
/* 1008FFF8 */
0
,
0
,
0
,
0
,
0
,
0
,
0
,
0
/* 1008FFF8 */
};
};
static
inline
KeySym
keycode_to_keysym
(
Display
*
display
,
KeyCode
keycode
,
int
index
)
{
#ifdef HAVE_XKB
if
(
use_xkb
)
return
XkbKeycodeToKeysym
(
display
,
keycode
,
0
,
index
);
#endif
return
XKeycodeToKeysym
(
display
,
keycode
,
index
);
}
/* Returns the Windows virtual key code associated with the X event <e> */
/* Returns the Windows virtual key code associated with the X event <e> */
/* x11 lock must be held */
/* x11 lock must be held */
static
WORD
EVENT_event_to_vkey
(
XIC
xic
,
XKeyEvent
*
e
)
static
WORD
EVENT_event_to_vkey
(
XIC
xic
,
XKeyEvent
*
e
)
...
@@ -1505,7 +1513,7 @@ X11DRV_KEYBOARD_DetectLayout( Display *display )
...
@@ -1505,7 +1513,7 @@ X11DRV_KEYBOARD_DetectLayout( Display *display )
for
(
keyc
=
min_keycode
;
keyc
<=
max_keycode
;
keyc
++
)
{
for
(
keyc
=
min_keycode
;
keyc
<=
max_keycode
;
keyc
++
)
{
/* get data for keycode from X server */
/* get data for keycode from X server */
for
(
i
=
0
;
i
<
syms
;
i
++
)
{
for
(
i
=
0
;
i
<
syms
;
i
++
)
{
if
(
!
(
keysym
=
XKeycodeToK
eysym
(
display
,
keyc
,
i
)))
continue
;
if
(
!
(
keysym
=
keycode_to_k
eysym
(
display
,
keyc
,
i
)))
continue
;
/* Allow both one-byte and two-byte national keysyms */
/* Allow both one-byte and two-byte national keysyms */
if
((
keysym
<
0x8000
)
&&
(
keysym
!=
' '
))
if
((
keysym
<
0x8000
)
&&
(
keysym
!=
' '
))
{
{
...
@@ -1717,12 +1725,12 @@ void X11DRV_InitKeyboard( Display *display )
...
@@ -1717,12 +1725,12 @@ void X11DRV_InitKeyboard( Display *display )
int
k
;
int
k
;
for
(
k
=
0
;
k
<
keysyms_per_keycode
;
k
+=
1
)
for
(
k
=
0
;
k
<
keysyms_per_keycode
;
k
+=
1
)
if
(
XKeycodeToK
eysym
(
display
,
*
kcp
,
k
)
==
XK_Num_Lock
)
if
(
keycode_to_k
eysym
(
display
,
*
kcp
,
k
)
==
XK_Num_Lock
)
{
{
NumLockMask
=
1
<<
i
;
NumLockMask
=
1
<<
i
;
TRACE_
(
key
)(
"NumLockMask is %x
\n
"
,
NumLockMask
);
TRACE_
(
key
)(
"NumLockMask is %x
\n
"
,
NumLockMask
);
}
}
else
if
(
XKeycodeToK
eysym
(
display
,
*
kcp
,
k
)
==
XK_Scroll_Lock
)
else
if
(
keycode_to_k
eysym
(
display
,
*
kcp
,
k
)
==
XK_Scroll_Lock
)
{
{
ScrollLockMask
=
1
<<
i
;
ScrollLockMask
=
1
<<
i
;
TRACE_
(
key
)(
"ScrollLockMask is %x
\n
"
,
ScrollLockMask
);
TRACE_
(
key
)(
"ScrollLockMask is %x
\n
"
,
ScrollLockMask
);
...
@@ -1774,7 +1782,7 @@ void X11DRV_InitKeyboard( Display *display )
...
@@ -1774,7 +1782,7 @@ void X11DRV_InitKeyboard( Display *display )
/* we seem to need to search the layout-dependent scancodes */
/* we seem to need to search the layout-dependent scancodes */
int
maxlen
=
0
,
maxval
=-
1
,
ok
;
int
maxlen
=
0
,
maxval
=-
1
,
ok
;
for
(
i
=
0
;
i
<
syms
;
i
++
)
{
for
(
i
=
0
;
i
<
syms
;
i
++
)
{
keysym
=
XKeycodeToK
eysym
(
display
,
keyc
,
i
);
keysym
=
keycode_to_k
eysym
(
display
,
keyc
,
i
);
if
((
keysym
<
0x8000
)
&&
(
keysym
!=
' '
))
if
((
keysym
<
0x8000
)
&&
(
keysym
!=
' '
))
{
{
#ifdef HAVE_XKB
#ifdef HAVE_XKB
...
@@ -1926,7 +1934,7 @@ void X11DRV_InitKeyboard( Display *display )
...
@@ -1926,7 +1934,7 @@ void X11DRV_InitKeyboard( Display *display )
for
(
scan
=
0x60
,
keyc
=
min_keycode
;
keyc
<=
max_keycode
;
keyc
++
)
for
(
scan
=
0x60
,
keyc
=
min_keycode
;
keyc
<=
max_keycode
;
keyc
++
)
if
(
keyc2vkey
[
keyc
]
&&!
keyc2scan
[
keyc
])
{
if
(
keyc2vkey
[
keyc
]
&&!
keyc2scan
[
keyc
])
{
const
char
*
ksname
;
const
char
*
ksname
;
keysym
=
XKeycodeToK
eysym
(
display
,
keyc
,
0
);
keysym
=
keycode_to_k
eysym
(
display
,
keyc
,
0
);
ksname
=
XKeysymToString
(
keysym
);
ksname
=
XKeysymToString
(
keysym
);
if
(
!
ksname
)
ksname
=
"NoSymbol"
;
if
(
!
ksname
)
ksname
=
"NoSymbol"
;
...
@@ -2130,7 +2138,7 @@ SHORT CDECL X11DRV_VkKeyScanEx(WCHAR wChar, HKL hkl)
...
@@ -2130,7 +2138,7 @@ SHORT CDECL X11DRV_VkKeyScanEx(WCHAR wChar, HKL hkl)
wine_tsx11_lock
();
wine_tsx11_lock
();
for
(
i
=
0
;
i
<
4
;
i
++
)
/* find shift state */
for
(
i
=
0
;
i
<
4
;
i
++
)
/* find shift state */
{
{
if
(
XKeycodeToK
eysym
(
display
,
keycode
,
i
)
==
keysym
)
if
(
keycode_to_k
eysym
(
display
,
keycode
,
i
)
==
keysym
)
{
{
index
=
i
;
index
=
i
;
break
;
break
;
...
@@ -2384,7 +2392,7 @@ INT CDECL X11DRV_GetKeyNameText(LONG lParam, LPWSTR lpBuffer, INT nSize)
...
@@ -2384,7 +2392,7 @@ INT CDECL X11DRV_GetKeyNameText(LONG lParam, LPWSTR lpBuffer, INT nSize)
{
{
wine_tsx11_lock
();
wine_tsx11_lock
();
keyc
=
(
KeyCode
)
keyi
;
keyc
=
(
KeyCode
)
keyi
;
keys
=
XKeycodeToK
eysym
(
display
,
keyc
,
0
);
keys
=
keycode_to_k
eysym
(
display
,
keyc
,
0
);
name
=
XKeysymToString
(
keys
);
name
=
XKeysymToString
(
keys
);
wine_tsx11_unlock
();
wine_tsx11_unlock
();
TRACE
(
"found scan=%04x keyc=%u keysym=%04x string=%s
\n
"
,
TRACE
(
"found scan=%04x keyc=%u keysym=%04x string=%s
\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