From 26a029d407be480d791972afb5975cf62c9360a6 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Fri, 19 Apr 2024 02:47:55 +0200 Subject: Adding upstream version 124.0.1. Signed-off-by: Daniel Baumann --- layout/style/TimelineCollection.h | 70 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 70 insertions(+) create mode 100644 layout/style/TimelineCollection.h (limited to 'layout/style/TimelineCollection.h') diff --git a/layout/style/TimelineCollection.h b/layout/style/TimelineCollection.h new file mode 100644 index 0000000000..21e0b2b6bc --- /dev/null +++ b/layout/style/TimelineCollection.h @@ -0,0 +1,70 @@ +/* -*- 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_TimelineCollection_h +#define mozilla_TimelineCollection_h + +#include "mozilla/Assertions.h" +#include "mozilla/LinkedList.h" +#include "mozilla/Maybe.h" +#include "mozilla/RefPtr.h" +#include "nsAtomHashKeys.h" +#include "nsTHashMap.h" + +class nsAtom; + +namespace mozilla { +namespace dom { +class Element; +} +enum class PseudoStyleType : uint8_t; + +// The collection of ScrollTimeline or ViewTimeline. We use the template class +// to share the implementation for these two timeline types. +template +class TimelineCollection final + : public LinkedListElement> { + public: + using SelfType = TimelineCollection; + using TimelineMap = nsTHashMap, RefPtr>; + + TimelineCollection(dom::Element& aElement, PseudoStyleType aPseudoType) + : mElement(aElement), mPseudo(aPseudoType) { + MOZ_COUNT_CTOR(TimelineCollection); + } + + ~TimelineCollection(); + + already_AddRefed Lookup(nsAtom* aName) const { + return mTimelines.Get(aName).forget(); + } + + already_AddRefed Extract(nsAtom* aName) { + Maybe> timeline = mTimelines.Extract(aName); + return timeline ? timeline->forget() : nullptr; + } + + void Swap(TimelineMap& aValue) { mTimelines.SwapElements(aValue); } + + void Destroy(); + + // Get the collection of timelines for the given |aElement| and or create it + // if it does not already exist. + static TimelineCollection* Get(const dom::Element* aElement, + PseudoStyleType aPseudoType); + const TimelineMap& Timelines() const { return mTimelines; } + + private: + // The element. Weak reference is fine since it owns us. + dom::Element& mElement; + const PseudoStyleType mPseudo; + + TimelineMap mTimelines; +}; + +} // namespace mozilla + +#endif // mozilla_TimelineCollection_h -- cgit v1.2.3