| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 "ui/base/accelerators/accelerator.h" | 5 #include "ui/base/accelerators/accelerator.h" |
| 6 | 6 |
| 7 #include <stdint.h> | 7 #include <stdint.h> |
| 8 | 8 |
| 9 #include "base/i18n/rtl.h" | 9 #include "base/i18n/rtl.h" |
| 10 #include "base/logging.h" | 10 #include "base/logging.h" |
| (...skipping 24 matching lines...) Expand all Loading... |
| 35 | 35 |
| 36 } // namespace | 36 } // namespace |
| 37 | 37 |
| 38 Accelerator::Accelerator() : Accelerator(VKEY_UNKNOWN, EF_NONE) {} | 38 Accelerator::Accelerator() : Accelerator(VKEY_UNKNOWN, EF_NONE) {} |
| 39 | 39 |
| 40 Accelerator::Accelerator(KeyboardCode key_code, | 40 Accelerator::Accelerator(KeyboardCode key_code, |
| 41 int modifiers, | 41 int modifiers, |
| 42 KeyState key_state) | 42 KeyState key_state) |
| 43 : key_code_(key_code), | 43 : key_code_(key_code), |
| 44 key_state_(key_state), | 44 key_state_(key_state), |
| 45 modifiers_(modifiers & kInterestingFlagsMask) {} | 45 modifiers_(modifiers & kInterestingFlagsMask), |
| 46 interrupted_by_mouse_event_(false) {} |
| 46 | 47 |
| 47 Accelerator::Accelerator(const KeyEvent& key_event) | 48 Accelerator::Accelerator(const KeyEvent& key_event) |
| 48 : key_code_(key_event.key_code()), | 49 : key_code_(key_event.key_code()), |
| 49 key_state_(key_event.type() == ET_KEY_PRESSED ? KeyState::PRESSED | 50 key_state_(key_event.type() == ET_KEY_PRESSED ? KeyState::PRESSED |
| 50 : KeyState::RELEASED), | 51 : KeyState::RELEASED), |
| 51 // |modifiers_| may include the repeat flag. | 52 // |modifiers_| may include the repeat flag. |
| 52 modifiers_(key_event.flags() & kInterestingFlagsMask) {} | 53 modifiers_(key_event.flags() & kInterestingFlagsMask), |
| 54 interrupted_by_mouse_event_(false) {} |
| 53 | 55 |
| 54 Accelerator::Accelerator(const Accelerator& accelerator) { | 56 Accelerator::Accelerator(const Accelerator& accelerator) { |
| 55 key_code_ = accelerator.key_code_; | 57 key_code_ = accelerator.key_code_; |
| 56 key_state_ = accelerator.key_state_; | 58 key_state_ = accelerator.key_state_; |
| 57 modifiers_ = accelerator.modifiers_; | 59 modifiers_ = accelerator.modifiers_; |
| 60 interrupted_by_mouse_event_ = accelerator.interrupted_by_mouse_event_; |
| 58 if (accelerator.platform_accelerator_) | 61 if (accelerator.platform_accelerator_) |
| 59 platform_accelerator_ = accelerator.platform_accelerator_->CreateCopy(); | 62 platform_accelerator_ = accelerator.platform_accelerator_->CreateCopy(); |
| 60 } | 63 } |
| 61 | 64 |
| 62 Accelerator::~Accelerator() { | 65 Accelerator::~Accelerator() { |
| 63 } | 66 } |
| 64 | 67 |
| 65 // static | 68 // static |
| 66 int Accelerator::MaskOutKeyEventFlags(int flags) { | 69 int Accelerator::MaskOutKeyEventFlags(int flags) { |
| 67 return flags & kModifierMask; | 70 return flags & kModifierMask; |
| 68 } | 71 } |
| 69 | 72 |
| 70 Accelerator& Accelerator::operator=(const Accelerator& accelerator) { | 73 Accelerator& Accelerator::operator=(const Accelerator& accelerator) { |
| 71 if (this != &accelerator) { | 74 if (this != &accelerator) { |
| 72 key_code_ = accelerator.key_code_; | 75 key_code_ = accelerator.key_code_; |
| 73 key_state_ = accelerator.key_state_; | 76 key_state_ = accelerator.key_state_; |
| 74 modifiers_ = accelerator.modifiers_; | 77 modifiers_ = accelerator.modifiers_; |
| 78 interrupted_by_mouse_event_ = accelerator.interrupted_by_mouse_event_; |
| 75 if (accelerator.platform_accelerator_) | 79 if (accelerator.platform_accelerator_) |
| 76 platform_accelerator_ = accelerator.platform_accelerator_->CreateCopy(); | 80 platform_accelerator_ = accelerator.platform_accelerator_->CreateCopy(); |
| 77 else | 81 else |
| 78 platform_accelerator_.reset(); | 82 platform_accelerator_.reset(); |
| 79 } | 83 } |
| 80 return *this; | 84 return *this; |
| 81 } | 85 } |
| 82 | 86 |
| 83 bool Accelerator::operator <(const Accelerator& rhs) const { | 87 bool Accelerator::operator <(const Accelerator& rhs) const { |
| 84 if (key_code_ != rhs.key_code_) | 88 if (key_code_ != rhs.key_code_) |
| 85 return key_code_ < rhs.key_code_; | 89 return key_code_ < rhs.key_code_; |
| 86 if (key_state_ != rhs.key_state_) { | 90 if (key_state_ != rhs.key_state_) { |
| 87 return static_cast<int32_t>(key_state_) < | 91 return static_cast<int32_t>(key_state_) < |
| 88 static_cast<int32_t>(rhs.key_state_); | 92 static_cast<int32_t>(rhs.key_state_); |
| 89 } | 93 } |
| 90 return MaskOutKeyEventFlags(modifiers_) < | 94 return MaskOutKeyEventFlags(modifiers_) < |
| 91 MaskOutKeyEventFlags(rhs.modifiers_); | 95 MaskOutKeyEventFlags(rhs.modifiers_); |
| 92 } | 96 } |
| 93 | 97 |
| 94 bool Accelerator::operator ==(const Accelerator& rhs) const { | 98 bool Accelerator::operator ==(const Accelerator& rhs) const { |
| 95 return (key_code_ == rhs.key_code_) && (key_state_ == rhs.key_state_) && | 99 return (key_code_ == rhs.key_code_) && (key_state_ == rhs.key_state_) && |
| 96 (MaskOutKeyEventFlags(modifiers_) == | 100 (MaskOutKeyEventFlags(modifiers_) == |
| 97 MaskOutKeyEventFlags(rhs.modifiers_)); | 101 MaskOutKeyEventFlags(rhs.modifiers_)) && |
| 102 interrupted_by_mouse_event_ == rhs.interrupted_by_mouse_event_; |
| 98 } | 103 } |
| 99 | 104 |
| 100 bool Accelerator::operator !=(const Accelerator& rhs) const { | 105 bool Accelerator::operator !=(const Accelerator& rhs) const { |
| 101 return !(*this == rhs); | 106 return !(*this == rhs); |
| 102 } | 107 } |
| 103 | 108 |
| 104 bool Accelerator::IsShiftDown() const { | 109 bool Accelerator::IsShiftDown() const { |
| 105 return (modifiers_ & EF_SHIFT_DOWN) != 0; | 110 return (modifiers_ & EF_SHIFT_DOWN) != 0; |
| 106 } | 111 } |
| 107 | 112 |
| (...skipping 175 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 283 | 288 |
| 284 // Subtracting the size of the shortcut key and 1 for the '+' sign. | 289 // Subtracting the size of the shortcut key and 1 for the '+' sign. |
| 285 shortcut_rtl.append(shortcut, 0, shortcut.length() - key_length - 1); | 290 shortcut_rtl.append(shortcut, 0, shortcut.length() - key_length - 1); |
| 286 shortcut.swap(shortcut_rtl); | 291 shortcut.swap(shortcut_rtl); |
| 287 } | 292 } |
| 288 | 293 |
| 289 return shortcut; | 294 return shortcut; |
| 290 } | 295 } |
| 291 | 296 |
| 292 } // namespace ui | 297 } // namespace ui |
| OLD | NEW |