Details
-
Bug
-
Resolution: Done
-
P2: Important
-
5.7.1
-
Mac OS X
-
-
25b00c88b6fda2eecd9ff566ab44974136dabf51
Description
Note firstly that this bug is currently 'masked' by QTBUG-56085, which prevents shortcuts requiring Shift from working correctly on the Mac in any keyboard layout. However, this is a separate problem, specific to Japanese (and any other layout that has no 'uchr' resource).
STEPS TO REPRODUCE
(0. Patch Qt to fix QTBUG-56085.)
1. Build the attached application on OS X.
2. Connect a Japanese keyboard.
3. Switch to the Japanese 'Romaji' input source in the OS.
4. Run the app. Observe that the menu has an entry with shortcut '*'.
5. Ensure 'Application Output' is visible in Qt Creator.
6. Press '*' (i.e. Shift+: on Japanese keyboard).
EXPECTED: The app should write 'QKeySequence("*")' to the output.
ACTUAL: Nothing happens.
I dug into this one a bit. The underlying problem seems to be that the Japanese IME doesn't provide a 'uchr' resource, and so Qt's call to the UCTranslateKey API in qcocoakeymapper.mm fails. Qt then falls back to filling in the table for all the modifiers with the same character, the one from the key down event, in this case ':'.
Not sure what the best fix is here but it's a very major problem for the Japanese version of our application.
Attachments
Issue Links
- relates to
-
QTBUG-53804 [REG: 5.3-5.6] Many shortcuts don't work on OSX when Japanese input sources are used
-
- Closed
-
For Gerrit Dashboard: QTBUG-57934 | ||||||
---|---|---|---|---|---|---|
# | Subject | Branch | Project | Status | CR | V |
181777,3 | cocoa: Account for getting a keyboard using input methods correctly | 5.8 | qt/qtbase | Status: MERGED | +2 | 0 |