зеркало из https://github.com/mozilla/gecko-dev.git
133 строки
5.1 KiB
C++
133 строки
5.1 KiB
C++
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
|
|
/* 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_dom_KeyboardEvent_h_
|
|
#define mozilla_dom_KeyboardEvent_h_
|
|
|
|
#include "mozilla/dom/UIEvent.h"
|
|
#include "mozilla/dom/KeyboardEventBinding.h"
|
|
#include "mozilla/EventForwards.h"
|
|
#include "nsRFPService.h"
|
|
|
|
namespace mozilla {
|
|
namespace dom {
|
|
|
|
class KeyboardEvent : public UIEvent {
|
|
public:
|
|
KeyboardEvent(EventTarget* aOwner, nsPresContext* aPresContext,
|
|
WidgetKeyboardEvent* aEvent);
|
|
|
|
NS_INLINE_DECL_REFCOUNTING_INHERITED(KeyboardEvent, UIEvent)
|
|
|
|
virtual KeyboardEvent* AsKeyboardEvent() override { return this; }
|
|
|
|
static already_AddRefed<KeyboardEvent> ConstructorJS(
|
|
const GlobalObject& aGlobal, const nsAString& aType,
|
|
const KeyboardEventInit& aParam);
|
|
|
|
virtual JSObject* WrapObjectInternal(
|
|
JSContext* aCx, JS::Handle<JSObject*> aGivenProto) override {
|
|
return KeyboardEvent_Binding::Wrap(aCx, this, aGivenProto);
|
|
}
|
|
|
|
bool AltKey(CallerType aCallerType = CallerType::System);
|
|
bool CtrlKey(CallerType aCallerType = CallerType::System);
|
|
bool ShiftKey(CallerType aCallerType = CallerType::System);
|
|
bool MetaKey();
|
|
|
|
bool GetModifierState(const nsAString& aKey,
|
|
CallerType aCallerType = CallerType::System) {
|
|
bool modifierState = GetModifierStateInternal(aKey);
|
|
|
|
if (!ShouldResistFingerprinting(aCallerType)) {
|
|
return modifierState;
|
|
}
|
|
|
|
Modifiers modifier = WidgetInputEvent::GetModifier(aKey);
|
|
return GetSpoofedModifierStates(modifier, modifierState);
|
|
}
|
|
|
|
bool Repeat();
|
|
bool IsComposing();
|
|
void GetKey(nsAString& aKey) const;
|
|
uint32_t CharCode(CallerType aCallerType = CallerType::System);
|
|
uint32_t KeyCode(CallerType aCallerType = CallerType::System);
|
|
virtual uint32_t Which(CallerType aCallerType = CallerType::System) override;
|
|
uint32_t Location();
|
|
|
|
void GetCode(nsAString& aCode, CallerType aCallerType = CallerType::System);
|
|
void GetInitDict(KeyboardEventInit& aParam);
|
|
|
|
void InitKeyEventJS(const nsAString& aType, bool aCanBubble, bool aCancelable,
|
|
nsGlobalWindowInner* aView, bool aCtrlKey, bool aAltKey,
|
|
bool aShiftKey, bool aMetaKey, uint32_t aKeyCode,
|
|
uint32_t aCharCode);
|
|
|
|
void InitKeyboardEventJS(const nsAString& aType, bool aCanBubble,
|
|
bool aCancelable, nsGlobalWindowInner* aView,
|
|
const nsAString& aKey, uint32_t aLocation,
|
|
bool aCtrlKey, bool aAltKey, bool aShiftKey,
|
|
bool aMetaKey);
|
|
|
|
protected:
|
|
~KeyboardEvent() = default;
|
|
|
|
void InitWithKeyboardEventInit(EventTarget* aOwner, const nsAString& aType,
|
|
const KeyboardEventInit& aParam);
|
|
|
|
private:
|
|
// True, if the instance is initialized by JS.
|
|
bool mInitializedByJS;
|
|
// True, if the instance is initialized by Ctor.
|
|
bool mInitializedByCtor;
|
|
|
|
// If the instance is created with Constructor(), which may have independent
|
|
// value. mInitializedWhichValue stores it. I.e., this is invalid when
|
|
// mInitializedByCtor is false.
|
|
uint32_t mInitializedWhichValue;
|
|
|
|
// This method returns the boolean to indicate whether spoofing keyboard
|
|
// event for fingerprinting resistance. It will return true when pref
|
|
// 'privacy.resistFingerprinting' is true and the event target is content.
|
|
// Otherwise, it will return false.
|
|
bool ShouldResistFingerprinting(CallerType aCallerType);
|
|
|
|
// This method returns the spoofed modifier state of the given modifier key
|
|
// for fingerprinting resistance.
|
|
bool GetSpoofedModifierStates(const Modifiers aModifierKey,
|
|
const bool aRawModifierState);
|
|
|
|
/**
|
|
* ComputeTraditionalKeyCode() computes traditional keyCode value. I.e.,
|
|
* returns 0 if this event should return non-zero from CharCode().
|
|
* In spite of the name containing "traditional", this computes spoof
|
|
* keyCode value if user wants it.
|
|
*
|
|
* @param aKeyboardEvent Should be |*mEvent->AsKeyboardEvent()|.
|
|
* @param aCallerType Set caller type of KeyCode() or CharCode().
|
|
* @return If traditional charCode value is 0, returns
|
|
* the raw keyCode value or spoof keyCode value.
|
|
* Otherwise, 0.
|
|
*/
|
|
uint32_t ComputeTraditionalKeyCode(WidgetKeyboardEvent& aKeyboardEvent,
|
|
CallerType aCallerType);
|
|
/**
|
|
* ShouldUseSameValueForCharCodeAndKeyCode() returns true if KeyCode() and
|
|
* CharCode() should return same value.
|
|
*/
|
|
bool ShouldUseSameValueForCharCodeAndKeyCode(
|
|
const WidgetKeyboardEvent& aKeyboardEvent, CallerType aCallerType) const;
|
|
};
|
|
|
|
} // namespace dom
|
|
} // namespace mozilla
|
|
|
|
already_AddRefed<mozilla::dom::KeyboardEvent> NS_NewDOMKeyboardEvent(
|
|
mozilla::dom::EventTarget* aOwner, nsPresContext* aPresContext,
|
|
mozilla::WidgetKeyboardEvent* aEvent);
|
|
|
|
#endif // mozilla_dom_KeyboardEvent_h_
|