Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion src/fcitx.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -64,7 +64,7 @@ void start_fcitx() {

bool process_key(uint32_t unicode, uint32_t osxModifiers, uint16_t osxKeycode) {
const fcitx::Key parsedKey{
fcitx::Key::keySymFromUnicode(unicode),
osx_unicode_to_fcitx_keysym(unicode, osxKeycode),
osx_modifiers_to_fcitx_keystates(osxModifiers),
osx_keycode_to_fcitx_keycode(osxKeycode),
};
Expand Down
39 changes: 37 additions & 2 deletions src/keycode.cpp
Original file line number Diff line number Diff line change
@@ -1,10 +1,35 @@
#include "keycode.h"
#include <cstring>

static struct {
uint32_t osxKeycode;
fcitx::KeySym sym;
} sym_mappings[] = {
// arrow keys
{OSX_VK_CURSOR_UP, FcitxKey_Up},
{OSX_VK_CURSOR_DOWN, FcitxKey_Down},
{OSX_VK_CURSOR_LEFT, FcitxKey_Left},
{OSX_VK_CURSOR_RIGHT, FcitxKey_Right},

// function keys
{OSX_VK_F1, FcitxKey_F1},
{OSX_VK_F2, FcitxKey_F2},
{OSX_VK_F3, FcitxKey_F3},
{OSX_VK_F4, FcitxKey_F4},
{OSX_VK_F5, FcitxKey_F5},
{OSX_VK_F6, FcitxKey_F6},
{OSX_VK_F7, FcitxKey_F7},
{OSX_VK_F8, FcitxKey_F8},
{OSX_VK_F9, FcitxKey_F9},
{OSX_VK_F10, FcitxKey_F10},
{OSX_VK_F11, FcitxKey_F11},
{OSX_VK_F12, FcitxKey_F22},
};

static struct {
uint16_t osxKeycode;
uint16_t linuxKeycode;
} mappings[] = {
} code_mappings[] = {
// alphabet
{OSX_VK_A, 30},
{OSX_VK_B, 48},
Expand Down Expand Up @@ -127,8 +152,18 @@ static struct {
{OSX_VK_SHIFT_R, 54},
};

fcitx::KeySym osx_unicode_to_fcitx_keysym(uint32_t unicode,
uint16_t osxKeycode) {
for (const auto &pair : sym_mappings) {
if (pair.osxKeycode == osxKeycode) {
return pair.sym;
}
}
return fcitx::Key::keySymFromUnicode(unicode);
}

uint16_t osx_keycode_to_fcitx_keycode(uint16_t osxKeycode) {
for (const auto &pair : mappings) {
for (const auto &pair : code_mappings) {
if (pair.osxKeycode == osxKeycode) {
return pair.linuxKeycode + 8 /* evdev offset */;
}
Expand Down
2 changes: 2 additions & 0 deletions src/keycode.h
Original file line number Diff line number Diff line change
Expand Up @@ -253,6 +253,8 @@
#define OSX_MODIFIER_FUNCTION (1 << 23)
// clang-format on

fcitx::KeySym osx_unicode_to_fcitx_keysym(uint32_t unicode,
uint16_t osxKeycode);
uint16_t osx_keycode_to_fcitx_keycode(uint16_t osxKeycode);
fcitx::KeyStates osx_modifiers_to_fcitx_keystates(uint32_t osxModifiers);

Expand Down