summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--BUILD.gn1
-rw-r--r--fxjs/cfxjse_isolatetracker.cpp23
-rw-r--r--fxjs/cfxjse_isolatetracker.h24
3 files changed, 31 insertions, 17 deletions
diff --git a/BUILD.gn b/BUILD.gn
index 23bf477125..abdd414562 100644
--- a/BUILD.gn
+++ b/BUILD.gn
@@ -1299,6 +1299,7 @@ jumbo_static_library("fxjs") {
"fxjs/cfxjse_engine.h",
"fxjs/cfxjse_formcalc_context.cpp",
"fxjs/cfxjse_formcalc_context.h",
+ "fxjs/cfxjse_isolatetracker.cpp",
"fxjs/cfxjse_isolatetracker.h",
"fxjs/cfxjse_resolveprocessor.cpp",
"fxjs/cfxjse_resolveprocessor.h",
diff --git a/fxjs/cfxjse_isolatetracker.cpp b/fxjs/cfxjse_isolatetracker.cpp
new file mode 100644
index 0000000000..2a66a74a8b
--- /dev/null
+++ b/fxjs/cfxjse_isolatetracker.cpp
@@ -0,0 +1,23 @@
+// Copyright 2018 PDFium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+// Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com
+
+#include "fxjs/cfxjse_isolatetracker.h"
+
+CFXJSE_ScopeUtil_IsolateHandle::CFXJSE_ScopeUtil_IsolateHandle(
+ v8::Isolate* pIsolate)
+ : m_iscope(pIsolate), m_hscope(pIsolate) {}
+
+CFXJSE_ScopeUtil_IsolateHandle::~CFXJSE_ScopeUtil_IsolateHandle() = default;
+
+CFXJSE_ScopeUtil_IsolateHandleRootContext::
+ CFXJSE_ScopeUtil_IsolateHandleRootContext(v8::Isolate* pIsolate)
+ : CFXJSE_ScopeUtil_IsolateHandle(pIsolate),
+ m_cscope(v8::Local<v8::Context>::New(
+ pIsolate,
+ CFXJSE_RuntimeData::Get(pIsolate)->m_hRootContext)) {}
+
+CFXJSE_ScopeUtil_IsolateHandleRootContext::
+ ~CFXJSE_ScopeUtil_IsolateHandleRootContext() = default;
diff --git a/fxjs/cfxjse_isolatetracker.h b/fxjs/cfxjse_isolatetracker.h
index 2bb16ca7ba..103b2757f6 100644
--- a/fxjs/cfxjse_isolatetracker.h
+++ b/fxjs/cfxjse_isolatetracker.h
@@ -7,19 +7,13 @@
#ifndef FXJS_CFXJSE_ISOLATETRACKER_H_
#define FXJS_CFXJSE_ISOLATETRACKER_H_
-#include <map>
-#include <memory>
-#include <vector>
-
-#include "v8/include/v8.h"
-
#include "fxjs/cfxjse_runtimedata.h"
+#include "v8/include/v8.h"
class CFXJSE_ScopeUtil_IsolateHandle {
public:
- explicit CFXJSE_ScopeUtil_IsolateHandle(v8::Isolate* pIsolate)
- : m_isolate(pIsolate), m_iscope(pIsolate), m_hscope(pIsolate) {}
- v8::Isolate* GetIsolate() { return m_isolate; }
+ explicit CFXJSE_ScopeUtil_IsolateHandle(v8::Isolate* pIsolate);
+ ~CFXJSE_ScopeUtil_IsolateHandle();
private:
CFXJSE_ScopeUtil_IsolateHandle(const CFXJSE_ScopeUtil_IsolateHandle&) =
@@ -28,18 +22,15 @@ class CFXJSE_ScopeUtil_IsolateHandle {
void* operator new(size_t size) = delete;
void operator delete(void*, size_t) = delete;
- v8::Isolate* m_isolate;
v8::Isolate::Scope m_iscope;
v8::HandleScope m_hscope;
};
-class CFXJSE_ScopeUtil_IsolateHandleRootContext {
+class CFXJSE_ScopeUtil_IsolateHandleRootContext
+ : public CFXJSE_ScopeUtil_IsolateHandle {
public:
- explicit CFXJSE_ScopeUtil_IsolateHandleRootContext(v8::Isolate* pIsolate)
- : m_parent(pIsolate),
- m_cscope(v8::Local<v8::Context>::New(
- pIsolate,
- CFXJSE_RuntimeData::Get(pIsolate)->m_hRootContext)) {}
+ explicit CFXJSE_ScopeUtil_IsolateHandleRootContext(v8::Isolate* pIsolate);
+ ~CFXJSE_ScopeUtil_IsolateHandleRootContext();
private:
CFXJSE_ScopeUtil_IsolateHandleRootContext(
@@ -48,7 +39,6 @@ class CFXJSE_ScopeUtil_IsolateHandleRootContext {
void* operator new(size_t size) = delete;
void operator delete(void*, size_t) = delete;
- CFXJSE_ScopeUtil_IsolateHandle m_parent;
v8::Context::Scope m_cscope;
};