Skip to content

Commit

Permalink
Avoid masking out bits of Windows codes
Browse files Browse the repository at this point in the history
  • Loading branch information
boppreh committed Mar 25, 2018
1 parent 9289aeb commit 14cd6f5
Showing 1 changed file with 6 additions and 6 deletions.
12 changes: 6 additions & 6 deletions keyboard/_winkeyboard.py
Original file line number Diff line number Diff line change
Expand Up @@ -373,9 +373,9 @@ def get_event_names(scan_code, vk, is_extended, modifiers):
if name_ret and name_buffer.value:
yield name_buffer.value

char = chr(user32.MapVirtualKeyW(vk, MAPVK_VK_TO_CHAR) & 0xFF)
if char != '\x00' and char:
yield char
char = user32.MapVirtualKeyW(vk, MAPVK_VK_TO_CHAR) & 0xFF
if char != 0:
yield chr(char)

if not is_keypad and is_official:
yield official_virtual_keys[vk][0]
Expand All @@ -390,8 +390,8 @@ def _setup_name_tables():

# Go through every possible scan code, and map them to virtual key codes.
# Then vice-versa.
all_scan_codes = [(sc, user32.MapVirtualKeyExW(sc, MAPVK_VSC_TO_VK_EX, 0) & 0xFF) for sc in range(0x100)]
all_vks = [(user32.MapVirtualKeyExW(vk, MAPVK_VK_TO_VSC_EX, 0) & 0xFF, vk) for vk in range(0x100)]
all_scan_codes = [(sc, user32.MapVirtualKeyExW(sc, MAPVK_VSC_TO_VK_EX, 0)) for sc in range(0x100)]
all_vks = [(user32.MapVirtualKeyExW(vk, MAPVK_VK_TO_VSC_EX, 0), vk) for vk in range(0x100)]
for scan_code, vk in all_scan_codes + all_vks:
# `to_name` and `from_name` entries will be a tuple (scan_code, vk, extended, shift_state).
if (scan_code, vk, 0, 0, 0) in to_name:
Expand Down Expand Up @@ -521,7 +521,7 @@ def process_key(event_type, vk, scan_code, is_extended):
else:
names = to_name[entry]
name = names[0] if names else None

# TODO: inaccurate when holding multiple different shifts.
if event_type == KEY_DOWN and vk in shift_vks:
shift_is_pressed = True
Expand Down

0 comments on commit 14cd6f5

Please sign in to comment.