| Index: fpdfsdk/src/jsapi/fxjs_v8.cpp
|
| diff --git a/fpdfsdk/src/jsapi/fxjs_v8.cpp b/fpdfsdk/src/jsapi/fxjs_v8.cpp
|
| index 24d7bcc50a4dc4c998c910fe115606d2f88d9112..c3b1b925fa59a4e789e29b3a1c98c9d6d5ffd4e3 100644
|
| --- a/fpdfsdk/src/jsapi/fxjs_v8.cpp
|
| +++ b/fpdfsdk/src/jsapi/fxjs_v8.cpp
|
| @@ -26,6 +26,7 @@ static double GetNan()
|
| {
|
| return *(double*)g_nan;
|
| }
|
| +static unsigned int g_embedderDataSlot = 0u;
|
|
|
|
|
| class CJS_PrivateData
|
| @@ -78,11 +79,11 @@ int JS_DefineObj(IJS_Runtime* pJSRuntime, const wchar_t* sObjName, FXJSOBJTYPE e
|
| v8::Isolate* isolate = (v8::Isolate*)pJSRuntime;
|
| v8::Isolate::Scope isolate_scope(isolate);
|
| v8::HandleScope handle_scope(isolate);
|
| - CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(1);
|
| + CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(g_embedderDataSlot);
|
| if(!pArray)
|
| {
|
| pArray = FX_NEW CFX_PtrArray();
|
| - isolate->SetData(1, pArray);
|
| + isolate->SetData(g_embedderDataSlot, pArray);
|
| }
|
| CJS_ObjDefintion* pObjDef = FX_NEW CJS_ObjDefintion(isolate, sObjName, eObjType, pConstructor, pDestructor);
|
| pArray->Add(pObjDef);
|
| @@ -98,7 +99,7 @@ int JS_DefineObjMethod(IJS_Runtime* pJSRuntime, int nObjDefnID, const wchar_t* s
|
| CFX_WideString ws = CFX_WideString(sMethodName);
|
| CFX_ByteString bsMethodName = ws.UTF8Encode();
|
|
|
| - CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(1);
|
| + CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(g_embedderDataSlot);
|
| if(!pArray) return 0;
|
|
|
| if(nObjDefnID<0 || nObjDefnID>= pArray->GetSize()) return 0;
|
| @@ -118,7 +119,7 @@ int JS_DefineObjProperty(IJS_Runtime* pJSRuntime, int nObjDefnID, const wchar_t*
|
| CFX_WideString ws = CFX_WideString(sPropName);
|
| CFX_ByteString bsPropertyName = ws.UTF8Encode();
|
|
|
| - CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(1);
|
| + CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(g_embedderDataSlot);
|
| if(!pArray) return 0;
|
|
|
| if(nObjDefnID<0 || nObjDefnID>= pArray->GetSize()) return 0;
|
| @@ -135,7 +136,7 @@ int JS_DefineObjAllProperties(IJS_Runtime* pJSRuntime, int nObjDefnID, v8::Named
|
| v8::Isolate::Scope isolate_scope(isolate);
|
| v8::HandleScope handle_scope(isolate);
|
|
|
| - CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(1);
|
| + CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(g_embedderDataSlot);
|
| if(!pArray) return 0;
|
|
|
| if(nObjDefnID<0 || nObjDefnID>= pArray->GetSize()) return 0;
|
| @@ -152,7 +153,7 @@ int JS_DefineObjConst(IJS_Runtime* pJSRuntime, int nObjDefnID, const wchar_t* sC
|
| v8::Isolate::Scope isolate_scope(isolate);
|
| v8::HandleScope handle_scope(isolate);
|
|
|
| - CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(1);
|
| + CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(g_embedderDataSlot);
|
| if(!pArray) return 0;
|
|
|
| CFX_WideString ws = CFX_WideString(sConstName);
|
| @@ -172,7 +173,7 @@ static v8::Global<v8::ObjectTemplate>& _getGlobalObjectTemplate(IJS_Runtime* pJS
|
| v8::Isolate::Scope isolate_scope(isolate);
|
| v8::HandleScope handle_scope(isolate);
|
|
|
| - CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(1);
|
| + CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(g_embedderDataSlot);
|
| ASSERT(pArray != NULL);
|
| for(int i=0; i<pArray->GetSize(); i++)
|
| {
|
| @@ -245,9 +246,10 @@ void JS_InitialRuntime(IJS_Runtime* pJSRuntime,IFXJS_Runtime* pFXRuntime, IFXJS_
|
|
|
| //v8::Local<External> ptr = External::New(isolate, pFXRuntime);
|
| //v8Context->SetEmbedderData(1, ptr);
|
| + // TODO(tsepez): Don't use more than one embedder data slot.
|
| isolate->SetData(2, pFXRuntime);
|
|
|
| - CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(1);
|
| + CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(g_embedderDataSlot);
|
| if(!pArray) return;
|
|
|
| for(int i=0; i<pArray->GetSize(); i++)
|
| @@ -291,7 +293,7 @@ void JS_ReleaseRuntime(IJS_Runtime* pJSRuntime, v8::Global<v8::Context>& v8Persi
|
| v8::Locker locker(isolate);
|
| v8::HandleScope handle_scope(isolate);
|
|
|
| - CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(1);
|
| + CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(g_embedderDataSlot);
|
| if(!pArray) return ;
|
|
|
| for(int i=0; i<pArray->GetSize(); i++)
|
| @@ -308,11 +310,14 @@ void JS_ReleaseRuntime(IJS_Runtime* pJSRuntime, v8::Global<v8::Context>& v8Persi
|
| }
|
| delete pArray;
|
| isolate->SetData(1,NULL);
|
| + isolate->SetData(g_embedderDataSlot,NULL);
|
| + // TODO(tsepez): Don't use more than one embedder data slot.
|
| isolate->SetData(2,NULL);
|
| }
|
|
|
| -void JS_Initial()
|
| +void JS_Initial(unsigned int embedderDataSlot)
|
| {
|
| + g_embedderDataSlot = embedderDataSlot;
|
| }
|
| void JS_Release()
|
| {
|
| @@ -374,7 +379,7 @@ v8::Local<v8::Object> JS_NewFxDynamicObj(IJS_Runtime* pJSRuntime, IFXJS_Context*
|
| return v8::Local<v8::Object>();
|
| }
|
|
|
| - CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(1);
|
| + CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(g_embedderDataSlot);
|
| if(!pArray) return v8::Local<v8::Object>();
|
|
|
|
|
| @@ -399,7 +404,7 @@ v8::Local<v8::Object> JS_GetStaticObj(IJS_Runtime* pJSRuntime, int nObjDefnID)
|
| v8::Isolate* isolate = (v8::Isolate*)pJSRuntime;
|
| v8::Isolate::Scope isolate_scope(isolate);
|
|
|
| - CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(1);
|
| + CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(g_embedderDataSlot);
|
| if(!pArray) return v8::Local<v8::Object>();
|
|
|
| if(nObjDefnID<0 || nObjDefnID>= pArray->GetSize()) return v8::Local<v8::Object>();
|
| @@ -418,7 +423,7 @@ v8::Local<v8::Object> JS_GetThisObj(IJS_Runtime * pJSRuntime)
|
| v8::Isolate* isolate = (v8::Isolate*)pJSRuntime;
|
| v8::Isolate::Scope isolate_scope(isolate);
|
|
|
| - CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(1);
|
| + CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(g_embedderDataSlot);
|
| if(!pArray) return v8::Local<v8::Object>();
|
|
|
| v8::Local<v8::Context> context = isolate->GetCurrentContext();
|
| @@ -447,7 +452,7 @@ int JS_GetObjDefnID(IJS_Runtime * pJSRuntime, const wchar_t* pObjName)
|
| v8::Isolate* isolate = (v8::Isolate*)pJSRuntime;
|
| v8::Isolate::Scope isolate_scope(isolate);
|
|
|
| - CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(1);
|
| + CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(g_embedderDataSlot);
|
| if(!pArray) return -1;
|
|
|
| for(int i=0; i<pArray->GetSize(); i++)
|
|
|