forked from mozilla/gecko-dev
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathLoadContextBase.h
103 lines (78 loc) · 3.37 KB
/
LoadContextBase.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
/* -*- 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 js_loader_BaseLoadContext_h
#define js_loader_BaseLoadContext_h
#include "js/loader/ScriptLoadRequest.h"
#include "nsIStringBundle.h"
namespace mozilla::dom {
class ScriptLoadContext;
class WorkerLoadContext;
} // namespace mozilla::dom
namespace mozilla::loader {
class ComponentLoadContext;
}
namespace JS::loader {
class ScriptLoadRequest;
/*
* LoadContextBase
*
* LoadContexts augment the loading of a ScriptLoadRequest. This class
* is used as a base for all LoadContexts, and provides shared functionality.
* This class should not be inherited from directly, unless you plan on
* implementing a unique nsISupports behavior not handled by LoadContextNoCCBase
* or LoadContextCCBase.
*
* Different loading environments have different rules applied to how a script
* is loaded. In DOM scripts, there are flags controlling load order (Async,
* Deferred, normal) as well as other elements that impact the loading of a
* script (<preload>). In the case of workers, service workers are potentially
* loaded from the Cache. For more detailed information per context see
* * The ScriptLoadContext: dom/script/ScriptLoadContext.h
* * The ComponentLoadContext: js/xpconnect/loader/ComponentModuleLoader.h
* * The WorkerLoadContext: dom/workers/loader/WorkerLoadContext.h
*/
enum class ContextKind { Window, Component, Worker };
class LoadContextBase : public nsISupports {
private:
ContextKind mKind;
protected:
virtual ~LoadContextBase() = default;
public:
explicit LoadContextBase(ContextKind kind);
virtual void SetRequest(JS::loader::ScriptLoadRequest* aRequest);
// Used to output a string for the Gecko Profiler.
virtual void GetProfilerLabel(nsACString& aOutString);
// Casting to the different contexts
bool IsWindowContext() const { return mKind == ContextKind::Window; }
mozilla::dom::ScriptLoadContext* AsWindowContext();
bool IsComponentContext() const { return mKind == ContextKind::Component; }
mozilla::loader::ComponentLoadContext* AsComponentContext();
bool IsWorkerContext() const { return mKind == ContextKind::Worker; }
mozilla::dom::WorkerLoadContext* AsWorkerContext();
RefPtr<JS::loader::ScriptLoadRequest> mRequest;
};
// A variant of the LoadContextbase with CC. Used by most LoadContexts. This
// works with the cycle collector and is the default class to inherit from.
class LoadContextCCBase : public LoadContextBase {
public:
explicit LoadContextCCBase(ContextKind kind);
NS_DECL_CYCLE_COLLECTING_ISUPPORTS
NS_DECL_CYCLE_COLLECTION_CLASS(LoadContextCCBase)
protected:
virtual ~LoadContextCCBase() = default;
};
// A variant of the LoadContextbase without CC. Used by the WorkerLoadContext,
// so that it can refcounted safely across threads. Note: You must manually
// break the cycle pointing to ScriptLoadRequest if you use this!
class LoadContextNoCCBase : public LoadContextBase {
public:
explicit LoadContextNoCCBase(ContextKind kind);
NS_DECL_THREADSAFE_ISUPPORTS
protected:
virtual ~LoadContextNoCCBase() = default;
};
} // namespace JS::loader
#endif // js_loader_BaseLoadContext_h