| Index: fpdfsdk/src/javascript/global.cpp
|
| diff --git a/fpdfsdk/src/javascript/global.cpp b/fpdfsdk/src/javascript/global.cpp
|
| index 6965c8c88495d5382e0941dacece7cf94d96428f..ee0591b9500ad5e84e32609d27ae288ecc9baaac 100644
|
| --- a/fpdfsdk/src/javascript/global.cpp
|
| +++ b/fpdfsdk/src/javascript/global.cpp
|
| @@ -39,51 +39,46 @@ struct CHash<ACC, N, Ns...> {
|
| };
|
|
|
| extern const unsigned int JSCONST_nStringHash =
|
| - CHash<'s','t','r','i','n','g'>::value;
|
| + CHash<'s', 't', 'r', 'i', 'n', 'g'>::value;
|
| extern const unsigned int JSCONST_nNumberHash =
|
| - CHash<'n','u','m','b','e','r'>::value;
|
| + CHash<'n', 'u', 'm', 'b', 'e', 'r'>::value;
|
| extern const unsigned int JSCONST_nBoolHash =
|
| - CHash<'b','o','o','l','e','a','n'>::value;
|
| -extern const unsigned int JSCONST_nDateHash =
|
| - CHash<'d','a','t','e'>::value;
|
| + CHash<'b', 'o', 'o', 'l', 'e', 'a', 'n'>::value;
|
| +extern const unsigned int JSCONST_nDateHash = CHash<'d', 'a', 't', 'e'>::value;
|
| extern const unsigned int JSCONST_nObjectHash =
|
| - CHash<'o','b','j','e','c','t'>::value;
|
| + CHash<'o', 'b', 'j', 'e', 'c', 't'>::value;
|
| extern const unsigned int JSCONST_nFXobjHash =
|
| - CHash<'f','x','o','b','j'>::value;
|
| -extern const unsigned int JSCONST_nNullHash =
|
| - CHash<'n','u','l','l'>::value;
|
| + CHash<'f', 'x', 'o', 'b', 'j'>::value;
|
| +extern const unsigned int JSCONST_nNullHash = CHash<'n', 'u', 'l', 'l'>::value;
|
| extern const unsigned int JSCONST_nUndefHash =
|
| - CHash<'u','n','d','e','f','i','n','e','d'>::value;
|
| + CHash<'u', 'n', 'd', 'e', 'f', 'i', 'n', 'e', 'd'>::value;
|
|
|
| #ifdef _DEBUG
|
| -class HashVerify
|
| -{
|
| -public:
|
| +class HashVerify {
|
| + public:
|
| HashVerify();
|
| } g_hashVerify;
|
|
|
| -HashVerify::HashVerify()
|
| -{
|
| +HashVerify::HashVerify() {
|
| ASSERT(JSCONST_nStringHash ==
|
| - JS_CalcHash(VALUE_NAME_STRING,wcslen(VALUE_NAME_STRING)));
|
| + JS_CalcHash(VALUE_NAME_STRING, wcslen(VALUE_NAME_STRING)));
|
| ASSERT(JSCONST_nNumberHash ==
|
| - JS_CalcHash(VALUE_NAME_NUMBER,wcslen(VALUE_NAME_NUMBER)));
|
| + JS_CalcHash(VALUE_NAME_NUMBER, wcslen(VALUE_NAME_NUMBER)));
|
| ASSERT(JSCONST_nBoolHash ==
|
| - JS_CalcHash(VALUE_NAME_BOOLEAN,wcslen(VALUE_NAME_BOOLEAN)));
|
| + JS_CalcHash(VALUE_NAME_BOOLEAN, wcslen(VALUE_NAME_BOOLEAN)));
|
| ASSERT(JSCONST_nDateHash ==
|
| - JS_CalcHash(VALUE_NAME_DATE,wcslen(VALUE_NAME_DATE)));
|
| + JS_CalcHash(VALUE_NAME_DATE, wcslen(VALUE_NAME_DATE)));
|
| ASSERT(JSCONST_nObjectHash ==
|
| - JS_CalcHash(VALUE_NAME_OBJECT,wcslen(VALUE_NAME_OBJECT)));
|
| + JS_CalcHash(VALUE_NAME_OBJECT, wcslen(VALUE_NAME_OBJECT)));
|
| ASSERT(JSCONST_nFXobjHash ==
|
| - JS_CalcHash(VALUE_NAME_FXOBJ,wcslen(VALUE_NAME_FXOBJ)));
|
| + JS_CalcHash(VALUE_NAME_FXOBJ, wcslen(VALUE_NAME_FXOBJ)));
|
| ASSERT(JSCONST_nNullHash ==
|
| - JS_CalcHash(VALUE_NAME_NULL,wcslen(VALUE_NAME_NULL)));
|
| + JS_CalcHash(VALUE_NAME_NULL, wcslen(VALUE_NAME_NULL)));
|
| ASSERT(JSCONST_nUndefHash ==
|
| - JS_CalcHash(VALUE_NAME_UNDEFINED,wcslen(VALUE_NAME_UNDEFINED)));
|
| + JS_CalcHash(VALUE_NAME_UNDEFINED, wcslen(VALUE_NAME_UNDEFINED)));
|
| }
|
| #endif
|
|
|
| -
|
| BEGIN_JS_STATIC_CONST(CJS_Global)
|
| END_JS_STATIC_CONST()
|
|
|
| @@ -91,500 +86,464 @@ BEGIN_JS_STATIC_PROP(CJS_Global)
|
| END_JS_STATIC_PROP()
|
|
|
| BEGIN_JS_STATIC_METHOD(CJS_Global)
|
| - JS_STATIC_METHOD_ENTRY(setPersistent)
|
| +JS_STATIC_METHOD_ENTRY(setPersistent)
|
| END_JS_STATIC_METHOD()
|
|
|
| IMPLEMENT_SPECIAL_JS_CLASS(CJS_Global, global_alternate, global);
|
|
|
| -FX_BOOL CJS_Global::InitInstance(IFXJS_Context* cc)
|
| -{
|
| - CJS_Context* pContext = (CJS_Context*)cc;
|
| - ASSERT(pContext != NULL);
|
| +FX_BOOL CJS_Global::InitInstance(IFXJS_Context* cc) {
|
| + CJS_Context* pContext = (CJS_Context*)cc;
|
| + ASSERT(pContext != NULL);
|
|
|
| - global_alternate* pGlobal = (global_alternate*)GetEmbedObject();
|
| - ASSERT(pGlobal != NULL);
|
| + global_alternate* pGlobal = (global_alternate*)GetEmbedObject();
|
| + ASSERT(pGlobal != NULL);
|
|
|
| - pGlobal->Initial(pContext->GetReaderApp());
|
| + pGlobal->Initial(pContext->GetReaderApp());
|
|
|
| - return TRUE;
|
| + return TRUE;
|
| };
|
|
|
| global_alternate::global_alternate(CJS_Object* pJSObject)
|
| - : CJS_EmbedObj(pJSObject),
|
| - m_pApp(NULL)
|
| -{
|
| -}
|
| + : CJS_EmbedObj(pJSObject), m_pApp(NULL) {}
|
|
|
| -global_alternate::~global_alternate(void)
|
| -{
|
| - DestroyGlobalPersisitentVariables();
|
| - m_pApp->GetRuntimeFactory()->ReleaseGlobalData();
|
| +global_alternate::~global_alternate(void) {
|
| + DestroyGlobalPersisitentVariables();
|
| + m_pApp->GetRuntimeFactory()->ReleaseGlobalData();
|
| }
|
|
|
| -void global_alternate::Initial(CPDFDoc_Environment* pApp)
|
| -{
|
| - m_pApp = pApp;
|
| - m_pGlobalData = pApp->GetRuntimeFactory()->NewGlobalData(pApp);
|
| - UpdateGlobalPersistentVariables();
|
| +void global_alternate::Initial(CPDFDoc_Environment* pApp) {
|
| + m_pApp = pApp;
|
| + m_pGlobalData = pApp->GetRuntimeFactory()->NewGlobalData(pApp);
|
| + UpdateGlobalPersistentVariables();
|
| }
|
|
|
| -FX_BOOL global_alternate::QueryProperty(const FX_WCHAR* propname)
|
| -{
|
| - return CFX_WideString(propname) != L"setPersistent";
|
| +FX_BOOL global_alternate::QueryProperty(const FX_WCHAR* propname) {
|
| + return CFX_WideString(propname) != L"setPersistent";
|
| }
|
|
|
| -FX_BOOL global_alternate::DelProperty(IFXJS_Context* cc, const FX_WCHAR* propname, CFX_WideString& sError)
|
| -{
|
| - js_global_data* pData = NULL;
|
| - CFX_ByteString sPropName = CFX_ByteString::FromUnicode(propname);
|
| +FX_BOOL global_alternate::DelProperty(IFXJS_Context* cc,
|
| + const FX_WCHAR* propname,
|
| + CFX_WideString& sError) {
|
| + js_global_data* pData = NULL;
|
| + CFX_ByteString sPropName = CFX_ByteString::FromUnicode(propname);
|
|
|
| - if (m_mapGlobal.Lookup(sPropName, (void*&)pData))
|
| - {
|
| - pData->bDeleted = TRUE;
|
| - return TRUE;
|
| - }
|
| + if (m_mapGlobal.Lookup(sPropName, (void*&)pData)) {
|
| + pData->bDeleted = TRUE;
|
| + return TRUE;
|
| + }
|
|
|
| - return FALSE;
|
| + return FALSE;
|
| }
|
|
|
| -FX_BOOL global_alternate::DoProperty(IFXJS_Context* cc, const FX_WCHAR* propname, CJS_PropValue& vp, CFX_WideString& sError)
|
| -{
|
| - if (vp.IsSetting())
|
| - {
|
| - CFX_ByteString sPropName = CFX_ByteString::FromUnicode(propname);
|
| - switch (vp.GetType())
|
| - {
|
| - case VT_number:
|
| - {
|
| - double dData;
|
| - vp >> dData;
|
| - return SetGlobalVariables(sPropName, JS_GLOBALDATA_TYPE_NUMBER, dData, false, "", v8::Local<v8::Object>(), FALSE);
|
| - }
|
| - case VT_boolean:
|
| - {
|
| - bool bData;
|
| - vp >> bData;
|
| - return SetGlobalVariables(sPropName, JS_GLOBALDATA_TYPE_BOOLEAN, 0, bData, "", v8::Local<v8::Object>(), FALSE);
|
| - }
|
| - case VT_string:
|
| - {
|
| - CFX_ByteString sData;
|
| - vp >> sData;
|
| - return SetGlobalVariables(sPropName, JS_GLOBALDATA_TYPE_STRING, 0, false, sData, v8::Local<v8::Object>(), FALSE);
|
| - }
|
| - case VT_object:
|
| - {
|
| - JSObject pData;
|
| - vp >> pData;
|
| - return SetGlobalVariables(sPropName, JS_GLOBALDATA_TYPE_OBJECT, 0, false, "", pData, FALSE);
|
| - }
|
| - case VT_null:
|
| - {
|
| - return SetGlobalVariables(sPropName, JS_GLOBALDATA_TYPE_NULL, 0, false, "", v8::Local<v8::Object>(), FALSE);
|
| - }
|
| - case VT_undefined:
|
| - {
|
| - DelProperty(cc, propname, sError);
|
| - return TRUE;
|
| - }
|
| - default:
|
| - break;
|
| - }
|
| +FX_BOOL global_alternate::DoProperty(IFXJS_Context* cc,
|
| + const FX_WCHAR* propname,
|
| + CJS_PropValue& vp,
|
| + CFX_WideString& sError) {
|
| + if (vp.IsSetting()) {
|
| + CFX_ByteString sPropName = CFX_ByteString::FromUnicode(propname);
|
| + switch (vp.GetType()) {
|
| + case VT_number: {
|
| + double dData;
|
| + vp >> dData;
|
| + return SetGlobalVariables(sPropName, JS_GLOBALDATA_TYPE_NUMBER, dData,
|
| + false, "", v8::Local<v8::Object>(), FALSE);
|
| + }
|
| + case VT_boolean: {
|
| + bool bData;
|
| + vp >> bData;
|
| + return SetGlobalVariables(sPropName, JS_GLOBALDATA_TYPE_BOOLEAN, 0,
|
| + bData, "", v8::Local<v8::Object>(), FALSE);
|
| + }
|
| + case VT_string: {
|
| + CFX_ByteString sData;
|
| + vp >> sData;
|
| + return SetGlobalVariables(sPropName, JS_GLOBALDATA_TYPE_STRING, 0,
|
| + false, sData, v8::Local<v8::Object>(), FALSE);
|
| + }
|
| + case VT_object: {
|
| + JSObject pData;
|
| + vp >> pData;
|
| + return SetGlobalVariables(sPropName, JS_GLOBALDATA_TYPE_OBJECT, 0,
|
| + false, "", pData, FALSE);
|
| + }
|
| + case VT_null: {
|
| + return SetGlobalVariables(sPropName, JS_GLOBALDATA_TYPE_NULL, 0, false,
|
| + "", v8::Local<v8::Object>(), FALSE);
|
| + }
|
| + case VT_undefined: {
|
| + DelProperty(cc, propname, sError);
|
| + return TRUE;
|
| + }
|
| + default:
|
| + break;
|
| }
|
| - else
|
| - {
|
| - void* pVoid = nullptr;
|
| - if (!m_mapGlobal.Lookup(CFX_ByteString::FromUnicode(propname), pVoid))
|
| - {
|
| - vp.SetNull();
|
| - return TRUE;
|
| - }
|
| - if (!pVoid)
|
| - {
|
| - vp.SetNull();
|
| - return TRUE;
|
| - }
|
| - js_global_data* pData = (js_global_data*)pVoid;
|
| - if (pData->bDeleted)
|
| - return TRUE;
|
| -
|
| - switch (pData->nType)
|
| - {
|
| - case JS_GLOBALDATA_TYPE_NUMBER:
|
| - vp << pData->dData;
|
| - return TRUE;
|
| - case JS_GLOBALDATA_TYPE_BOOLEAN:
|
| - vp << pData->bData;
|
| - return TRUE;
|
| - case JS_GLOBALDATA_TYPE_STRING:
|
| - vp << pData->sData;
|
| - return TRUE;
|
| - case JS_GLOBALDATA_TYPE_OBJECT:
|
| - {
|
| - v8::Local<v8::Object> obj = v8::Local<v8::Object>::New(vp.GetIsolate(),pData->pData);
|
| - vp << obj;
|
| - return TRUE;
|
| - }
|
| - case JS_GLOBALDATA_TYPE_NULL:
|
| - vp.SetNull();
|
| - return TRUE;
|
| - default:
|
| - break;
|
| - }
|
| + } else {
|
| + void* pVoid = nullptr;
|
| + if (!m_mapGlobal.Lookup(CFX_ByteString::FromUnicode(propname), pVoid)) {
|
| + vp.SetNull();
|
| + return TRUE;
|
| }
|
| - return FALSE;
|
| -}
|
| -
|
| -FX_BOOL global_alternate::setPersistent(IFXJS_Context* cc, const CJS_Parameters& params, CJS_Value& vRet, CFX_WideString& sError)
|
| -{
|
| - CJS_Context* pContext = static_cast<CJS_Context*>(cc);
|
| - if (params.size() != 2)
|
| - {
|
| - sError = JSGetStringFromID(pContext, IDS_STRING_JSPARAMERROR);
|
| - return FALSE;
|
| + if (!pVoid) {
|
| + vp.SetNull();
|
| + return TRUE;
|
| }
|
| + js_global_data* pData = (js_global_data*)pVoid;
|
| + if (pData->bDeleted)
|
| + return TRUE;
|
|
|
| - CFX_ByteString sName = params[0].ToCFXByteString();
|
| -
|
| - js_global_data* pData = NULL;
|
| - if (m_mapGlobal.Lookup(sName, (void*&)pData))
|
| - {
|
| - if (pData && !pData->bDeleted)
|
| - {
|
| - pData->bPersistent = params[1].ToBool();
|
| - return TRUE;
|
| - }
|
| + switch (pData->nType) {
|
| + case JS_GLOBALDATA_TYPE_NUMBER:
|
| + vp << pData->dData;
|
| + return TRUE;
|
| + case JS_GLOBALDATA_TYPE_BOOLEAN:
|
| + vp << pData->bData;
|
| + return TRUE;
|
| + case JS_GLOBALDATA_TYPE_STRING:
|
| + vp << pData->sData;
|
| + return TRUE;
|
| + case JS_GLOBALDATA_TYPE_OBJECT: {
|
| + v8::Local<v8::Object> obj =
|
| + v8::Local<v8::Object>::New(vp.GetIsolate(), pData->pData);
|
| + vp << obj;
|
| + return TRUE;
|
| + }
|
| + case JS_GLOBALDATA_TYPE_NULL:
|
| + vp.SetNull();
|
| + return TRUE;
|
| + default:
|
| + break;
|
| }
|
| -
|
| - sError = JSGetStringFromID(pContext, IDS_STRING_JSNOGLOBAL);
|
| - return FALSE;
|
| + }
|
| + return FALSE;
|
| }
|
|
|
| -void global_alternate::UpdateGlobalPersistentVariables()
|
| -{
|
| - ASSERT(m_pGlobalData != NULL);
|
| -
|
| - for (int i=0,sz=m_pGlobalData->GetSize(); i<sz; i++)
|
| - {
|
| - CJS_GlobalData_Element* pData = m_pGlobalData->GetAt(i);
|
| - ASSERT(pData != NULL);
|
| -
|
| - switch (pData->data.nType)
|
| - {
|
| - case JS_GLOBALDATA_TYPE_NUMBER:
|
| - SetGlobalVariables(pData->data.sKey, JS_GLOBALDATA_TYPE_NUMBER, pData->data.dData, false, "", v8::Local<v8::Object>(), pData->bPersistent == 1);
|
| - JS_PutObjectNumber(NULL,(JSFXObject)(*m_pJSObject),
|
| - pData->data.sKey.UTF8Decode().c_str(), pData->data.dData);
|
| - break;
|
| - case JS_GLOBALDATA_TYPE_BOOLEAN:
|
| - SetGlobalVariables(pData->data.sKey, JS_GLOBALDATA_TYPE_BOOLEAN, 0, (bool)(pData->data.bData == 1), "", v8::Local<v8::Object>(), pData->bPersistent == 1);
|
| - JS_PutObjectBoolean(NULL,(JSFXObject)(*m_pJSObject),
|
| - pData->data.sKey.UTF8Decode().c_str(), (bool)(pData->data.bData == 1));
|
| - break;
|
| - case JS_GLOBALDATA_TYPE_STRING:
|
| - SetGlobalVariables(pData->data.sKey, JS_GLOBALDATA_TYPE_STRING, 0, false, pData->data.sData, v8::Local<v8::Object>(), pData->bPersistent == 1);
|
| - JS_PutObjectString(NULL, (JSFXObject)(*m_pJSObject),
|
| - pData->data.sKey.UTF8Decode().c_str(),
|
| - pData->data.sData.UTF8Decode().c_str());
|
| - break;
|
| - case JS_GLOBALDATA_TYPE_OBJECT:
|
| - {
|
| - IJS_Runtime* pRuntime = JS_GetRuntime((JSFXObject)(*m_pJSObject));
|
| - v8::Local<v8::Object> pObj = JS_NewFxDynamicObj(pRuntime, NULL, -1);
|
| +FX_BOOL global_alternate::setPersistent(IFXJS_Context* cc,
|
| + const CJS_Parameters& params,
|
| + CJS_Value& vRet,
|
| + CFX_WideString& sError) {
|
| + CJS_Context* pContext = static_cast<CJS_Context*>(cc);
|
| + if (params.size() != 2) {
|
| + sError = JSGetStringFromID(pContext, IDS_STRING_JSPARAMERROR);
|
| + return FALSE;
|
| + }
|
|
|
| - PutObjectProperty(pObj, &pData->data);
|
| + CFX_ByteString sName = params[0].ToCFXByteString();
|
|
|
| - SetGlobalVariables(pData->data.sKey, JS_GLOBALDATA_TYPE_OBJECT, 0, false, "",
|
| - (JSObject)pObj, pData->bPersistent == 1);
|
| - JS_PutObjectObject(NULL,(JSFXObject)(*m_pJSObject),
|
| - pData->data.sKey.UTF8Decode().c_str(), (JSObject)pObj);
|
| - }
|
| - break;
|
| - case JS_GLOBALDATA_TYPE_NULL:
|
| - SetGlobalVariables(pData->data.sKey, JS_GLOBALDATA_TYPE_NULL, 0, false, "", v8::Local<v8::Object>(), pData->bPersistent == 1);
|
| - JS_PutObjectNull(NULL,(JSFXObject)(*m_pJSObject),
|
| - pData->data.sKey.UTF8Decode().c_str());
|
| - break;
|
| - }
|
| + js_global_data* pData = NULL;
|
| + if (m_mapGlobal.Lookup(sName, (void*&)pData)) {
|
| + if (pData && !pData->bDeleted) {
|
| + pData->bPersistent = params[1].ToBool();
|
| + return TRUE;
|
| }
|
| -}
|
| + }
|
|
|
| -void global_alternate::CommitGlobalPersisitentVariables()
|
| -{
|
| - ASSERT(m_pGlobalData != NULL);
|
| -
|
| - FX_POSITION pos = m_mapGlobal.GetStartPosition();
|
| - while (pos)
|
| - {
|
| - CFX_ByteString name;
|
| - js_global_data* pData = NULL;
|
| - m_mapGlobal.GetNextAssoc(pos, name, (void*&)pData);
|
| -
|
| - if (pData)
|
| - {
|
| - if (pData->bDeleted)
|
| - {
|
| - m_pGlobalData->DeleteGlobalVariable(name);
|
| - }
|
| - else
|
| - {
|
| - switch (pData->nType)
|
| - {
|
| - case JS_GLOBALDATA_TYPE_NUMBER:
|
| - m_pGlobalData->SetGlobalVariableNumber(name, pData->dData);
|
| - m_pGlobalData->SetGlobalVariablePersistent(name, pData->bPersistent);
|
| - break;
|
| - case JS_GLOBALDATA_TYPE_BOOLEAN:
|
| - m_pGlobalData->SetGlobalVariableBoolean(name, pData->bData);
|
| - m_pGlobalData->SetGlobalVariablePersistent(name, pData->bPersistent);
|
| - break;
|
| - case JS_GLOBALDATA_TYPE_STRING:
|
| - m_pGlobalData->SetGlobalVariableString(name, pData->sData);
|
| - m_pGlobalData->SetGlobalVariablePersistent(name, pData->bPersistent);
|
| - break;
|
| - case JS_GLOBALDATA_TYPE_OBJECT:
|
| - //if (pData->pData)
|
| - {
|
| - CJS_GlobalVariableArray array;
|
| - v8::Local<v8::Object> obj = v8::Local<v8::Object>::New(GetJSObject()->GetIsolate(),pData->pData);
|
| - ObjectToArray(obj, array);
|
| - m_pGlobalData->SetGlobalVariableObject(name, array);
|
| - m_pGlobalData->SetGlobalVariablePersistent(name, pData->bPersistent);
|
| - }
|
| - break;
|
| - case JS_GLOBALDATA_TYPE_NULL:
|
| - m_pGlobalData->SetGlobalVariableNull(name);
|
| - m_pGlobalData->SetGlobalVariablePersistent(name, pData->bPersistent);
|
| - break;
|
| - }
|
| - }
|
| - }
|
| - }
|
| + sError = JSGetStringFromID(pContext, IDS_STRING_JSNOGLOBAL);
|
| + return FALSE;
|
| }
|
|
|
| -void global_alternate::ObjectToArray(v8::Local<v8::Object> pObj, CJS_GlobalVariableArray& array)
|
| -{
|
| - v8::Local<v8::Context> context = pObj->CreationContext();
|
| - v8::Isolate* isolate = context->GetIsolate();
|
| - v8::Local<v8::Array> pKeyList = JS_GetObjectElementNames(isolate, pObj);
|
| - int nObjElements = pKeyList->Length();
|
| +void global_alternate::UpdateGlobalPersistentVariables() {
|
| + ASSERT(m_pGlobalData != NULL);
|
|
|
| - for (int i=0; i<nObjElements; i++)
|
| - {
|
| -
|
| - CFX_WideString ws = JS_ToString(isolate, JS_GetArrayElement(isolate, pKeyList, i));
|
| - CFX_ByteString sKey = ws.UTF8Encode();
|
| + for (int i = 0, sz = m_pGlobalData->GetSize(); i < sz; i++) {
|
| + CJS_GlobalData_Element* pData = m_pGlobalData->GetAt(i);
|
| + ASSERT(pData != NULL);
|
|
|
| - v8::Local<v8::Value> v = JS_GetObjectElement(isolate, pObj, ws.c_str());
|
| - FXJSVALUETYPE vt = GET_VALUE_TYPE(v);
|
| - switch (vt)
|
| - {
|
| - case VT_number:
|
| - {
|
| - CJS_KeyValue* pObjElement = new CJS_KeyValue;
|
| - pObjElement->nType = JS_GLOBALDATA_TYPE_NUMBER;
|
| - pObjElement->sKey = sKey;
|
| - pObjElement->dData = JS_ToNumber(isolate, v);
|
| - array.Add(pObjElement);
|
| - }
|
| - break;
|
| - case VT_boolean:
|
| - {
|
| - CJS_KeyValue* pObjElement = new CJS_KeyValue;
|
| - pObjElement->nType = JS_GLOBALDATA_TYPE_BOOLEAN;
|
| - pObjElement->sKey = sKey;
|
| - pObjElement->dData = JS_ToBoolean(isolate, v);
|
| - array.Add(pObjElement);
|
| - }
|
| - break;
|
| - case VT_string:
|
| - {
|
| - CFX_ByteString sValue = CJS_Value(isolate, v, VT_string).ToCFXByteString();
|
| - CJS_KeyValue* pObjElement = new CJS_KeyValue;
|
| - pObjElement->nType = JS_GLOBALDATA_TYPE_STRING;
|
| - pObjElement->sKey = sKey;
|
| - pObjElement->sData = sValue;
|
| - array.Add(pObjElement);
|
| - }
|
| - break;
|
| - case VT_object:
|
| - {
|
| - CJS_KeyValue* pObjElement = new CJS_KeyValue;
|
| - pObjElement->nType = JS_GLOBALDATA_TYPE_OBJECT;
|
| - pObjElement->sKey = sKey;
|
| - ObjectToArray(JS_ToObject(isolate, v), pObjElement->objData);
|
| - array.Add(pObjElement);
|
| - }
|
| - break;
|
| - case VT_null:
|
| - {
|
| - CJS_KeyValue* pObjElement = new CJS_KeyValue;
|
| - pObjElement->nType = JS_GLOBALDATA_TYPE_NULL;
|
| - pObjElement->sKey = sKey;
|
| - array.Add(pObjElement);
|
| - }
|
| - break;
|
| - default:
|
| - break;
|
| - }
|
| + switch (pData->data.nType) {
|
| + case JS_GLOBALDATA_TYPE_NUMBER:
|
| + SetGlobalVariables(pData->data.sKey, JS_GLOBALDATA_TYPE_NUMBER,
|
| + pData->data.dData, false, "",
|
| + v8::Local<v8::Object>(), pData->bPersistent == 1);
|
| + JS_PutObjectNumber(NULL, (JSFXObject)(*m_pJSObject),
|
| + pData->data.sKey.UTF8Decode().c_str(),
|
| + pData->data.dData);
|
| + break;
|
| + case JS_GLOBALDATA_TYPE_BOOLEAN:
|
| + SetGlobalVariables(pData->data.sKey, JS_GLOBALDATA_TYPE_BOOLEAN, 0,
|
| + (bool)(pData->data.bData == 1), "",
|
| + v8::Local<v8::Object>(), pData->bPersistent == 1);
|
| + JS_PutObjectBoolean(NULL, (JSFXObject)(*m_pJSObject),
|
| + pData->data.sKey.UTF8Decode().c_str(),
|
| + (bool)(pData->data.bData == 1));
|
| + break;
|
| + case JS_GLOBALDATA_TYPE_STRING:
|
| + SetGlobalVariables(pData->data.sKey, JS_GLOBALDATA_TYPE_STRING, 0,
|
| + false, pData->data.sData, v8::Local<v8::Object>(),
|
| + pData->bPersistent == 1);
|
| + JS_PutObjectString(NULL, (JSFXObject)(*m_pJSObject),
|
| + pData->data.sKey.UTF8Decode().c_str(),
|
| + pData->data.sData.UTF8Decode().c_str());
|
| + break;
|
| + case JS_GLOBALDATA_TYPE_OBJECT: {
|
| + IJS_Runtime* pRuntime = JS_GetRuntime((JSFXObject)(*m_pJSObject));
|
| + v8::Local<v8::Object> pObj = JS_NewFxDynamicObj(pRuntime, NULL, -1);
|
| +
|
| + PutObjectProperty(pObj, &pData->data);
|
| +
|
| + SetGlobalVariables(pData->data.sKey, JS_GLOBALDATA_TYPE_OBJECT, 0,
|
| + false, "", (JSObject)pObj, pData->bPersistent == 1);
|
| + JS_PutObjectObject(NULL, (JSFXObject)(*m_pJSObject),
|
| + pData->data.sKey.UTF8Decode().c_str(),
|
| + (JSObject)pObj);
|
| + } break;
|
| + case JS_GLOBALDATA_TYPE_NULL:
|
| + SetGlobalVariables(pData->data.sKey, JS_GLOBALDATA_TYPE_NULL, 0, false,
|
| + "", v8::Local<v8::Object>(),
|
| + pData->bPersistent == 1);
|
| + JS_PutObjectNull(NULL, (JSFXObject)(*m_pJSObject),
|
| + pData->data.sKey.UTF8Decode().c_str());
|
| + break;
|
| }
|
| + }
|
| }
|
|
|
| -void global_alternate::PutObjectProperty(v8::Local<v8::Object> pObj, CJS_KeyValue* pData)
|
| -{
|
| - ASSERT(pData != NULL);
|
| -
|
| - for (int i=0,sz=pData->objData.Count(); i<sz; i++)
|
| - {
|
| - CJS_KeyValue* pObjData = pData->objData.GetAt(i);
|
| - ASSERT(pObjData != NULL);
|
| +void global_alternate::CommitGlobalPersisitentVariables() {
|
| + ASSERT(m_pGlobalData != NULL);
|
|
|
| - switch (pObjData->nType)
|
| - {
|
| - case JS_GLOBALDATA_TYPE_NUMBER:
|
| - JS_PutObjectNumber(NULL,(JSObject)pObj, pObjData->sKey.UTF8Decode().c_str(), pObjData->dData);
|
| + FX_POSITION pos = m_mapGlobal.GetStartPosition();
|
| + while (pos) {
|
| + CFX_ByteString name;
|
| + js_global_data* pData = NULL;
|
| + m_mapGlobal.GetNextAssoc(pos, name, (void*&)pData);
|
| +
|
| + if (pData) {
|
| + if (pData->bDeleted) {
|
| + m_pGlobalData->DeleteGlobalVariable(name);
|
| + } else {
|
| + switch (pData->nType) {
|
| + case JS_GLOBALDATA_TYPE_NUMBER:
|
| + m_pGlobalData->SetGlobalVariableNumber(name, pData->dData);
|
| + m_pGlobalData->SetGlobalVariablePersistent(name,
|
| + pData->bPersistent);
|
| break;
|
| - case JS_GLOBALDATA_TYPE_BOOLEAN:
|
| - JS_PutObjectBoolean(NULL,(JSObject)pObj, pObjData->sKey.UTF8Decode().c_str(), (bool)(pObjData->bData == 1));
|
| + case JS_GLOBALDATA_TYPE_BOOLEAN:
|
| + m_pGlobalData->SetGlobalVariableBoolean(name, pData->bData);
|
| + m_pGlobalData->SetGlobalVariablePersistent(name,
|
| + pData->bPersistent);
|
| break;
|
| - case JS_GLOBALDATA_TYPE_STRING:
|
| - JS_PutObjectString(NULL,(JSObject)pObj, pObjData->sKey.UTF8Decode().c_str(), pObjData->sData.UTF8Decode().c_str());
|
| + case JS_GLOBALDATA_TYPE_STRING:
|
| + m_pGlobalData->SetGlobalVariableString(name, pData->sData);
|
| + m_pGlobalData->SetGlobalVariablePersistent(name,
|
| + pData->bPersistent);
|
| break;
|
| - case JS_GLOBALDATA_TYPE_OBJECT:
|
| + case JS_GLOBALDATA_TYPE_OBJECT:
|
| + // if (pData->pData)
|
| {
|
| - IJS_Runtime* pRuntime = JS_GetRuntime((JSFXObject)(*m_pJSObject));
|
| - v8::Local<v8::Object> pNewObj = JS_NewFxDynamicObj(pRuntime, NULL, -1);
|
| - PutObjectProperty(pNewObj, pObjData);
|
| - JS_PutObjectObject(NULL, (JSObject)pObj, pObjData->sKey.UTF8Decode().c_str(), (JSObject)pNewObj);
|
| + CJS_GlobalVariableArray array;
|
| + v8::Local<v8::Object> obj = v8::Local<v8::Object>::New(
|
| + GetJSObject()->GetIsolate(), pData->pData);
|
| + ObjectToArray(obj, array);
|
| + m_pGlobalData->SetGlobalVariableObject(name, array);
|
| + m_pGlobalData->SetGlobalVariablePersistent(name,
|
| + pData->bPersistent);
|
| }
|
| break;
|
| - case JS_GLOBALDATA_TYPE_NULL:
|
| - JS_PutObjectNull(NULL,(JSObject)pObj, pObjData->sKey.UTF8Decode().c_str());
|
| + case JS_GLOBALDATA_TYPE_NULL:
|
| + m_pGlobalData->SetGlobalVariableNull(name);
|
| + m_pGlobalData->SetGlobalVariablePersistent(name,
|
| + pData->bPersistent);
|
| break;
|
| }
|
| + }
|
| }
|
| + }
|
| }
|
|
|
| -void global_alternate::DestroyGlobalPersisitentVariables()
|
| -{
|
| - FX_POSITION pos = m_mapGlobal.GetStartPosition();
|
| - while (pos)
|
| - {
|
| - CFX_ByteString name;
|
| - js_global_data* pData = NULL;
|
| - m_mapGlobal.GetNextAssoc(pos, name, (void*&)pData);
|
| - delete pData;
|
| +void global_alternate::ObjectToArray(v8::Local<v8::Object> pObj,
|
| + CJS_GlobalVariableArray& array) {
|
| + v8::Local<v8::Context> context = pObj->CreationContext();
|
| + v8::Isolate* isolate = context->GetIsolate();
|
| + v8::Local<v8::Array> pKeyList = JS_GetObjectElementNames(isolate, pObj);
|
| + int nObjElements = pKeyList->Length();
|
| +
|
| + for (int i = 0; i < nObjElements; i++) {
|
| + CFX_WideString ws =
|
| + JS_ToString(isolate, JS_GetArrayElement(isolate, pKeyList, i));
|
| + CFX_ByteString sKey = ws.UTF8Encode();
|
| +
|
| + v8::Local<v8::Value> v = JS_GetObjectElement(isolate, pObj, ws.c_str());
|
| + FXJSVALUETYPE vt = GET_VALUE_TYPE(v);
|
| + switch (vt) {
|
| + case VT_number: {
|
| + CJS_KeyValue* pObjElement = new CJS_KeyValue;
|
| + pObjElement->nType = JS_GLOBALDATA_TYPE_NUMBER;
|
| + pObjElement->sKey = sKey;
|
| + pObjElement->dData = JS_ToNumber(isolate, v);
|
| + array.Add(pObjElement);
|
| + } break;
|
| + case VT_boolean: {
|
| + CJS_KeyValue* pObjElement = new CJS_KeyValue;
|
| + pObjElement->nType = JS_GLOBALDATA_TYPE_BOOLEAN;
|
| + pObjElement->sKey = sKey;
|
| + pObjElement->dData = JS_ToBoolean(isolate, v);
|
| + array.Add(pObjElement);
|
| + } break;
|
| + case VT_string: {
|
| + CFX_ByteString sValue =
|
| + CJS_Value(isolate, v, VT_string).ToCFXByteString();
|
| + CJS_KeyValue* pObjElement = new CJS_KeyValue;
|
| + pObjElement->nType = JS_GLOBALDATA_TYPE_STRING;
|
| + pObjElement->sKey = sKey;
|
| + pObjElement->sData = sValue;
|
| + array.Add(pObjElement);
|
| + } break;
|
| + case VT_object: {
|
| + CJS_KeyValue* pObjElement = new CJS_KeyValue;
|
| + pObjElement->nType = JS_GLOBALDATA_TYPE_OBJECT;
|
| + pObjElement->sKey = sKey;
|
| + ObjectToArray(JS_ToObject(isolate, v), pObjElement->objData);
|
| + array.Add(pObjElement);
|
| + } break;
|
| + case VT_null: {
|
| + CJS_KeyValue* pObjElement = new CJS_KeyValue;
|
| + pObjElement->nType = JS_GLOBALDATA_TYPE_NULL;
|
| + pObjElement->sKey = sKey;
|
| + array.Add(pObjElement);
|
| + } break;
|
| + default:
|
| + break;
|
| }
|
| -
|
| - m_mapGlobal.RemoveAll();
|
| + }
|
| }
|
|
|
| +void global_alternate::PutObjectProperty(v8::Local<v8::Object> pObj,
|
| + CJS_KeyValue* pData) {
|
| + ASSERT(pData != NULL);
|
|
|
| -FX_BOOL global_alternate::SetGlobalVariables(const FX_CHAR* propname, int nType,
|
| - double dData, bool bData, const CFX_ByteString& sData, JSObject pData, bool bDefaultPersistent)
|
| -{
|
| - if (propname == NULL) return FALSE;
|
| + for (int i = 0, sz = pData->objData.Count(); i < sz; i++) {
|
| + CJS_KeyValue* pObjData = pData->objData.GetAt(i);
|
| + ASSERT(pObjData != NULL);
|
|
|
| - js_global_data* pTemp = NULL;
|
| - m_mapGlobal.Lookup(propname, (void*&)pTemp);
|
| + switch (pObjData->nType) {
|
| + case JS_GLOBALDATA_TYPE_NUMBER:
|
| + JS_PutObjectNumber(NULL, (JSObject)pObj,
|
| + pObjData->sKey.UTF8Decode().c_str(),
|
| + pObjData->dData);
|
| + break;
|
| + case JS_GLOBALDATA_TYPE_BOOLEAN:
|
| + JS_PutObjectBoolean(NULL, (JSObject)pObj,
|
| + pObjData->sKey.UTF8Decode().c_str(),
|
| + (bool)(pObjData->bData == 1));
|
| + break;
|
| + case JS_GLOBALDATA_TYPE_STRING:
|
| + JS_PutObjectString(NULL, (JSObject)pObj,
|
| + pObjData->sKey.UTF8Decode().c_str(),
|
| + pObjData->sData.UTF8Decode().c_str());
|
| + break;
|
| + case JS_GLOBALDATA_TYPE_OBJECT: {
|
| + IJS_Runtime* pRuntime = JS_GetRuntime((JSFXObject)(*m_pJSObject));
|
| + v8::Local<v8::Object> pNewObj = JS_NewFxDynamicObj(pRuntime, NULL, -1);
|
| + PutObjectProperty(pNewObj, pObjData);
|
| + JS_PutObjectObject(NULL, (JSObject)pObj,
|
| + pObjData->sKey.UTF8Decode().c_str(),
|
| + (JSObject)pNewObj);
|
| + } break;
|
| + case JS_GLOBALDATA_TYPE_NULL:
|
| + JS_PutObjectNull(NULL, (JSObject)pObj,
|
| + pObjData->sKey.UTF8Decode().c_str());
|
| + break;
|
| + }
|
| + }
|
| +}
|
|
|
| - if (pTemp)
|
| - {
|
| - if (pTemp->bDeleted || pTemp->nType != nType)
|
| - {
|
| - pTemp->dData = 0;
|
| - pTemp->bData = 0;
|
| - pTemp->sData = "";
|
| - pTemp->nType = nType;
|
| - }
|
| +void global_alternate::DestroyGlobalPersisitentVariables() {
|
| + FX_POSITION pos = m_mapGlobal.GetStartPosition();
|
| + while (pos) {
|
| + CFX_ByteString name;
|
| + js_global_data* pData = NULL;
|
| + m_mapGlobal.GetNextAssoc(pos, name, (void*&)pData);
|
| + delete pData;
|
| + }
|
|
|
| - pTemp->bDeleted = FALSE;
|
| + m_mapGlobal.RemoveAll();
|
| +}
|
|
|
| - switch (nType)
|
| - {
|
| - case JS_GLOBALDATA_TYPE_NUMBER:
|
| - {
|
| - pTemp->dData = dData;
|
| - }
|
| - break;
|
| - case JS_GLOBALDATA_TYPE_BOOLEAN:
|
| - {
|
| - pTemp->bData = bData;
|
| - }
|
| - break;
|
| - case JS_GLOBALDATA_TYPE_STRING:
|
| - {
|
| - pTemp->sData = sData;
|
| - }
|
| - break;
|
| - case JS_GLOBALDATA_TYPE_OBJECT:
|
| - {
|
| - pTemp->pData.Reset(JS_GetRuntime(pData), pData);
|
| - }
|
| - break;
|
| - case JS_GLOBALDATA_TYPE_NULL:
|
| - break;
|
| - default:
|
| - return FALSE;
|
| - }
|
| +FX_BOOL global_alternate::SetGlobalVariables(const FX_CHAR* propname,
|
| + int nType,
|
| + double dData,
|
| + bool bData,
|
| + const CFX_ByteString& sData,
|
| + JSObject pData,
|
| + bool bDefaultPersistent) {
|
| + if (propname == NULL)
|
| + return FALSE;
|
|
|
| - return TRUE;
|
| - }
|
| + js_global_data* pTemp = NULL;
|
| + m_mapGlobal.Lookup(propname, (void*&)pTemp);
|
|
|
| - js_global_data* pNewData = NULL;
|
| + if (pTemp) {
|
| + if (pTemp->bDeleted || pTemp->nType != nType) {
|
| + pTemp->dData = 0;
|
| + pTemp->bData = 0;
|
| + pTemp->sData = "";
|
| + pTemp->nType = nType;
|
| + }
|
|
|
| - switch (nType)
|
| - {
|
| - case JS_GLOBALDATA_TYPE_NUMBER:
|
| - {
|
| - pNewData = new js_global_data;
|
| - pNewData->nType = JS_GLOBALDATA_TYPE_NUMBER;
|
| - pNewData->dData = dData;
|
| - pNewData->bPersistent = bDefaultPersistent;
|
| - }
|
| - break;
|
| - case JS_GLOBALDATA_TYPE_BOOLEAN:
|
| - {
|
| - pNewData = new js_global_data;
|
| - pNewData->nType = JS_GLOBALDATA_TYPE_BOOLEAN;
|
| - pNewData->bData = bData;
|
| - pNewData->bPersistent = bDefaultPersistent;
|
| - }
|
| - break;
|
| - case JS_GLOBALDATA_TYPE_STRING:
|
| - {
|
| - pNewData = new js_global_data;
|
| - pNewData->nType = JS_GLOBALDATA_TYPE_STRING;
|
| - pNewData->sData = sData;
|
| - pNewData->bPersistent = bDefaultPersistent;
|
| - }
|
| - break;
|
| - case JS_GLOBALDATA_TYPE_OBJECT:
|
| - {
|
| - pNewData = new js_global_data;
|
| - pNewData->nType = JS_GLOBALDATA_TYPE_OBJECT;
|
| - pNewData->pData.Reset(JS_GetRuntime(pData), pData);
|
| - pNewData->bPersistent = bDefaultPersistent;
|
| - }
|
| - break;
|
| - case JS_GLOBALDATA_TYPE_NULL:
|
| - {
|
| - pNewData = new js_global_data;
|
| - pNewData->nType = JS_GLOBALDATA_TYPE_NULL;
|
| - pNewData->bPersistent = bDefaultPersistent;
|
| - }
|
| + pTemp->bDeleted = FALSE;
|
| +
|
| + switch (nType) {
|
| + case JS_GLOBALDATA_TYPE_NUMBER: {
|
| + pTemp->dData = dData;
|
| + } break;
|
| + case JS_GLOBALDATA_TYPE_BOOLEAN: {
|
| + pTemp->bData = bData;
|
| + } break;
|
| + case JS_GLOBALDATA_TYPE_STRING: {
|
| + pTemp->sData = sData;
|
| + } break;
|
| + case JS_GLOBALDATA_TYPE_OBJECT: {
|
| + pTemp->pData.Reset(JS_GetRuntime(pData), pData);
|
| + } break;
|
| + case JS_GLOBALDATA_TYPE_NULL:
|
| break;
|
| - default:
|
| + default:
|
| return FALSE;
|
| }
|
|
|
| - m_mapGlobal.SetAt(propname, (void*)pNewData);
|
| -
|
| return TRUE;
|
| + }
|
| +
|
| + js_global_data* pNewData = NULL;
|
| +
|
| + switch (nType) {
|
| + case JS_GLOBALDATA_TYPE_NUMBER: {
|
| + pNewData = new js_global_data;
|
| + pNewData->nType = JS_GLOBALDATA_TYPE_NUMBER;
|
| + pNewData->dData = dData;
|
| + pNewData->bPersistent = bDefaultPersistent;
|
| + } break;
|
| + case JS_GLOBALDATA_TYPE_BOOLEAN: {
|
| + pNewData = new js_global_data;
|
| + pNewData->nType = JS_GLOBALDATA_TYPE_BOOLEAN;
|
| + pNewData->bData = bData;
|
| + pNewData->bPersistent = bDefaultPersistent;
|
| + } break;
|
| + case JS_GLOBALDATA_TYPE_STRING: {
|
| + pNewData = new js_global_data;
|
| + pNewData->nType = JS_GLOBALDATA_TYPE_STRING;
|
| + pNewData->sData = sData;
|
| + pNewData->bPersistent = bDefaultPersistent;
|
| + } break;
|
| + case JS_GLOBALDATA_TYPE_OBJECT: {
|
| + pNewData = new js_global_data;
|
| + pNewData->nType = JS_GLOBALDATA_TYPE_OBJECT;
|
| + pNewData->pData.Reset(JS_GetRuntime(pData), pData);
|
| + pNewData->bPersistent = bDefaultPersistent;
|
| + } break;
|
| + case JS_GLOBALDATA_TYPE_NULL: {
|
| + pNewData = new js_global_data;
|
| + pNewData->nType = JS_GLOBALDATA_TYPE_NULL;
|
| + pNewData->bPersistent = bDefaultPersistent;
|
| + } break;
|
| + default:
|
| + return FALSE;
|
| + }
|
| +
|
| + m_mapGlobal.SetAt(propname, (void*)pNewData);
|
| +
|
| + return TRUE;
|
| }
|
|
|
| -FXJSVALUETYPE GET_VALUE_TYPE(v8::Local<v8::Value> p)
|
| -{
|
| +FXJSVALUETYPE GET_VALUE_TYPE(v8::Local<v8::Value> p) {
|
| const unsigned int nHash = JS_CalcHash(JS_GetTypeof(p));
|
|
|
| if (nHash == JSCONST_nUndefHash)
|
|
|