Use a 1-byte enum class for TextDirection
[WebKit-https.git] / Source / WebCore / dom / LoadableModuleScript.h
index 83f5391..ba1fe1d 100644 (file)
 
 #pragma once
 
-#include "CachedModuleScript.h"
-#include "CachedModuleScriptClient.h"
 #include "LoadableScript.h"
 #include <wtf/TypeCasts.h>
 
 namespace WebCore {
 
-class LoadableModuleScript final : public LoadableScript, private CachedModuleScriptClient {
+class ScriptSourceCode;
+class ModuleFetchParameters;
+
+class LoadableModuleScript final : public LoadableScript {
 public:
     virtual ~LoadableModuleScript();
 
-    static Ref<LoadableModuleScript> create(const String& nonce, const String& crossOriginMode, const String& charset, const AtomicString& initiatorName, bool isInUserAgentShadowTree);
+    static Ref<LoadableModuleScript> create(const String& nonce, const String& integrity, const String& crossOriginMode, const String& charset, const AtomicString& initiatorName, bool isInUserAgentShadowTree);
 
     bool isLoaded() const final;
     std::optional<Error> error() const final;
     bool wasCanceled() const final;
 
-    CachedModuleScript& moduleScript() { return m_moduleScript.get(); }
+    bool isClassicScript() const final { return false; }
     bool isModuleScript() const final { return true; }
 
     void execute(ScriptElement&) final;
@@ -52,12 +53,20 @@ public:
     void load(Document&, const URL& rootURL);
     void load(Document&, const ScriptSourceCode&);
 
-private:
-    LoadableModuleScript(const String& nonce, const String& crossOriginMode, const String& charset, const AtomicString& initiatorName, bool isInUserAgentShadowTree, Ref<CachedModuleScript>&&);
+    void notifyLoadCompleted(UniquedStringImpl&);
+    void notifyLoadFailed(LoadableScript::Error&&);
+    void notifyLoadWasCanceled();
 
-    void notifyFinished(CachedModuleScript&) final;
+    UniquedStringImpl* moduleKey() const { return m_moduleKey.get(); }
+
+private:
+    LoadableModuleScript(const String& nonce, const String& integrity, const String& crossOriginMode, const String& charset, const AtomicString& initiatorName, bool isInUserAgentShadowTree);
 
-    Ref<CachedModuleScript> m_moduleScript;
+    Ref<ModuleFetchParameters> m_parameters;
+    RefPtr<UniquedStringImpl> m_moduleKey;
+    std::optional<LoadableScript::Error> m_error;
+    bool m_wasCanceled { false };
+    bool m_isLoaded { false };
 };
 
 }