-
Notifications
You must be signed in to change notification settings - Fork 121
/
per_context_data.h
48 lines (37 loc) · 1.61 KB
/
per_context_data.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
// Copyright 2013 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef GIN_PER_CONTEXT_DATA_H_
#define GIN_PER_CONTEXT_DATA_H_
#include "base/memory/raw_ptr.h"
#include "base/supports_user_data.h"
#include "gin/gin_export.h"
#include "v8/include/v8-forward.h"
namespace gin {
class ContextHolder;
class Runner;
// There is one instance of PerContextData per v8::Context managed by Gin. This
// class stores all the Gin-related data that varies per context. Arbitrary data
// can be associated with this class by way of the SupportsUserData methods.
// Instances of this class (and any associated user data) are destroyed before
// the associated v8::Context.
class GIN_EXPORT PerContextData : public base::SupportsUserData {
public:
PerContextData(ContextHolder* context_holder,
v8::Local<v8::Context> context);
PerContextData(const PerContextData&) = delete;
PerContextData& operator=(const PerContextData&) = delete;
~PerContextData() override;
// Can return NULL after the ContextHolder has detached from context.
static PerContextData* From(v8::Local<v8::Context> context);
// The Runner associated with this context. To execute script in this context,
// please use the appropriate API on Runner.
Runner* runner() const { return runner_; }
void set_runner(Runner* runner) { runner_ = runner; }
ContextHolder* context_holder() { return context_holder_; }
private:
raw_ptr<ContextHolder, DanglingUntriaged> context_holder_;
raw_ptr<Runner> runner_;
};
} // namespace gin
#endif // GIN_PER_CONTEXT_DATA_H_