xenocara/dist/xkeyboard-config/compat
2011-03-12 10:16:01 +00:00
..
accessx Import xkeyboard-config version 1.6. 2009-06-06 17:52:23 +00:00
basic Import xkeyboard-config version 1.6. 2009-06-06 17:52:23 +00:00
caps Update xkeyboard-config to 2.0 2011-01-10 14:25:56 +00:00
compat.dir Update xkeyboard-config to 2.0 2011-01-10 14:25:56 +00:00
complete Update xkeyboard-config to 2.1 2011-03-12 10:16:01 +00:00
default Update xkeyboard-config to 2.1 2011-03-12 10:16:01 +00:00
iso9995 Import xkeyboard-config version 1.6. 2009-06-06 17:52:23 +00:00
japan Import xkeyboard-config version 1.6. 2009-06-06 17:52:23 +00:00
keypad Import xkeyboard-config version 1.6. 2009-06-06 17:52:23 +00:00
ledcaps Import xkeyboard-config version 1.6. 2009-06-06 17:52:23 +00:00
lednum Import xkeyboard-config version 1.6. 2009-06-06 17:52:23 +00:00
ledscroll Import xkeyboard-config version 1.6. 2009-06-06 17:52:23 +00:00
level5 Update xkeyboard-config to 2.0 2011-01-10 14:25:56 +00:00
Makefile.am Update xkeyboard-config to 2.0 2011-01-10 14:25:56 +00:00
Makefile.in Update xkeyboard-config to 2.0 2011-01-10 14:25:56 +00:00
misc Update xkeyboard-config to 2.1 2011-03-12 10:16:01 +00:00
mousekeys Import xkeyboard-config version 1.6. 2009-06-06 17:52:23 +00:00
norepeat Import xkeyboard-config version 1.6. 2009-06-06 17:52:23 +00:00
olpc Import xkeyboard-config version 1.6. 2009-06-06 17:52:23 +00:00
pc Import xkeyboard-config version 1.6. 2009-06-06 17:52:23 +00:00
pc98 Import xkeyboard-config version 1.6. 2009-06-06 17:52:23 +00:00
README Import xkeyboard-config version 1.6. 2009-06-06 17:52:23 +00:00
xfree86 Import xkeyboard-config version 1.6. 2009-06-06 17:52:23 +00:00
xtest Import xkeyboard-config version 1.6. 2009-06-06 17:52:23 +00:00

The core protocol interpretation of keyboard modifiers does not include direct
support for multiple keyboard groups, so XKB reports the effective keyboard
group to XKB-aware clients using some of reserved bits in the state field of
some core protocol events. This modified state field would not be interpreted
correctly by XKB-unaware clients, so XKB provides a group compatibility mapping
which remaps the keyboard group into a core modifier mask that has similar
effects, when possible.

XKB maintains three compatibility state components that are used to make
XKB-unaware clients(*) work as well as possible:
- The compatibility state which corresponds to the effective modifier and
  effective group state.
- The compatibility lookup state which is the core-protocol equivalent of the
  lookup state.
- The compatibility grab state which is the nearest core-protocol equivalent
  of the grab state.

Compatibility state are essentially the corresponding XKB states, but with
keyboard group possibly encoded as one or more modifiers. 

Modifiers that correspond to each keyboard group are described in this
group compatibility map.


----
(*) The implementation of XKB invisibly extends the X library to use the
keyboard extension if it is present. That means, clients that use library or
toolkit routines to interpret keyboard events automatically use all of XKB
features; clients that directly interpret the state field of core protocol
events or the keymap direcly may be affected by some of the XKB differences.
Thus most clients can take all advantages without modification but it also
means that XKB state can be reported to clients that have not explicitly
requested the keyboard extension.