summaryrefslogtreecommitdiff
path: root/dom/base/CustomElementRegistry.h
diff options
context:
space:
mode:
authorGaming4JC <g4jc@hyperbola.info>2020-01-03 22:18:55 -0500
committerGaming4JC <g4jc@hyperbola.info>2020-01-26 15:50:12 -0500
commit25a33c7123d457a59ecb4b15a2466cfc8507406b (patch)
tree63a7ed7795fd48dfbe59cdc23738846646e7ce93 /dom/base/CustomElementRegistry.h
parent5cf46e2f87f4f6294d02d96c7905b069c9975eee (diff)
downloaduxp-25a33c7123d457a59ecb4b15a2466cfc8507406b.tar.gz
Bug 1347446 - Move custom element reactions stack to DocGroup.
Tag UXP Issue #1344
Diffstat (limited to 'dom/base/CustomElementRegistry.h')
-rw-r--r--dom/base/CustomElementRegistry.h157
1 files changed, 87 insertions, 70 deletions
diff --git a/dom/base/CustomElementRegistry.h b/dom/base/CustomElementRegistry.h
index 8fdf282890..5fc2eb2fde 100644
--- a/dom/base/CustomElementRegistry.h
+++ b/dom/base/CustomElementRegistry.h
@@ -165,6 +165,86 @@ private:
virtual void Invoke(Element* aElement) override;
};
+// https://html.spec.whatwg.org/multipage/scripting.html#custom-element-reactions-stack
+class CustomElementReactionsStack
+{
+public:
+ NS_INLINE_DECL_REFCOUNTING(CustomElementReactionsStack)
+
+ CustomElementReactionsStack()
+ : mIsBackupQueueProcessing(false)
+ {
+ }
+
+ // nsWeakPtr is a weak pointer of Element
+ // The element reaction queues are stored in ElementReactionQueueMap.
+ // We need to lookup ElementReactionQueueMap again to get relevant reaction queue.
+ typedef nsTArray<nsWeakPtr> ElementQueue;
+
+ /**
+ * Enqueue a custom element upgrade reaction
+ * https://html.spec.whatwg.org/multipage/scripting.html#enqueue-a-custom-element-upgrade-reaction
+ */
+ void EnqueueUpgradeReaction(CustomElementRegistry* aRegistry,
+ Element* aElement,
+ CustomElementDefinition* aDefinition);
+
+ // [CEReactions] Before executing the algorithm's steps
+ // Push a new element queue onto the custom element reactions stack.
+ void CreateAndPushElementQueue();
+
+ // [CEReactions] After executing the algorithm's steps
+ // Pop the element queue from the custom element reactions stack,
+ // and invoke custom element reactions in that queue.
+ void PopAndInvokeElementQueue();
+
+private:
+ ~CustomElementReactionsStack() {};
+
+ typedef nsTArray<nsAutoPtr<CustomElementReaction>> ReactionQueue;
+ typedef nsClassHashtable<nsISupportsHashKey, ReactionQueue>
+ ElementReactionQueueMap;
+
+ ElementReactionQueueMap mElementReactionQueueMap;
+
+ nsTArray<ElementQueue> mReactionsStack;
+ ElementQueue mBackupQueue;
+ // https://html.spec.whatwg.org/#enqueue-an-element-on-the-appropriate-element-queue
+ bool mIsBackupQueueProcessing;
+
+ void InvokeBackupQueue();
+
+ /**
+ * Invoke custom element reactions
+ * https://html.spec.whatwg.org/multipage/scripting.html#invoke-custom-element-reactions
+ */
+ void InvokeReactions(ElementQueue& aElementQueue);
+
+ void Enqueue(Element* aElement, CustomElementReaction* aReaction);
+
+private:
+ class ProcessBackupQueueRunnable : public mozilla::Runnable {
+ public:
+ explicit ProcessBackupQueueRunnable(CustomElementReactionsStack* aReactionStack)
+ : mReactionStack(aReactionStack)
+ {
+ MOZ_ASSERT(!mReactionStack->mIsBackupQueueProcessing,
+ "mIsBackupQueueProcessing should be initially false");
+ mReactionStack->mIsBackupQueueProcessing = true;
+ }
+
+ NS_IMETHOD Run() override
+ {
+ mReactionStack->InvokeBackupQueue();
+ mReactionStack->mIsBackupQueueProcessing = false;
+ return NS_OK;
+ }
+
+ private:
+ RefPtr<CustomElementReactionsStack> mReactionStack;
+ };
+};
+
class CustomElementRegistry final : public nsISupports,
public nsWrapperCache
{
@@ -210,24 +290,8 @@ public:
void GetCustomPrototype(nsIAtom* aAtom,
JS::MutableHandle<JSObject*> aPrototype);
- /**
- * Enqueue a custom element upgrade reaction
- * https://html.spec.whatwg.org/multipage/scripting.html#enqueue-a-custom-element-upgrade-reaction
- */
- void EnqueueUpgradeReaction(Element* aElement,
- CustomElementDefinition* aDefinition);
-
void Upgrade(Element* aElement, CustomElementDefinition* aDefinition);
- // [CEReactions] Before executing the algorithm's steps
- // Push a new element queue onto the custom element reactions stack.
- void CreateAndPushElementQueue();
-
- // [CEReactions] After executing the algorithm's steps
- // Pop the element queue from the custom element reactions stack,
- // and invoke custom element reactions in that queue.
- void PopAndInvokeElementQueue();
-
private:
~CustomElementRegistry();
@@ -244,22 +308,8 @@ private:
void UpgradeCandidates(JSContext* aCx,
nsIAtom* aKey,
- CustomElementDefinition* aDefinition);
-
- void InvokeBackupQueue();
-
- void Enqueue(Element* aElement, CustomElementReaction* aReaction);
-
- // nsWeakPtr is a weak pointer of Element
- // The element reaction queues are stored in ElementReactionQueueMap.
- // We need to lookup ElementReactionQueueMap again to get relevant reaction queue.
- typedef nsTArray<nsWeakPtr> ElementQueue;
-
- /**
- * Invoke custom element reactions
- * https://html.spec.whatwg.org/multipage/scripting.html#invoke-custom-element-reactions
- */
- void InvokeReactions(ElementQueue& aElementQueue);
+ CustomElementDefinition* aDefinition,
+ ErrorResult& aRv);
typedef nsClassHashtable<nsISupportsHashKey, CustomElementDefinition>
DefinitionMap;
@@ -301,17 +351,6 @@ private:
// It is used to prevent reentrant invocations of element definition.
bool mIsCustomDefinitionRunning;
- // https://html.spec.whatwg.org/#enqueue-an-element-on-the-appropriate-element-queue
- bool mIsBackupQueueProcessing;
-
- typedef nsTArray<nsAutoPtr<CustomElementReaction>> ReactionQueue;
- typedef nsClassHashtable<nsISupportsHashKey, ReactionQueue>
- ElementReactionQueueMap;
-
- ElementReactionQueueMap mElementReactionQueueMap;
-
- nsTArray<ElementQueue> mReactionsStack;
- ElementQueue mBackupQueue;
private:
class MOZ_RAII AutoSetRunningFlag final {
@@ -332,28 +371,6 @@ private:
CustomElementRegistry* mRegistry;
};
-private:
- class ProcessBackupQueueRunnable : public mozilla::Runnable {
- public:
- explicit ProcessBackupQueueRunnable(CustomElementRegistry* aRegistry)
- : mRegistry(aRegistry)
- {
- MOZ_ASSERT(!mRegistry->mIsBackupQueueProcessing,
- "mIsBackupQueueProcessing should be initially false");
- mRegistry->mIsBackupQueueProcessing = true;
- }
-
- NS_IMETHOD Run() override
- {
- mRegistry->InvokeBackupQueue();
- mRegistry->mIsBackupQueueProcessing = false;
- return NS_OK;
- }
-
- private:
- RefPtr<CustomElementRegistry> mRegistry;
- };
-
public:
nsISupports* GetParentObject() const;
@@ -370,15 +387,15 @@ public:
class MOZ_RAII AutoCEReaction final {
public:
- explicit AutoCEReaction(CustomElementRegistry* aRegistry)
- : mRegistry(aRegistry) {
- mRegistry->CreateAndPushElementQueue();
+ explicit AutoCEReaction(CustomElementReactionsStack* aReactionsStack)
+ : mReactionsStack(aReactionsStack) {
+ mReactionsStack->CreateAndPushElementQueue();
}
~AutoCEReaction() {
- mRegistry->PopAndInvokeElementQueue();
+ mReactionsStack->PopAndInvokeElementQueue();
}
private:
- RefPtr<CustomElementRegistry> mRegistry;
+ RefPtr<CustomElementReactionsStack> mReactionsStack;
};
} // namespace dom