diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 00:47:55 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-04-19 00:47:55 +0000 |
commit | 26a029d407be480d791972afb5975cf62c9360a6 (patch) | |
tree | f435a8308119effd964b339f76abb83a57c29483 /layout/base/GeckoMVMContext.h | |
parent | Initial commit. (diff) | |
download | firefox-26a029d407be480d791972afb5975cf62c9360a6.tar.xz firefox-26a029d407be480d791972afb5975cf62c9360a6.zip |
Adding upstream version 124.0.1.upstream/124.0.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'layout/base/GeckoMVMContext.h')
-rw-r--r-- | layout/base/GeckoMVMContext.h | 70 |
1 files changed, 70 insertions, 0 deletions
diff --git a/layout/base/GeckoMVMContext.h b/layout/base/GeckoMVMContext.h new file mode 100644 index 0000000000..fdbdcf22ae --- /dev/null +++ b/layout/base/GeckoMVMContext.h @@ -0,0 +1,70 @@ +/* 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 GeckoMVMContext_h_ +#define GeckoMVMContext_h_ + +#include "MVMContext.h" + +#include "mozilla/Attributes.h" // for MOZ_NON_OWNING_REF +#include "mozilla/RefPtr.h" +#include "nsCOMPtr.h" + +namespace mozilla { +class PresShell; +namespace dom { +class Document; +class EventTarget; +} // namespace dom + +/** + * An implementation of MVMContext that uses actual Gecko components. + * This is intended for production use (whereas TestMVMContext is intended for + * testing.) + */ +class GeckoMVMContext final : public MVMContext { + public: + explicit GeckoMVMContext(dom::Document* aDocument, PresShell* aPresShell); + void AddEventListener(const nsAString& aType, nsIDOMEventListener* aListener, + bool aUseCapture) override; + void RemoveEventListener(const nsAString& aType, + nsIDOMEventListener* aListener, + bool aUseCapture) override; + void AddObserver(nsIObserver* aObserver, const char* aTopic, + bool aOwnsWeak) override; + void RemoveObserver(nsIObserver* aObserver, const char* aTopic) override; + void Destroy() override; + + nsViewportInfo GetViewportInfo( + const ScreenIntSize& aDisplaySize) const override; + CSSToLayoutDeviceScale CSSToDevPixelScale() const override; + float GetResolution() const override; + bool SubjectMatchesDocument(nsISupports* aSubject) const override; + Maybe<CSSRect> CalculateScrollableRectForRSF() const override; + bool IsResolutionUpdatedByApz() const override; + LayoutDeviceMargin ScrollbarAreaToExcludeFromCompositionBounds() + const override; + Maybe<LayoutDeviceIntSize> GetDocumentViewerSize() const override; + bool AllowZoomingForDocument() const override; + bool IsInReaderMode() const override; + bool IsDocumentLoading() const override; + + void SetResolutionAndScaleTo(float aResolution, + ResolutionChangeOrigin aOrigin) override; + void SetVisualViewportSize(const CSSSize& aSize) override; + void PostVisualViewportResizeEventByDynamicToolbar() override; + void UpdateDisplayPortMargins() override; + MOZ_CAN_RUN_SCRIPT_BOUNDARY void Reflow(const CSSSize& aNewSize) override; + ScreenIntCoord GetDynamicToolbarOffset() override; + + private: + RefPtr<dom::Document> mDocument; + // raw ref since the presShell owns this + PresShell* MOZ_NON_OWNING_REF mPresShell; + nsCOMPtr<dom::EventTarget> mEventTarget; +}; + +} // namespace mozilla + +#endif // GeckoMVMContext_h_ |