Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(675)

Side by Side Diff: ui/events/ozone/layout/xkb/xkb_keyboard_layout_engine_unittest.cc

Issue 841263005: Use DOM- rather than Windows-based key code for non-layout cases. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: address review comments (sadrul) Created 5 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "testing/gtest/include/gtest/gtest.h" 5 #include "testing/gtest/include/gtest/gtest.h"
6 #include "ui/events/event_constants.h" 6 #include "ui/events/event_constants.h"
7 #include "ui/events/keycodes/dom3/dom_code.h" 7 #include "ui/events/keycodes/dom3/dom_code.h"
8 #include "ui/events/keycodes/dom3/dom_key.h" 8 #include "ui/events/keycodes/dom3/dom_key.h"
9 #include "ui/events/keycodes/keyboard_code_conversion.h"
9 #include "ui/events/ozone/layout/keyboard_layout_engine_manager.h" 10 #include "ui/events/ozone/layout/keyboard_layout_engine_manager.h"
10 #include "ui/events/ozone/layout/layout_util.h"
11 #include "ui/events/ozone/layout/xkb/xkb_keyboard_layout_engine.h" 11 #include "ui/events/ozone/layout/xkb/xkb_keyboard_layout_engine.h"
12 12
13 namespace ui { 13 namespace ui {
14 14
15 namespace { 15 namespace {
16 16
17 // This XkbKeyCodeConverter simply uses the numeric value of the DomCode. 17 // This XkbKeyCodeConverter simply uses the numeric value of the DomCode.
18 class VkTestXkbKeyCodeConverter : public XkbKeyCodeConverter { 18 class VkTestXkbKeyCodeConverter : public XkbKeyCodeConverter {
19 public: 19 public:
20 VkTestXkbKeyCodeConverter() { 20 VkTestXkbKeyCodeConverter() {
(...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after
65 xkb_keysym_t CharacterToKeySym(base::char16 c) const { 65 xkb_keysym_t CharacterToKeySym(base::char16 c) const {
66 return 0x01000000u + c; 66 return 0x01000000u + c;
67 } 67 }
68 68
69 KeyboardCode GetKeyboardCode(DomCode dom_code, 69 KeyboardCode GetKeyboardCode(DomCode dom_code,
70 int flags, 70 int flags,
71 base::char16 character) const { 71 base::char16 character) const {
72 KeyboardCode key_code = DifficultKeyboardCode( 72 KeyboardCode key_code = DifficultKeyboardCode(
73 dom_code, flags, key_code_converter_.DomCodeToXkbKeyCode(dom_code), 73 dom_code, flags, key_code_converter_.DomCodeToXkbKeyCode(dom_code),
74 flags, CharacterToKeySym(character), DomKey::CHARACTER, character); 74 flags, CharacterToKeySym(character), DomKey::CHARACTER, character);
75 if (key_code == VKEY_UNKNOWN) 75 if (key_code == VKEY_UNKNOWN) {
76 key_code = DomCodeToNonLocatedKeyboardCode(dom_code); 76 DomKey dummy_dom_key;
77 base::char16 dummy_character;
78 // If this fails, key_code remains VKEY_UNKNOWN.
79 ignore_result(DomCodeToUsLayoutMeaning(dom_code, EF_NONE, &dummy_dom_key,
80 &dummy_character, &key_code));
81 }
77 return key_code; 82 return key_code;
78 } 83 }
79 84
80 // XkbKeyboardLayoutEngine overrides: 85 // XkbKeyboardLayoutEngine overrides:
81 bool XkbLookup(xkb_keycode_t xkb_keycode, 86 bool XkbLookup(xkb_keycode_t xkb_keycode,
82 xkb_mod_mask_t xkb_flags, 87 xkb_mod_mask_t xkb_flags,
83 xkb_keysym_t* xkb_keysym, 88 xkb_keysym_t* xkb_keysym,
84 base::char16* character) const override { 89 base::char16* character) const override {
85 if (!entry_ || 90 if (!entry_ ||
86 (xkb_keycode != static_cast<xkb_keycode_t>(entry_->dom_code))) 91 (xkb_keycode != static_cast<xkb_keycode_t>(entry_->dom_code)))
87 return false; 92 return false;
88 if (xkb_flags & EF_ALTGR_DOWN) 93 if (xkb_flags & EF_ALTGR_DOWN)
89 *character = entry_->altgr_character; 94 *character = entry_->altgr_character;
90 else if (xkb_flags & EF_SHIFT_DOWN) 95 else if (xkb_flags & EF_SHIFT_DOWN)
91 *character = entry_->shift_character; 96 *character = entry_->shift_character;
92 else 97 else
93 *character = entry_->plain_character; 98 *character = entry_->plain_character;
94 *xkb_keysym = CharacterToKeySym(*character); 99 *xkb_keysym = CharacterToKeySym(*character);
(...skipping 629 matching lines...) Expand 10 before | Expand all | Expand 10 after
724 layout_engine_->SetEntry(e); 729 layout_engine_->SetEntry(e);
725 730
726 // Test with predetermined plain character. 731 // Test with predetermined plain character.
727 KeyboardCode key_code = layout_engine_->GetKeyboardCode( 732 KeyboardCode key_code = layout_engine_->GetKeyboardCode(
728 e->dom_code, EF_NONE, e->plain_character); 733 e->dom_code, EF_NONE, e->plain_character);
729 EXPECT_EQ(e->key_code, key_code); 734 EXPECT_EQ(e->key_code, key_code);
730 735
731 if (e->shift_character) { 736 if (e->shift_character) {
732 // Test with predetermined shifted character. 737 // Test with predetermined shifted character.
733 key_code = layout_engine_->GetKeyboardCode(e->dom_code, EF_SHIFT_DOWN, 738 key_code = layout_engine_->GetKeyboardCode(e->dom_code, EF_SHIFT_DOWN,
734 e->shift_character); 739 e->shift_character);
735 EXPECT_EQ(e->key_code, key_code); 740 EXPECT_EQ(e->key_code, key_code);
736 } 741 }
737 742
738 if (e->altgr_character) { 743 if (e->altgr_character) {
739 // Test with predetermined AltGr character. 744 // Test with predetermined AltGr character.
740 key_code = layout_engine_->GetKeyboardCode(e->dom_code, EF_ALTGR_DOWN, 745 key_code = layout_engine_->GetKeyboardCode(e->dom_code, EF_ALTGR_DOWN,
741 e->altgr_character); 746 e->altgr_character);
742 EXPECT_EQ(e->key_code, key_code); 747 EXPECT_EQ(e->key_code, key_code);
743 } 748 }
744 749
745 // Test with unrelated predetermined character. 750 // Test with unrelated predetermined character.
746 key_code = 751 key_code =
747 layout_engine_->GetKeyboardCode(e->dom_code, EF_MOD3_DOWN, 0xFFFFu); 752 layout_engine_->GetKeyboardCode(e->dom_code, EF_MOD3_DOWN, 0xFFFFu);
748 EXPECT_EQ(e->key_code, key_code); 753 EXPECT_EQ(e->key_code, key_code);
749 } 754 }
750 } 755 }
751 756
(...skipping 58 matching lines...) Expand 10 before | Expand all | Expand 10 after
810 std::string layout_id; 815 std::string layout_id;
811 std::string layout_variant; 816 std::string layout_variant;
812 XkbKeyboardLayoutEngine::ParseLayoutName(e->layout_name, &layout_id, 817 XkbKeyboardLayoutEngine::ParseLayoutName(e->layout_name, &layout_id,
813 &layout_variant); 818 &layout_variant);
814 EXPECT_EQ(layout_id, e->layout); 819 EXPECT_EQ(layout_id, e->layout);
815 EXPECT_EQ(layout_variant, e->variant); 820 EXPECT_EQ(layout_variant, e->variant);
816 } 821 }
817 } 822 }
818 823
819 } // namespace ui 824 } // namespace ui
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698