// Copyright (c) 2006-2010 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 CHROME_BROWSER_UI_VIEWS_UNHANDLED_KEYBOARD_EVENT_HANDLER_H_
#define CHROME_BROWSER_UI_VIEWS_UNHANDLED_KEYBOARD_EVENT_HANDLER_H_
#pragma once
#include "views/view.h"
#include "content/common/native_web_keyboard_event.h"
namespace views {
class FocusManager;
} // namespace views
// This class handles unhandled keyboard messages coming back from the renderer
// process.
class UnhandledKeyboardEventHandler {
public:
UnhandledKeyboardEventHandler();
~UnhandledKeyboardEventHandler();
void HandleKeyboardEvent(const NativeWebKeyboardEvent& event,
views::FocusManager* focus_manager);
private:
// Whether to ignore the next Char keyboard event.
// If a RawKeyDown event was handled as a shortcut key, then we're done
// handling it and should eat any Char event that the translate phase may
// have produced from it. (Handling this event may cause undesirable effects,
// such as a beep if DefWindowProc() has no default handling for the given
// Char.)
bool ignore_next_char_event_;
DISALLOW_COPY_AND_ASSIGN(UnhandledKeyboardEventHandler);
};
#endif // CHROME_BROWSER_UI_VIEWS_UNHANDLED_KEYBOARD_EVENT_HANDLER_H_