diff -r 000000000000 -r 6474c204b198 widget/shared/WidgetUtils.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/widget/shared/WidgetUtils.h Wed Dec 31 06:09:35 2014 +0100 @@ -0,0 +1,67 @@ +/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- + * + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +#ifndef __mozilla_widget_WidgetUtils_h__ +#define __mozilla_widget_WidgetUtils_h__ + +#include "nsCOMPtr.h" +#include "nsIWidget.h" +#include "nsPIDOMWindow.h" +#include "nsIDOMWindow.h" +#include "mozilla/EventForwards.h" + +namespace mozilla { +namespace widget { + +class WidgetUtils +{ +public: + + /** + * Starting at the docshell item for the passed in DOM window this looks up + * the docshell tree until it finds a docshell item that has a widget. + */ + static already_AddRefed DOMWindowToWidget(nsIDOMWindow *aDOMWindow); + + /** + * Compute our keyCode value (NS_VK_*) from an ASCII character. + */ + static uint32_t ComputeKeyCodeFromChar(uint32_t aCharCode); + + /** + * Get unshifted charCode and shifted charCode for aKeyCode if the keyboad + * layout is a Latin keyboard layout. + * + * @param aKeyCode Our keyCode (NS_VK_*). + * @param aIsCapsLock TRUE if CapsLock is Locked. Otherwise, FALSE. + * This is used only when aKeyCode is NS_VK_[0-9]. + * @param aUnshiftedCharCode CharCode for aKeyCode without Shift key. + * This may be zero if aKeyCode key doesn't input + * a Latin character. + * Note that must not be nullptr. + * @param aShiftedCharCode CharCode for aKeyCOde with Shift key. + * This is always 0 when aKeyCode isn't + * NS_VK_[A-Z]. + * Note that must not be nullptr. + */ + static void GetLatinCharCodeForKeyCode(uint32_t aKeyCode, + bool aIsCapsLock, + uint32_t* aUnshiftedCharCode, + uint32_t* aShiftedCharCode); + + /** + * GetDeadKeyNameIndex() returns a key name index for dead key or + * "Unidentified". This method can return the index from non-combining + * unicode character, e.g., '`' returns KEY_NAME_INDEX_DeadGrave. + * So, you cannot use this method for checking if the char is a dead char. + */ + static KeyNameIndex GetDeadKeyNameIndex(char16_t aChar); +}; + +} // namespace widget +} // namespace mozilla + +#endif