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

Side by Side Diff: fpdfsdk/src/javascript/JS_Runtime.cpp

Issue 1381633008: Merge to XFA: Pass v8::Isolate to PDFium at init time. (Closed) Base URL: https://pdfium.googlesource.com/pdfium.git@xfa
Patch Set: Rebase Created 5 years, 2 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 2014 PDFium Authors. All rights reserved. 1 // Copyright 2014 PDFium 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 // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com 5 // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com
6 6
7 #include "JS_Runtime.h" 7 #include "JS_Runtime.h"
8 8
9 #include "../../../xfa/src/fxjse/src/value.h" 9 #include "../../../xfa/src/fxjse/src/value.h"
10 #include "../../include/fpdfxfa/fpdfxfa_app.h" 10 #include "../../include/fpdfxfa/fpdfxfa_app.h"
(...skipping 27 matching lines...) Expand all
38 38
39 CJS_Runtime::CJS_Runtime(CPDFDoc_Environment* pApp) 39 CJS_Runtime::CJS_Runtime(CPDFDoc_Environment* pApp)
40 : m_pApp(pApp), 40 : m_pApp(pApp),
41 m_pDocument(NULL), 41 m_pDocument(NULL),
42 m_bBlocking(FALSE), 42 m_bBlocking(FALSE),
43 m_isolate(NULL), 43 m_isolate(NULL),
44 m_isolateManaged(false) { 44 m_isolateManaged(false) {
45 if (CPDFXFA_App::GetInstance()->GetJSERuntime()) { 45 if (CPDFXFA_App::GetInstance()->GetJSERuntime()) {
46 // TODO(tsepez): CPDFXFA_App should also use the embedder provided isolate. 46 // TODO(tsepez): CPDFXFA_App should also use the embedder provided isolate.
47 m_isolate = (v8::Isolate*)CPDFXFA_App::GetInstance()->GetJSERuntime(); 47 m_isolate = (v8::Isolate*)CPDFXFA_App::GetInstance()->GetJSERuntime();
48 } else if (m_pApp->GetFormFillInfo()->m_pJsPlatform->version >= 2) { 48 } else {
49 m_isolate = reinterpret_cast<v8::Isolate*>( 49 IPDF_JSPLATFORM* pPlatform = m_pApp->GetFormFillInfo()->m_pJsPlatform;
50 m_pApp->GetFormFillInfo()->m_pJsPlatform->m_isolate); 50 if (pPlatform->version <= 2) {
51 } 51 unsigned int embedderDataSlot = 0;
52 if (!m_isolate) { 52 v8::Isolate* pExternalIsolate = nullptr;
53 m_pArrayBufferAllocator.reset(new FXJS_ArrayBufferAllocator()); 53 if (pPlatform->version == 2) {
54 54 pExternalIsolate = reinterpret_cast<v8::Isolate*>(pPlatform->m_isolate);
55 v8::Isolate::CreateParams params; 55 embedderDataSlot = pPlatform->m_v8EmbedderSlot;
56 params.array_buffer_allocator = m_pArrayBufferAllocator.get(); 56 }
57 m_isolate = v8::Isolate::New(params); 57 FXJS_Initialize(embedderDataSlot, pExternalIsolate);
58 m_isolateManaged = true; 58 }
59 m_isolateManaged = FXJS_GetIsolate(&m_isolate);
59 } 60 }
60 61
61 v8::Isolate* isolate = m_isolate; 62 v8::Isolate* isolate = m_isolate;
62 v8::Isolate::Scope isolate_scope(isolate); 63 v8::Isolate::Scope isolate_scope(isolate);
63 v8::Locker locker(isolate); 64 v8::Locker locker(isolate);
64 v8::HandleScope handle_scope(isolate); 65 v8::HandleScope handle_scope(isolate);
65 if (CPDFXFA_App::GetInstance()->IsJavaScriptInitialized()) { 66 if (CPDFXFA_App::GetInstance()->IsJavaScriptInitialized()) {
66 CJS_Context* pContext = (CJS_Context*)NewContext(); 67 CJS_Context* pContext = (CJS_Context*)NewContext();
67 FXJS_InitializeRuntime(GetIsolate(), this, pContext, m_context); 68 FXJS_InitializeRuntime(GetIsolate(), this, pContext, m_context);
68 ReleaseContext(pContext); 69 ReleaseContext(pContext);
69 return; 70 return;
70 } 71 }
71 72
72 unsigned int embedderDataSlot = 0;
73 if (m_pApp->GetFormFillInfo()->m_pJsPlatform->version >= 2)
74 embedderDataSlot = pApp->GetFormFillInfo()->m_pJsPlatform->m_v8EmbedderSlot;
75 FXJS_Initialize(embedderDataSlot);
76 DefineJSObjects(); 73 DefineJSObjects();
77 CPDFXFA_App::GetInstance()->SetJavaScriptInitialized(TRUE); 74 CPDFXFA_App::GetInstance()->SetJavaScriptInitialized(TRUE);
78 75
79 CJS_Context* pContext = (CJS_Context*)NewContext(); 76 CJS_Context* pContext = (CJS_Context*)NewContext();
80 FXJS_InitializeRuntime(GetIsolate(), this, pContext, m_context); 77 FXJS_InitializeRuntime(GetIsolate(), this, pContext, m_context);
81 ReleaseContext(pContext); 78 ReleaseContext(pContext);
82 } 79 }
83 80
84 CJS_Runtime::~CJS_Runtime() { 81 CJS_Runtime::~CJS_Runtime() {
85 for (auto* obs : m_observers) 82 for (auto* obs : m_observers)
(...skipping 180 matching lines...) Expand 10 before | Expand all | Expand 10 after
266 263
267 void CJS_Runtime::AddObserver(Observer* observer) { 264 void CJS_Runtime::AddObserver(Observer* observer) {
268 ASSERT(m_observers.find(observer) == m_observers.end()); 265 ASSERT(m_observers.find(observer) == m_observers.end());
269 m_observers.insert(observer); 266 m_observers.insert(observer);
270 } 267 }
271 268
272 void CJS_Runtime::RemoveObserver(Observer* observer) { 269 void CJS_Runtime::RemoveObserver(Observer* observer) {
273 ASSERT(m_observers.find(observer) != m_observers.end()); 270 ASSERT(m_observers.find(observer) != m_observers.end());
274 m_observers.erase(observer); 271 m_observers.erase(observer);
275 } 272 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698