Skip to content

Commit

Permalink
Merge pull request #87498 from bruvzg/mac_fix_mod_space_events
Browse files Browse the repository at this point in the history
[macOS] Fix missing modifier + space key down events.
  • Loading branch information
YuriSizov committed Jan 24, 2024
2 parents 6876303 + ce47551 commit 47ec590
Showing 1 changed file with 14 additions and 12 deletions.
26 changes: 14 additions & 12 deletions platform/macos/godot_content_view.mm
Original file line number Diff line number Diff line change
Expand Up @@ -576,21 +576,23 @@ - (void)keyDown:(NSEvent *)event {
String u32text;
u32text.parse_utf16(text.ptr(), text.length());

DisplayServerMacOS::KeyEvent ke;
ke.window_id = window_id;
ke.macos_state = [event modifierFlags];
ke.pressed = true;
ke.echo = [event isARepeat];
ke.keycode = KeyMappingMacOS::remap_key([event keyCode], [event modifierFlags], false);
ke.physical_keycode = KeyMappingMacOS::translate_key([event keyCode]);
ke.key_label = KeyMappingMacOS::remap_key([event keyCode], [event modifierFlags], true);
ke.raw = true;

if (u32text.is_empty()) {
ke.unicode = 0;
ds->push_to_key_event_buffer(ke);
}
for (int i = 0; i < u32text.length(); i++) {
const char32_t codepoint = u32text[i];

DisplayServerMacOS::KeyEvent ke;

ke.window_id = window_id;
ke.macos_state = [event modifierFlags];
ke.pressed = true;
ke.echo = [event isARepeat];
ke.keycode = KeyMappingMacOS::remap_key([event keyCode], [event modifierFlags], false);
ke.physical_keycode = KeyMappingMacOS::translate_key([event keyCode]);
ke.key_label = KeyMappingMacOS::remap_key([event keyCode], [event modifierFlags], true);
ke.unicode = fix_unicode(codepoint);
ke.raw = true;

ds->push_to_key_event_buffer(ke);
}
} else {
Expand Down

0 comments on commit 47ec590

Please sign in to comment.