| Index: fpdfsdk/src/javascript/JS_Runtime.cpp
|
| diff --git a/fpdfsdk/src/javascript/JS_Runtime.cpp b/fpdfsdk/src/javascript/JS_Runtime.cpp
|
| index 346b642913de52b5c6e432a0bd5b28d08d06865e..d68b26859103eee80edd621e855a44368594b70f 100644
|
| --- a/fpdfsdk/src/javascript/JS_Runtime.cpp
|
| +++ b/fpdfsdk/src/javascript/JS_Runtime.cpp
|
| @@ -37,7 +37,11 @@ IFXJS_Runtime* CJS_RuntimeFactory::NewJSRuntime(CPDFDoc_Environ
|
| {
|
| if (!m_bInit)
|
| {
|
| - JS_Initial();
|
| + unsigned int embedderDataSlot = 0;
|
| + if (pApp->GetFormFillInfo()->m_pJsPlatform->version >= 2) {
|
| + embedderDataSlot = pApp->GetFormFillInfo()->m_pJsPlatform->m_v8EmbedderSlot;
|
| + }
|
| + JS_Initial(embedderDataSlot);
|
| m_bInit = TRUE;
|
| }
|
| return new CJS_Runtime(pApp);
|
| @@ -107,16 +111,22 @@ CJS_Runtime::CJS_Runtime(CPDFDoc_Environment* pApp) :
|
| m_pApp(pApp),
|
| m_pDocument(NULL),
|
| m_bBlocking(FALSE),
|
| - m_pFieldEventPath(NULL)
|
| + m_pFieldEventPath(NULL),
|
| + m_isolate(NULL)
|
| {
|
| if (CPDFXFA_App::GetInstance()->GetJSERuntime()) {
|
| + // TODO(tsepez): CPDFXFA_App should also use the embedder provided isolate.
|
| m_isolate = (v8::Isolate*)CPDFXFA_App::GetInstance()->GetJSERuntime();
|
| - } else {
|
| + } else if (m_pApp->GetFormFillInfo()->m_pJsPlatform->version >= 2) {
|
| + m_isolate = reinterpret_cast<v8::Isolate*>(m_pApp->GetFormFillInfo()->m_pJsPlatform->m_isolate);
|
| + }
|
| + if (!m_isolate) {
|
| m_pArrayBufferAllocator.reset(new CJS_ArrayBufferAllocator());
|
| +
|
| v8::Isolate::CreateParams params;
|
| params.array_buffer_allocator = m_pArrayBufferAllocator.get();
|
| m_isolate = v8::Isolate::New(params);
|
| - }
|
| + }
|
|
|
| v8::Isolate* isolate = m_isolate;
|
| v8::Isolate::Scope isolate_scope(isolate);
|
|
|