Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(6)

Side by Side Diff: third_party/WebKit/Source/modules/worklet/Worklet.h

Issue 2178223002: Refactor Worklet class to use ScriptResource (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: removed redundant ExecutionContext parameter, changed WorkletScriptLoader to inherit from ResourceO… Created 4 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef Worklet_h 5 #ifndef Worklet_h
6 #define Worklet_h 6 #define Worklet_h
7 7
8 #include "bindings/core/v8/ScriptPromise.h" 8 #include "bindings/core/v8/ScriptPromise.h"
9 #include "bindings/core/v8/ScriptWrappable.h" 9 #include "bindings/core/v8/ScriptWrappable.h"
10 #include "core/dom/ActiveDOMObject.h" 10 #include "core/dom/ActiveDOMObject.h"
11 #include "core/frame/csp/ContentSecurityPolicy.h" 11 #include "core/fetch/ScriptResource.h"
12 #include "core/workers/WorkerScriptLoader.h"
13 #include "modules/ModulesExport.h" 12 #include "modules/ModulesExport.h"
14 #include "platform/heap/Handle.h" 13 #include "platform/heap/Handle.h"
15 14
16 namespace blink { 15 namespace blink {
17 16
18 class ExecutionContext; 17 class LocalFrame;
19 class ScriptPromiseResolver; 18 class Resource;
20 class WorkerScriptLoader; 19 class ResourceFetcher;
21 class WorkletGlobalScopeProxy; 20 class WorkletGlobalScopeProxy;
21 class WorkletScriptLoader;
22 22
23 class MODULES_EXPORT Worklet : public GarbageCollectedFinalized<Worklet>, public ScriptWrappable, public ActiveDOMObject { 23 class MODULES_EXPORT Worklet : public GarbageCollectedFinalized<Worklet>, public ScriptWrappable, public ActiveDOMObject {
24 DEFINE_WRAPPERTYPEINFO(); 24 DEFINE_WRAPPERTYPEINFO();
25 USING_GARBAGE_COLLECTED_MIXIN(Worklet); 25 USING_GARBAGE_COLLECTED_MIXIN(Worklet);
26 WTF_MAKE_NONCOPYABLE(Worklet); 26 WTF_MAKE_NONCOPYABLE(Worklet);
27 public: 27 public:
28 virtual WorkletGlobalScopeProxy* workletGlobalScopeProxy() const = 0; 28 virtual WorkletGlobalScopeProxy* workletGlobalScopeProxy() const = 0;
29 29
30 // Worklet 30 // Worklet
31 ScriptPromise import(ScriptState*, const String& url); 31 ScriptPromise import(ScriptState*, const String& url);
32 32
33 void notifyFinished(Resource*);
34
33 // ActiveDOMObject 35 // ActiveDOMObject
34 void stop() final; 36 void stop() final;
35 37
36 DECLARE_VIRTUAL_TRACE(); 38 DECLARE_VIRTUAL_TRACE();
37 39
38 protected: 40 protected:
39 // The ExecutionContext argument is the parent document of the Worklet. The 41 // The Worklet inherits the url and userAgent from the frame->document().
40 // Worklet inherits the url and userAgent from the document. 42 explicit Worklet(LocalFrame*);
41 explicit Worklet(ExecutionContext*);
42 43
43 private: 44 private:
44 void onResponse(WorkerScriptLoader*); 45 ResourceFetcher* fetcher() const { return m_fetcher.get(); }
45 void onFinished(WorkerScriptLoader*, ScriptPromiseResolver*);
46 46
47 Vector<RefPtr<WorkerScriptLoader>> m_scriptLoaders; 47 Member<ResourceFetcher> m_fetcher;
48 HeapVector<Member<ScriptPromiseResolver>> m_resolvers; 48 HeapVector<Member<Resource>> m_resources;
yhirano 2016/08/01 10:56:28 It seems having m_resources is not necessary if we
Gleb Lanbin 2016/08/01 19:49:51 Done.
49 HeapVector<Member<WorkletScriptLoader>> m_scriptLoaders;
49 }; 50 };
50 51
51 } // namespace blink 52 } // namespace blink
52 53
53 #endif // Worklet_h 54 #endif // Worklet_h
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698