// Copyright (c) 2012 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef REMOTING_CLIENT_KEY_EVENT_MAPPER_H_ #define REMOTING_CLIENT_KEY_EVENT_MAPPER_H_ #include <map> #include <set> #include "base/basictypes.h" #include "base/callback.h" #include "base/compiler_specific.h" #include "remoting/protocol/input_filter.h" namespace remoting { // Filtering InputStub which can be used to re-map the USB keycodes of events // before they are passed on to the next InputStub in the chain, or to trap // events with specific USB keycodes for special handling. class KeyEventMapper : public protocol::InputFilter { public: KeyEventMapper(); explicit KeyEventMapper(InputStub* input_stub); virtual ~KeyEventMapper(); // Callback type for use with SetTrapCallback(), below. typedef base::Callback<void(const protocol::KeyEvent&)> KeyTrapCallback; // Sets the callback to which trapped keys will be delivered. void SetTrapCallback(KeyTrapCallback callback); // Causes events matching |usb_keycode| to be delivered to the trap callback. // Trapped events are not dispatched to the next InputStub in the chain. void TrapKey(uint32 usb_keycode, bool trap_key); // Causes events matching |in_usb_keycode| to be mapped to |out_usb_keycode|. // Keys are remapped at most once. Traps are processed before remapping. void RemapKey(uint32 in_usb_keycode, uint32 out_usb_keycode); // InputFilter overrides. virtual void InjectKeyEvent(const protocol::KeyEvent& event) OVERRIDE; private: std::map<uint32,uint32> mapped_keys; std::set<uint32> trapped_keys; KeyTrapCallback trap_callback; DISALLOW_COPY_AND_ASSIGN(KeyEventMapper); }; } // namespace remoting #endif // REMOTING_CLIENT_KEY_EVENT_MAPPER_H_