Некоторые приложения X принимают мои нелатинские символы, некоторые игнорируют их
Я использую среду X с двойной раскладкой клавиатуры: us,il
, Теперь, в некоторых из моих приложений, и в il
макет, ивритские символы не регистрируются, а знаки препинания -. В других приложениях ивритские символы хорошо регистрируются и добавляются к любому тексту, который я набираю. Английская раскладка отлично работает. Я предоставлю полную информацию о моей конфигурации ниже.
Мои вопросы: почему это происходит? И что еще более важно, как я могу это исправить / обойти и заставить все приложения также принимать ивритские символы?
Подробности о моей настройке
- Физическая раскладка клавиатуры: стандартная US 104-клавишная (как эта).
- Распространение ОС: Devuan 2.0 ASCII (~ = Debian 9.0 Stretch)
Конфигурация XKB:
$ setxkbmap -query rules: evdev model: pc105 layout: us,il variant: , options: grp:alt_shift_toggle,grp_led:scroll
Окружение рабочего стола: это происходит со мной как с Cinnamon, так и с LXQt; еще не пробовал других.
- Приложения, отклоняющие ивритские символы: Cinnamon's Alt + F2 launcher; Leafpad; GEdit, xterm.
- Приложения, принимающие ивритские символы: KWrite, GNOME Terminal, LibreOffice, Firefox, Kolourpaint, lxterminal, Konsole.
xev
выход
Вывод при нажатии a
на клавиатуре:
KeyRelease event, serial 34, synthetic NO, window 0x7e00001,
root 0x43, subw 0x0, time 369470632, (96,-25), root:(146,62),
state 0x0, keycode 38 (keysym 0x61, a), same_screen YES,
XLookupString gives 1 bytes: (61) "a"
XFilterEvent returns: False
KeyPress event, serial 34, synthetic NO, window 0x7e00001,
root 0x43, subw 0x0, time 369474392, (96,-25), root:(146,62),
state 0x0, keycode 38 (keysym 0x61, a), same_screen YES,
XLookupString gives 1 bytes: (61) "a"
XFilterEvent returns: False
Выход при переключении раскладки клавиатуры:
KeyPress event, serial 34, synthetic NO, window 0x7e00001,
root 0x43, subw 0x0, time 369547896, (75,-23), root:(125,64),
state 0x0, keycode 64 (keysym 0xffe9, Alt_L), same_screen YES,
XLookupString gives 0 bytes:
XFilterEvent returns: False
KeyPress event, serial 34, synthetic NO, window 0x7e00001,
root 0x43, subw 0x0, time 369548008, (75,-23), root:(125,64),
state 0x8, keycode 62 (keysym 0xfe08, ISO_Next_Group), same_screen YES,
XKeysymToKeycode returns keycode: 50
XLookupString gives 0 bytes:
XFilterEvent returns: False
PropertyNotify event, serial 34, synthetic NO, window 0x7e00001,
atom 0x176 (XKLAVIER_STATE), time 369548013, state PropertyNewValue
PropertyNotify event, serial 34, synthetic NO, window 0x7e00001,
atom 0x176 (XKLAVIER_STATE), time 369548013, state PropertyNewValue
KeyRelease event, serial 34, synthetic NO, window 0x7e00001,
root 0x43, subw 0x0, time 369548072, (75,-23), root:(125,64),
state 0x2008, keycode 62 (keysym 0xfe08, ISO_Next_Group), same_screen YES,
XKeysymToKeycode returns keycode: 50
XLookupString gives 0 bytes:
XFilterEvent returns: False
KeyRelease event, serial 34, synthetic NO, window 0x7e00001,
root 0x43, subw 0x0, time 369548168, (75,-23), root:(125,64),
state 0x2008, keycode 64 (keysym 0xffe9, Alt_L), same_screen YES,
XLookupString gives 0 bytes:
XFilterEvent returns: False
Вывод при нажатии a
снова на клавиатуре (эта клавиша также соответствует букве иврита,,):
KeyPress event, serial 34, synthetic NO, window 0x7e00001,
root 0x43, subw 0x0, time 369560440, (75,-23), root:(125,64),
state 0x2000, keycode 38 (keysym 0xcf9, hebrew_shin), same_screen YES,
XLookupString gives 0 bytes:
XFilterEvent returns: False
KeyRelease event, serial 34, synthetic NO, window 0x7e00001,
root 0x43, subw 0x0, time 369560504, (75,-23), root:(125,64),
state 0x2000, keycode 38 (keysym 0xcf9, hebrew_shin), same_screen YES,
XLookupString gives 0 bytes:
XFilterEvent returns: False
xmodmap -pke
выход
Часть вывода xmodmap -pke
:
... etc. etc. ...
keycode 24 = q Q slash Q U05C2
keycode 25 = w W apostrophe W U05C1
keycode 26 = e E hebrew_qoph E U05B8
keycode 27 = r R hebrew_resh R U05B3
keycode 28 = t T hebrew_aleph T
keycode 29 = y Y hebrew_tet Y U05F0
keycode 30 = u U hebrew_waw U U05B9
keycode 31 = i I hebrew_finalnun I
keycode 32 = o O hebrew_finalmem O
keycode 33 = p P hebrew_pe P U05B7
keycode 34 = bracketleft braceleft bracketright braceright U05B2
keycode 35 = bracketright braceright bracketleft braceleft U05BF
keycode 36 = Return NoSymbol Return
keycode 37 = Control_L NoSymbol Control_L
keycode 38 = a A hebrew_shin A U05B0
keycode 39 = s S hebrew_dalet S U05BC
keycode 40 = d D hebrew_gimel D
keycode 41 = f F hebrew_kaph F
keycode 42 = g G hebrew_ayin G U05F1
keycode 43 = h H hebrew_yod H U05F2
keycode 44 = j J hebrew_chet J U05B4
keycode 45 = k K hebrew_lamed K
keycode 46 = l L hebrew_finalkaph L rightdoublequotemark
keycode 47 = semicolon colon hebrew_finalpe colon doublelowquotemark
keycode 48 = apostrophe quotedbl comma quotedbl U05F4
keycode 49 = grave asciitilde semicolon asciitilde U05F3
keycode 50 = Shift_L ISO_Next_Group Shift_L ISO_Next_Group
keycode 51 = backslash bar backslash bar U05BB
keycode 52 = z Z hebrew_zain Z
keycode 53 = x X hebrew_samech X U05B6
keycode 54 = c C hebrew_bet C U05B1
keycode 55 = v V hebrew_he V
keycode 56 = b B hebrew_nun B NoSymbol U05C6
keycode 57 = n N hebrew_mem N
keycode 58 = m M hebrew_zade M U05B5
keycode 59 = comma less hebrew_taw greater rightsinglequotemark
keycode 60 = period greater hebrew_finalzade less singlelowquotemark
keycode 61 = slash question period question division
... etc. etc. ...
Языковые переменные среды
$ env | grep LANG
LANG=en_IL
GDM_LANG=en_US.utf8
LANGUAGE=en_IL:en
Другие заметки
- Если я создаю чистую учетную запись пользователя, этот пользователь не сталкивается с этой проблемой. Так что это должна быть какая-то пользовательская настройка.
- Если я копирую текст на иврите, я могу вставить его в приложения, которые не используют иврит, и он будет отображаться нормально.
- Я сохранил свою домашнюю папку из предыдущей, не Devuan, установки Linux (это был Linux Mint 18.3).
3 ответа
Вам необходимо удалить / очистить файл ~/.xinputrc.
Вдохновленный некоторыми догадками, предложенными @harrymc, я нашел виновника: мой ~/.xinputrc
файл, созданный в моем предыдущем выпуске (Linux Mint 18.3). Это говорит:
# im-config(8) generated on Wed, 25 Jan 2017 22:44:55 +0100
run_im xim
# im-config signature: 21f3e409b30c3de81e8302273ccb3d5c -
im-config
механизм
метод ввода в X Window System с графическим интерфейсом GTK или диалоговым окном консоли.
который объясняет, почему только (более простые) приложения GTK, кажется, затронуты. Я совсем не знаком с делом метода ввода, но - если я удалю этот файл или закомментирую run_im
опция - все приложения теперь, кажется, принимают ивритские символы, которые я печатаю.
Приведенный ниже ответ не решил проблему автора, но последующее обсуждение, наконец, указало на это.
Мы оба пришли к выводу, что причиной проблемы было некоторое различие между монетным двором и девуаном, которое проявилось, когда плакат скопировал всю его домашнюю папку из одной в другую. Большим намеком был тот факт, что под профилем пользователя root проблема не проявлялась.
Затем автор изучил файлы в своей домашней папке, связанные с клавиатурой, и результат можно найти в его ответе.
Ваша проблема кажется такой же, как в посте
Терминал не принимает некоторые напечатанные символы Юникода.
Обходной путь, найденный в этом посте, должен был изменить .Xmodmap
и замените имена ключей на их шестнадцатеричные коды Unicode.
В приведенном выше посте, для греческого ifonlyif
персонаж, постер заменил строку:
код ключа 58 = m M m M процентов Greek_mu KP_1 KP_1 ifonlyif
по линии:
код клавиши 58 = m M m M процентов Greek_mu KP_1 KP_1 U21D4
Не имея вашего окружения, я полагаю, что в вашем примере для кода ключа 38 следует заменить текст hebrew_shin
по U05E9 (или что-то подобное).
Если это работает для вас, вы должны сделать то же самое для всех букв иврита, что, к сожалению, будет довольно болезненным. Если вам повезет, шестнадцатеричный код Unicode может быть уже упомянут в Xmodmap, так что вы можете сделать это через некоторые sed
магия.
Частичный ответ:
Если вы сравните a
а также ש
, вот увидишь
XLookupString gives 1 bytes: (61) "a"
против
XLookupString gives 0 bytes:
И это проблема, потому что, глядя на справочную страницу, XLookupString обрабатывает только Latin-1, поэтому приложения, использующие XLookupString для преобразования нажатий клавиш в символы, получат пустой результат, в результате чего ваши "ивритские символы не будут регистрироваться, пока пунктуация Знаки делают.
И, видимо, некоторые другие приложения, например, KDE, обходят это или используют другой метод.
Я не знаю, как это исправить. Вам нужно будет использовать приложения, которые понимают Unicode/UTF-8, а также правильно переводят полученные ключевые символы. Патчить исходный код неработающих приложений - вариант, но если бы это было легко, я уверен, что кто-то уже сделал бы это... так что я бы предположил, что есть некоторые ошибки.
Альтернативы XLookupString
эта работа с UTF-8 ( Xutf8LookupString) существует.