OLD | NEW |
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 "../../include/javascript/IJavaScript.h" | 7 #include "../../include/javascript/IJavaScript.h" |
8 #include "../../include/javascript/JS_Context.h" | 8 #include "../../include/javascript/JS_Context.h" |
9 #include "../../include/javascript/JS_Define.h" | 9 #include "../../include/javascript/JS_Define.h" |
10 #include "../../include/javascript/JS_EventHandler.h" | 10 #include "../../include/javascript/JS_EventHandler.h" |
(...skipping 151 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
162 { | 162 { |
163 if (vp.IsSetting()) | 163 if (vp.IsSetting()) |
164 { | 164 { |
165 CFX_ByteString sPropName = CFX_ByteString::FromUnicode(propname)
; | 165 CFX_ByteString sPropName = CFX_ByteString::FromUnicode(propname)
; |
166 switch (vp.GetType()) | 166 switch (vp.GetType()) |
167 { | 167 { |
168 case VT_number: | 168 case VT_number: |
169 { | 169 { |
170 double dData; | 170 double dData; |
171 vp >> dData; | 171 vp >> dData; |
172 » » » » return SetGlobalVariables(sPropName, JS_GLOBALDA
TA_TYPE_NUMBER, dData, false, "", v8::Handle<v8::Object>(), FALSE); | 172 » » » » return SetGlobalVariables(sPropName, JS_GLOBALDA
TA_TYPE_NUMBER, dData, false, "", v8::Local<v8::Object>(), FALSE); |
173 } | 173 } |
174 case VT_boolean: | 174 case VT_boolean: |
175 { | 175 { |
176 bool bData; | 176 bool bData; |
177 vp >> bData; | 177 vp >> bData; |
178 » » » » return SetGlobalVariables(sPropName, JS_GLOBALDA
TA_TYPE_BOOLEAN, 0, bData, "", v8::Handle<v8::Object>(), FALSE); | 178 » » » » return SetGlobalVariables(sPropName, JS_GLOBALDA
TA_TYPE_BOOLEAN, 0, bData, "", v8::Local<v8::Object>(), FALSE); |
179 } | 179 } |
180 case VT_string: | 180 case VT_string: |
181 { | 181 { |
182 CFX_ByteString sData; | 182 CFX_ByteString sData; |
183 vp >> sData; | 183 vp >> sData; |
184 » » » » return SetGlobalVariables(sPropName, JS_GLOBALDA
TA_TYPE_STRING, 0, false, sData, v8::Handle<v8::Object>(), FALSE); | 184 » » » » return SetGlobalVariables(sPropName, JS_GLOBALDA
TA_TYPE_STRING, 0, false, sData, v8::Local<v8::Object>(), FALSE); |
185 } | 185 } |
186 case VT_object: | 186 case VT_object: |
187 { | 187 { |
188 JSObject pData; | 188 JSObject pData; |
189 vp >> pData; | 189 vp >> pData; |
190 return SetGlobalVariables(sPropName, JS_GLOBALDA
TA_TYPE_OBJECT, 0, false, "", pData, FALSE); | 190 return SetGlobalVariables(sPropName, JS_GLOBALDA
TA_TYPE_OBJECT, 0, false, "", pData, FALSE); |
191 } | 191 } |
192 case VT_null: | 192 case VT_null: |
193 { | 193 { |
194 » » » » return SetGlobalVariables(sPropName, JS_GLOBALDA
TA_TYPE_NULL, 0, false, "", v8::Handle<v8::Object>(), FALSE); | 194 » » » » return SetGlobalVariables(sPropName, JS_GLOBALDA
TA_TYPE_NULL, 0, false, "", v8::Local<v8::Object>(), FALSE); |
195 } | 195 } |
196 case VT_undefined: | 196 case VT_undefined: |
197 { | 197 { |
198 DelProperty(cc, propname, sError); | 198 DelProperty(cc, propname, sError); |
199 return TRUE; | 199 return TRUE; |
200 } | 200 } |
201 default: | 201 default: |
202 return FALSE; | 202 return FALSE; |
203 } | 203 } |
204 } | 204 } |
(...skipping 14 matching lines...) Expand all Loading... |
219 vp << pData->dData; | 219 vp << pData->dData; |
220 break; | 220 break; |
221 case JS_GLOBALDATA_TYPE_BOOLEAN: | 221 case JS_GLOBALDATA_TYPE_BOOLEAN: |
222 vp << pData->bData; | 222 vp << pData->bData; |
223 break; | 223 break; |
224 case JS_GLOBALDATA_TYPE_STRING: | 224 case JS_GLOBALDATA_TYPE_STRING: |
225 vp << pData->sData; | 225 vp << pData->sData; |
226 break; | 226 break; |
227 case JS_GLOBALDATA_TYPE_OBJECT: | 227 case JS_GLOBALDATA_TYPE_OBJECT: |
228 { | 228 { |
229 » » » » » » » v8::Handle<v8::Object> o
bj = v8::Local<v8::Object>::New(vp.GetIsolate(),pData->pData); | 229 » » » » » » » v8::Local<v8::Object> ob
j = v8::Local<v8::Object>::New(vp.GetIsolate(),pData->pData); |
230 vp << obj; | 230 vp << obj; |
231 break; | 231 break; |
232 } | 232 } |
233 case JS_GLOBALDATA_TYPE_NULL: | 233 case JS_GLOBALDATA_TYPE_NULL: |
234 vp.SetNull(); | 234 vp.SetNull(); |
235 break; | 235 break; |
236 default: | 236 default: |
237 return FALSE; | 237 return FALSE; |
238 } | 238 } |
239 return TRUE; | 239 return TRUE; |
(...skipping 49 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
289 ASSERT(m_pGlobalData != NULL); | 289 ASSERT(m_pGlobalData != NULL); |
290 | 290 |
291 for (int i=0,sz=m_pGlobalData->GetSize(); i<sz; i++) | 291 for (int i=0,sz=m_pGlobalData->GetSize(); i<sz; i++) |
292 { | 292 { |
293 CJS_GlobalData_Element* pData = m_pGlobalData->GetAt(i); | 293 CJS_GlobalData_Element* pData = m_pGlobalData->GetAt(i); |
294 ASSERT(pData != NULL); | 294 ASSERT(pData != NULL); |
295 | 295 |
296 switch (pData->data.nType) | 296 switch (pData->data.nType) |
297 { | 297 { |
298 case JS_GLOBALDATA_TYPE_NUMBER: | 298 case JS_GLOBALDATA_TYPE_NUMBER: |
299 » » » this->SetGlobalVariables(pData->data.sKey, JS_GLOBALDATA
_TYPE_NUMBER, pData->data.dData, false, "", v8::Handle<v8::Object>(), pData->bPe
rsistent == 1); | 299 » » » this->SetGlobalVariables(pData->data.sKey, JS_GLOBALDATA
_TYPE_NUMBER, pData->data.dData, false, "", v8::Local<v8::Object>(), pData->bPer
sistent == 1); |
300 JS_PutObjectNumber(NULL,(JSFXObject)(*m_pJSObject), | 300 JS_PutObjectNumber(NULL,(JSFXObject)(*m_pJSObject), |
301 pData->data.sKey.UTF8
Decode().c_str(), pData->data.dData); | 301 pData->data.sKey.UTF8
Decode().c_str(), pData->data.dData); |
302 break; | 302 break; |
303 case JS_GLOBALDATA_TYPE_BOOLEAN: | 303 case JS_GLOBALDATA_TYPE_BOOLEAN: |
304 » » » this->SetGlobalVariables(pData->data.sKey, JS_GLOBALDATA
_TYPE_BOOLEAN, 0, (bool)(pData->data.bData == 1), "", v8::Handle<v8::Object>(),
pData->bPersistent == 1); | 304 » » » this->SetGlobalVariables(pData->data.sKey, JS_GLOBALDATA
_TYPE_BOOLEAN, 0, (bool)(pData->data.bData == 1), "", v8::Local<v8::Object>(), p
Data->bPersistent == 1); |
305 JS_PutObjectBoolean(NULL,(JSFXObject)(*m_pJSObject), | 305 JS_PutObjectBoolean(NULL,(JSFXObject)(*m_pJSObject), |
306 pData->data.sKey
.UTF8Decode().c_str(), (bool)(pData->data.bData == 1)); | 306 pData->data.sKey
.UTF8Decode().c_str(), (bool)(pData->data.bData == 1)); |
307 break; | 307 break; |
308 case JS_GLOBALDATA_TYPE_STRING: | 308 case JS_GLOBALDATA_TYPE_STRING: |
309 » » » this->SetGlobalVariables(pData->data.sKey, JS_GLOBALDATA
_TYPE_STRING, 0, false, pData->data.sData, v8::Handle<v8::Object>(), pData->bPer
sistent == 1); | 309 » » » this->SetGlobalVariables(pData->data.sKey, JS_GLOBALDATA
_TYPE_STRING, 0, false, pData->data.sData, v8::Local<v8::Object>(), pData->bPers
istent == 1); |
310 JS_PutObjectString(NULL, (JSFXObject)(*m_pJSObject), | 310 JS_PutObjectString(NULL, (JSFXObject)(*m_pJSObject), |
311 pData->data.sKey.UTF8
Decode().c_str(), | 311 pData->data.sKey.UTF8
Decode().c_str(), |
312 pData->data.sData.UTF
8Decode().c_str()); | 312 pData->data.sData.UTF
8Decode().c_str()); |
313 break; | 313 break; |
314 case JS_GLOBALDATA_TYPE_OBJECT: | 314 case JS_GLOBALDATA_TYPE_OBJECT: |
315 { | 315 { |
316 IJS_Runtime* pRuntime = JS_GetRuntime((JSFXObjec
t)(*m_pJSObject)); | 316 IJS_Runtime* pRuntime = JS_GetRuntime((JSFXObjec
t)(*m_pJSObject)); |
317 » » » » v8::Handle<v8::Object> pObj = JS_NewFxDynamicObj
(pRuntime, NULL, -1); | 317 » » » » v8::Local<v8::Object> pObj = JS_NewFxDynamicObj(
pRuntime, NULL, -1); |
318 | 318 |
319 PutObjectProperty(pObj, &pData->data); | 319 PutObjectProperty(pObj, &pData->data); |
320 | 320 |
321 this->SetGlobalVariables(pData->data.sKey, JS_GL
OBALDATA_TYPE_OBJECT, 0, false, "", | 321 this->SetGlobalVariables(pData->data.sKey, JS_GL
OBALDATA_TYPE_OBJECT, 0, false, "", |
322 (JSObject)pObj, pData->bPersistent == 1)
; | 322 (JSObject)pObj, pData->bPersistent == 1)
; |
323 JS_PutObjectObject(NULL,(JSFXObject)(*m_pJSObjec
t), | 323 JS_PutObjectObject(NULL,(JSFXObject)(*m_pJSObjec
t), |
324 pData->data.s
Key.UTF8Decode().c_str(), (JSObject)pObj); | 324 pData->data.s
Key.UTF8Decode().c_str(), (JSObject)pObj); |
325 } | 325 } |
326 break; | 326 break; |
327 case JS_GLOBALDATA_TYPE_NULL: | 327 case JS_GLOBALDATA_TYPE_NULL: |
328 » » » this->SetGlobalVariables(pData->data.sKey, JS_GLOBALDATA
_TYPE_NULL, 0, false, "", v8::Handle<v8::Object>(), pData->bPersistent == 1); | 328 » » » this->SetGlobalVariables(pData->data.sKey, JS_GLOBALDATA
_TYPE_NULL, 0, false, "", v8::Local<v8::Object>(), pData->bPersistent == 1); |
329 JS_PutObjectNull(NULL,(JSFXObject)(*m_pJSObject), | 329 JS_PutObjectNull(NULL,(JSFXObject)(*m_pJSObject), |
330 pData->data.sKey.UTF8De
code().c_str()); | 330 pData->data.sKey.UTF8De
code().c_str()); |
331 break; | 331 break; |
332 } | 332 } |
333 } | 333 } |
334 } | 334 } |
335 | 335 |
336 void global_alternate::CommitGlobalPersisitentVariables() | 336 void global_alternate::CommitGlobalPersisitentVariables() |
337 { | 337 { |
338 ASSERT(m_pGlobalData != NULL); | 338 ASSERT(m_pGlobalData != NULL); |
(...skipping 24 matching lines...) Expand all Loading... |
363 m_pGlobalData->SetGlobalVariablePersiste
nt(name, pData->bPersistent); | 363 m_pGlobalData->SetGlobalVariablePersiste
nt(name, pData->bPersistent); |
364 break; | 364 break; |
365 case JS_GLOBALDATA_TYPE_STRING: | 365 case JS_GLOBALDATA_TYPE_STRING: |
366 m_pGlobalData->SetGlobalVariableString(n
ame, pData->sData); | 366 m_pGlobalData->SetGlobalVariableString(n
ame, pData->sData); |
367 m_pGlobalData->SetGlobalVariablePersiste
nt(name, pData->bPersistent); | 367 m_pGlobalData->SetGlobalVariablePersiste
nt(name, pData->bPersistent); |
368 break; | 368 break; |
369 case JS_GLOBALDATA_TYPE_OBJECT: | 369 case JS_GLOBALDATA_TYPE_OBJECT: |
370 //if (pData->pData) | 370 //if (pData->pData) |
371 { | 371 { |
372 CJS_GlobalVariableArray array; | 372 CJS_GlobalVariableArray array; |
373 » » » » » » v8::Handle<v8::Object> obj = v8:
:Local<v8::Object>::New(GetJSObject()->GetIsolate(),pData->pData); | 373 » » » » » » v8::Local<v8::Object> obj = v8::
Local<v8::Object>::New(GetJSObject()->GetIsolate(),pData->pData); |
374 ObjectToArray(obj, array); | 374 ObjectToArray(obj, array); |
375 m_pGlobalData->SetGlobalVariable
Object(name, array); | 375 m_pGlobalData->SetGlobalVariable
Object(name, array); |
376 m_pGlobalData->SetGlobalVariable
Persistent(name, pData->bPersistent); | 376 m_pGlobalData->SetGlobalVariable
Persistent(name, pData->bPersistent); |
377 } | 377 } |
378 break; | 378 break; |
379 case JS_GLOBALDATA_TYPE_NULL: | 379 case JS_GLOBALDATA_TYPE_NULL: |
380 m_pGlobalData->SetGlobalVariableNull(nam
e); | 380 m_pGlobalData->SetGlobalVariableNull(nam
e); |
381 m_pGlobalData->SetGlobalVariablePersiste
nt(name, pData->bPersistent); | 381 m_pGlobalData->SetGlobalVariablePersiste
nt(name, pData->bPersistent); |
382 break; | 382 break; |
383 } | 383 } |
384 } | 384 } |
385 } | 385 } |
386 } | 386 } |
387 } | 387 } |
388 | 388 |
389 void global_alternate::ObjectToArray(v8::Handle<v8::Object> pObj, CJS_GlobalVari
ableArray& array) | 389 void global_alternate::ObjectToArray(v8::Local<v8::Object> pObj, CJS_GlobalVaria
bleArray& array) |
390 { | 390 { |
391 v8::Handle<v8::Array> pKeyList = JS_GetObjectElementNames(pObj); | |
392 int nObjElements = pKeyList->Length(); | |
393 | |
394 v8::Local<v8::Context> context = pObj->CreationContext(); | 391 v8::Local<v8::Context> context = pObj->CreationContext(); |
395 v8::Isolate* isolate = context->GetIsolate(); | 392 v8::Isolate* isolate = context->GetIsolate(); |
| 393 v8::Local<v8::Array> pKeyList = JS_GetObjectElementNames(isolate, pObj); |
| 394 int nObjElements = pKeyList->Length(); |
396 | 395 |
397 for (int i=0; i<nObjElements; i++) | 396 for (int i=0; i<nObjElements; i++) |
398 { | 397 { |
399 | 398 |
400 » » CFX_WideString ws = JS_ToString(JS_GetArrayElemnet(pKeyList, i))
; | 399 » » CFX_WideString ws = JS_ToString(isolate, JS_GetArrayElement(isol
ate, pKeyList, i)); |
401 CFX_ByteString sKey = ws.UTF8Encode(); | 400 CFX_ByteString sKey = ws.UTF8Encode(); |
402 | 401 |
403 » » v8::Handle<v8::Value> v = JS_GetObjectElement(isolate, pObj, ws.
c_str()); | 402 » » v8::Local<v8::Value> v = JS_GetObjectElement(isolate, pObj, ws.c
_str()); |
404 FXJSVALUETYPE vt = GET_VALUE_TYPE(v); | 403 FXJSVALUETYPE vt = GET_VALUE_TYPE(v); |
405 switch (vt) | 404 switch (vt) |
406 { | 405 { |
407 case VT_number: | 406 case VT_number: |
408 { | 407 { |
409 CJS_KeyValue* pObjElement = new CJS_KeyValue; | 408 CJS_KeyValue* pObjElement = new CJS_KeyValue; |
410 pObjElement->nType = JS_GLOBALDATA_TYPE_NUMBER; | 409 pObjElement->nType = JS_GLOBALDATA_TYPE_NUMBER; |
411 pObjElement->sKey = sKey; | 410 pObjElement->sKey = sKey; |
412 » » » » pObjElement->dData = JS_ToNumber(v); | 411 » » » » pObjElement->dData = JS_ToNumber(isolate, v); |
413 array.Add(pObjElement); | 412 array.Add(pObjElement); |
414 } | 413 } |
415 break; | 414 break; |
416 case VT_boolean: | 415 case VT_boolean: |
417 { | 416 { |
418 CJS_KeyValue* pObjElement = new CJS_KeyValue; | 417 CJS_KeyValue* pObjElement = new CJS_KeyValue; |
419 pObjElement->nType = JS_GLOBALDATA_TYPE_BOOLEAN; | 418 pObjElement->nType = JS_GLOBALDATA_TYPE_BOOLEAN; |
420 pObjElement->sKey = sKey; | 419 pObjElement->sKey = sKey; |
421 » » » » pObjElement->dData = JS_ToBoolean(v); | 420 » » » » pObjElement->dData = JS_ToBoolean(isolate, v); |
422 array.Add(pObjElement); | 421 array.Add(pObjElement); |
423 } | 422 } |
424 break; | 423 break; |
425 case VT_string: | 424 case VT_string: |
426 { | 425 { |
427 CFX_ByteString sValue = CJS_Value(isolate, v, VT
_string).ToCFXByteString(); | 426 CFX_ByteString sValue = CJS_Value(isolate, v, VT
_string).ToCFXByteString(); |
428 CJS_KeyValue* pObjElement = new CJS_KeyValue; | 427 CJS_KeyValue* pObjElement = new CJS_KeyValue; |
429 pObjElement->nType = JS_GLOBALDATA_TYPE_STRING; | 428 pObjElement->nType = JS_GLOBALDATA_TYPE_STRING; |
430 pObjElement->sKey = sKey; | 429 pObjElement->sKey = sKey; |
431 pObjElement->sData = sValue; | 430 pObjElement->sData = sValue; |
432 array.Add(pObjElement); | 431 array.Add(pObjElement); |
433 } | 432 } |
434 break; | 433 break; |
435 case VT_object: | 434 case VT_object: |
436 { | 435 { |
437 CJS_KeyValue* pObjElement = new CJS_KeyValue; | 436 CJS_KeyValue* pObjElement = new CJS_KeyValue; |
438 pObjElement->nType = JS_GLOBALDATA_TYPE_OBJECT; | 437 pObjElement->nType = JS_GLOBALDATA_TYPE_OBJECT; |
439 pObjElement->sKey = sKey; | 438 pObjElement->sKey = sKey; |
440 » » » » ObjectToArray(JS_ToObject(v), pObjElement->objDa
ta); | 439 » » » » ObjectToArray(JS_ToObject(isolate, v), pObjEleme
nt->objData); |
441 array.Add(pObjElement); | 440 array.Add(pObjElement); |
442 } | 441 } |
443 break; | 442 break; |
444 case VT_null: | 443 case VT_null: |
445 { | 444 { |
446 CJS_KeyValue* pObjElement = new CJS_KeyValue; | 445 CJS_KeyValue* pObjElement = new CJS_KeyValue; |
447 pObjElement->nType = JS_GLOBALDATA_TYPE_NULL; | 446 pObjElement->nType = JS_GLOBALDATA_TYPE_NULL; |
448 pObjElement->sKey = sKey; | 447 pObjElement->sKey = sKey; |
449 array.Add(pObjElement); | 448 array.Add(pObjElement); |
450 } | 449 } |
451 break; | 450 break; |
452 default: | 451 default: |
453 break; | 452 break; |
454 } | 453 } |
455 } | 454 } |
456 } | 455 } |
457 | 456 |
458 void global_alternate::PutObjectProperty(v8::Handle<v8::Object> pObj, CJS_KeyVal
ue* pData) | 457 void global_alternate::PutObjectProperty(v8::Local<v8::Object> pObj, CJS_KeyValu
e* pData) |
459 { | 458 { |
460 ASSERT(pData != NULL); | 459 ASSERT(pData != NULL); |
461 | 460 |
462 for (int i=0,sz=pData->objData.Count(); i<sz; i++) | 461 for (int i=0,sz=pData->objData.Count(); i<sz; i++) |
463 { | 462 { |
464 CJS_KeyValue* pObjData = pData->objData.GetAt(i); | 463 CJS_KeyValue* pObjData = pData->objData.GetAt(i); |
465 ASSERT(pObjData != NULL); | 464 ASSERT(pObjData != NULL); |
466 | 465 |
467 switch (pObjData->nType) | 466 switch (pObjData->nType) |
468 { | 467 { |
469 case JS_GLOBALDATA_TYPE_NUMBER: | 468 case JS_GLOBALDATA_TYPE_NUMBER: |
470 JS_PutObjectNumber(NULL,(JSObject)pObj, pObjData->sKey.U
TF8Decode().c_str(), pObjData->dData); | 469 JS_PutObjectNumber(NULL,(JSObject)pObj, pObjData->sKey.U
TF8Decode().c_str(), pObjData->dData); |
471 break; | 470 break; |
472 case JS_GLOBALDATA_TYPE_BOOLEAN: | 471 case JS_GLOBALDATA_TYPE_BOOLEAN: |
473 JS_PutObjectBoolean(NULL,(JSObject)pObj, pObjData->sKey.
UTF8Decode().c_str(), (bool)(pObjData->bData == 1)); | 472 JS_PutObjectBoolean(NULL,(JSObject)pObj, pObjData->sKey.
UTF8Decode().c_str(), (bool)(pObjData->bData == 1)); |
474 break; | 473 break; |
475 case JS_GLOBALDATA_TYPE_STRING: | 474 case JS_GLOBALDATA_TYPE_STRING: |
476 JS_PutObjectString(NULL,(JSObject)pObj, pObjData->sKey.U
TF8Decode().c_str(), pObjData->sData.UTF8Decode().c_str()); | 475 JS_PutObjectString(NULL,(JSObject)pObj, pObjData->sKey.U
TF8Decode().c_str(), pObjData->sData.UTF8Decode().c_str()); |
477 break; | 476 break; |
478 case JS_GLOBALDATA_TYPE_OBJECT: | 477 case JS_GLOBALDATA_TYPE_OBJECT: |
479 { | 478 { |
480 IJS_Runtime* pRuntime = JS_GetRuntime((JSFXObjec
t)(*m_pJSObject)); | 479 IJS_Runtime* pRuntime = JS_GetRuntime((JSFXObjec
t)(*m_pJSObject)); |
481 » » » » v8::Handle<v8::Object> pNewObj = JS_NewFxDynamic
Obj(pRuntime, NULL, -1); | 480 » » » » v8::Local<v8::Object> pNewObj = JS_NewFxDynamicO
bj(pRuntime, NULL, -1); |
482 PutObjectProperty(pNewObj, pObjData); | 481 PutObjectProperty(pNewObj, pObjData); |
483 JS_PutObjectObject(NULL, (JSObject)pObj, pObjDat
a->sKey.UTF8Decode().c_str(), (JSObject)pNewObj); | 482 JS_PutObjectObject(NULL, (JSObject)pObj, pObjDat
a->sKey.UTF8Decode().c_str(), (JSObject)pNewObj); |
484 } | 483 } |
485 break; | 484 break; |
486 case JS_GLOBALDATA_TYPE_NULL: | 485 case JS_GLOBALDATA_TYPE_NULL: |
487 JS_PutObjectNull(NULL,(JSObject)pObj, pObjData->sKey.UTF
8Decode().c_str()); | 486 JS_PutObjectNull(NULL,(JSObject)pObj, pObjData->sKey.UTF
8Decode().c_str()); |
488 break; | 487 break; |
489 } | 488 } |
490 } | 489 } |
491 } | 490 } |
(...skipping 109 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
601 break; | 600 break; |
602 default: | 601 default: |
603 return FALSE; | 602 return FALSE; |
604 } | 603 } |
605 | 604 |
606 m_mapGlobal.SetAt(propname, (FX_LPVOID)pNewData); | 605 m_mapGlobal.SetAt(propname, (FX_LPVOID)pNewData); |
607 | 606 |
608 return TRUE; | 607 return TRUE; |
609 } | 608 } |
610 | 609 |
611 FXJSVALUETYPE GET_VALUE_TYPE(v8::Handle<v8::Value> p) | 610 FXJSVALUETYPE GET_VALUE_TYPE(v8::Local<v8::Value> p) |
612 { | 611 { |
613 const unsigned int nHash = JS_CalcHash(JS_GetTypeof(p)); | 612 const unsigned int nHash = JS_CalcHash(JS_GetTypeof(p)); |
614 | 613 |
615 if (nHash == JSCONST_nUndefHash) | 614 if (nHash == JSCONST_nUndefHash) |
616 return VT_undefined; | 615 return VT_undefined; |
617 if (nHash == JSCONST_nNullHash) | 616 if (nHash == JSCONST_nNullHash) |
618 return VT_null; | 617 return VT_null; |
619 if (nHash == JSCONST_nStringHash) | 618 if (nHash == JSCONST_nStringHash) |
620 return VT_string; | 619 return VT_string; |
621 if (nHash == JSCONST_nNumberHash) | 620 if (nHash == JSCONST_nNumberHash) |
622 return VT_number; | 621 return VT_number; |
623 if (nHash == JSCONST_nBoolHash) | 622 if (nHash == JSCONST_nBoolHash) |
624 return VT_boolean; | 623 return VT_boolean; |
625 if (nHash == JSCONST_nDateHash) | 624 if (nHash == JSCONST_nDateHash) |
626 return VT_date; | 625 return VT_date; |
627 if (nHash == JSCONST_nObjectHash) | 626 if (nHash == JSCONST_nObjectHash) |
628 return VT_object; | 627 return VT_object; |
629 if (nHash == JSCONST_nFXobjHash) | 628 if (nHash == JSCONST_nFXobjHash) |
630 return VT_fxobject; | 629 return VT_fxobject; |
631 | 630 |
632 return VT_unknown; | 631 return VT_unknown; |
633 } | 632 } |
634 | 633 |
OLD | NEW |