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 "../../../core/include/fxcrt/fx_basic.h" | 7 #include "../../../core/include/fxcrt/fx_basic.h" |
8 #include "../../../core/include/fxcrt/fx_ext.h" | 8 #include "../../../core/include/fxcrt/fx_ext.h" |
9 #include "../../include/jsapi/fxjs_v8.h" | 9 #include "../../include/jsapi/fxjs_v8.h" |
10 #include "../../include/fsdk_define.h" | 10 #include "../../include/fsdk_define.h" |
11 #include "time.h" | 11 #include "time.h" |
12 #include <cmath> | 12 #include <cmath> |
13 #include <limits> | 13 #include <limits> |
14 | 14 |
15 #define VALUE_NAME_STRING L"string" | 15 #define VALUE_NAME_STRING L"string" |
16 #define VALUE_NAME_NUMBER L"number" | 16 #define VALUE_NAME_NUMBER L"number" |
17 #define VALUE_NAME_BOOLEAN L"boolean" | 17 #define VALUE_NAME_BOOLEAN L"boolean" |
18 #define VALUE_NAME_DATE L"date" | 18 #define VALUE_NAME_DATE L"date" |
19 #define VALUE_NAME_OBJECT L"object" | 19 #define VALUE_NAME_OBJECT L"object" |
20 #define VALUE_NAME_FXOBJ L"fxobj" | 20 #define VALUE_NAME_FXOBJ L"fxobj" |
21 #define VALUE_NAME_NULL L"null" | 21 #define VALUE_NAME_NULL L"null" |
22 #define VALUE_NAME_UNDEFINED L"undefined" | 22 #define VALUE_NAME_UNDEFINED L"undefined" |
23 | 23 |
24 static FX_DWORD g_nan[2] = {0,0x7FF80000 }; | 24 static FX_DWORD g_nan[2] = { 0, 0x7FF80000 }; |
25 double g_NaN = (*(double *)g_nan); | 25 double g_NaN = (*(double*)g_nan); |
26 | 26 |
27 | 27 class CJS_PrivateData : public CFX_Object { |
28 class CJS_PrivateData: public CFX_Object | 28 public: |
| 29 CJS_PrivateData() : ObjDefID(-1), pPrivate(NULL) {} |
| 30 int ObjDefID; |
| 31 FX_LPVOID pPrivate; |
| 32 }; |
| 33 |
| 34 class CJS_ObjDefintion : public CFX_Object { |
| 35 public: |
| 36 CJS_ObjDefintion(v8::Isolate* isolate, |
| 37 const wchar_t* sObjName, |
| 38 FXJSOBJTYPE eObjType, |
| 39 LP_CONSTRUCTOR pConstructor, |
| 40 LP_DESTRUCTOR pDestructor, |
| 41 unsigned bApplyNew) |
| 42 : objName(sObjName), |
| 43 objType(eObjType), |
| 44 m_pConstructor(pConstructor), |
| 45 m_pDestructor(pDestructor), |
| 46 m_bApplyNew(bApplyNew), |
| 47 m_bSetAsGlobalObject(FALSE) { |
| 48 v8::Isolate::Scope isolate_scope(isolate); |
| 49 v8::HandleScope handle_scope(isolate); |
| 50 |
| 51 v8::Handle<v8::ObjectTemplate> objTemplate = |
| 52 v8::ObjectTemplate::New(isolate); |
| 53 objTemplate->SetInternalFieldCount(1); |
| 54 m_objTemplate.Reset(isolate, objTemplate); |
| 55 |
| 56 // Document as the global object. |
| 57 if (FXSYS_wcscmp(sObjName, L"Document") == 0) { |
| 58 m_bSetAsGlobalObject = TRUE; |
| 59 } |
| 60 } |
| 61 ~CJS_ObjDefintion() { |
| 62 m_objTemplate.Reset(); |
| 63 m_StaticObj.Reset(); |
| 64 } |
| 65 |
| 66 public: |
| 67 const wchar_t* objName; |
| 68 FXJSOBJTYPE objType; |
| 69 LP_CONSTRUCTOR m_pConstructor; |
| 70 LP_DESTRUCTOR m_pDestructor; |
| 71 unsigned m_bApplyNew; |
| 72 FX_BOOL m_bSetAsGlobalObject; |
| 73 |
| 74 v8::Persistent<v8::ObjectTemplate> m_objTemplate; |
| 75 v8::Persistent<v8::Object> m_StaticObj; |
| 76 }; |
| 77 |
| 78 int JS_DefineObj(IJS_Runtime* pJSRuntime, |
| 79 const wchar_t* sObjName, |
| 80 FXJSOBJTYPE eObjType, |
| 81 LP_CONSTRUCTOR pConstructor, |
| 82 LP_DESTRUCTOR pDestructor, |
| 83 unsigned bApplyNew) { |
| 84 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; |
| 85 v8::Isolate::Scope isolate_scope(isolate); |
| 86 v8::HandleScope handle_scope(isolate); |
| 87 CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(0); |
| 88 if (!pArray) { |
| 89 pArray = FX_NEW CFX_PtrArray(); |
| 90 isolate->SetData(0, pArray); |
| 91 } |
| 92 CJS_ObjDefintion* pObjDef = FX_NEW CJS_ObjDefintion( |
| 93 isolate, sObjName, eObjType, pConstructor, pDestructor, bApplyNew); |
| 94 pArray->Add(pObjDef); |
| 95 return pArray->GetSize() - 1; |
| 96 } |
| 97 |
| 98 int JS_DefineObjMethod(IJS_Runtime* pJSRuntime, |
| 99 int nObjDefnID, |
| 100 const wchar_t* sMethodName, |
| 101 v8::FunctionCallback pMethodCall, |
| 102 unsigned nParamNum) { |
| 103 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; |
| 104 v8::Isolate::Scope isolate_scope(isolate); |
| 105 v8::HandleScope handle_scope(isolate); |
| 106 |
| 107 CFX_WideString ws = CFX_WideString((FX_LPCWSTR)sMethodName); |
| 108 CFX_ByteString bsMethodName = ws.UTF8Encode(); |
| 109 |
| 110 CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(0); |
| 111 if (!pArray) |
| 112 return 0; |
| 113 |
| 114 if (nObjDefnID < 0 || nObjDefnID >= pArray->GetSize()) |
| 115 return 0; |
| 116 CJS_ObjDefintion* pObjDef = (CJS_ObjDefintion*)pArray->GetAt(nObjDefnID); |
| 117 v8::Local<v8::ObjectTemplate> objTemp = |
| 118 v8::Local<v8::ObjectTemplate>::New(isolate, pObjDef->m_objTemplate); |
| 119 objTemp->Set(v8::String::NewFromUtf8(isolate, FX_LPCSTR(bsMethodName)), |
| 120 v8::FunctionTemplate::New(isolate, pMethodCall), |
| 121 v8::ReadOnly); |
| 122 pObjDef->m_objTemplate.Reset(isolate, objTemp); |
| 123 return 0; |
| 124 } |
| 125 |
| 126 int JS_DefineObjProperty(IJS_Runtime* pJSRuntime, |
| 127 int nObjDefnID, |
| 128 const wchar_t* sPropName, |
| 129 v8::AccessorGetterCallback pPropGet, |
| 130 v8::AccessorSetterCallback pPropPut) { |
| 131 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; |
| 132 v8::Isolate::Scope isolate_scope(isolate); |
| 133 v8::HandleScope handle_scope(isolate); |
| 134 |
| 135 CFX_WideString ws = CFX_WideString((FX_LPCWSTR)sPropName); |
| 136 CFX_ByteString bsPropertyName = ws.UTF8Encode(); |
| 137 |
| 138 CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(0); |
| 139 if (!pArray) |
| 140 return 0; |
| 141 |
| 142 if (nObjDefnID < 0 || nObjDefnID >= pArray->GetSize()) |
| 143 return 0; |
| 144 CJS_ObjDefintion* pObjDef = (CJS_ObjDefintion*)pArray->GetAt(nObjDefnID); |
| 145 v8::Local<v8::ObjectTemplate> objTemp = |
| 146 v8::Local<v8::ObjectTemplate>::New(isolate, pObjDef->m_objTemplate); |
| 147 objTemp->SetAccessor( |
| 148 v8::String::NewFromUtf8(isolate, FX_LPCSTR(bsPropertyName)), |
| 149 pPropGet, |
| 150 pPropPut); |
| 151 pObjDef->m_objTemplate.Reset(isolate, objTemp); |
| 152 return 0; |
| 153 } |
| 154 |
| 155 int JS_DefineObjAllProperties(IJS_Runtime* pJSRuntime, |
| 156 int nObjDefnID, |
| 157 v8::NamedPropertyQueryCallback pPropQurey, |
| 158 v8::NamedPropertyGetterCallback pPropGet, |
| 159 v8::NamedPropertySetterCallback pPropPut, |
| 160 v8::NamedPropertyDeleterCallback pPropDel) { |
| 161 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; |
| 162 v8::Isolate::Scope isolate_scope(isolate); |
| 163 v8::HandleScope handle_scope(isolate); |
| 164 |
| 165 CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(0); |
| 166 if (!pArray) |
| 167 return 0; |
| 168 |
| 169 if (nObjDefnID < 0 || nObjDefnID >= pArray->GetSize()) |
| 170 return 0; |
| 171 CJS_ObjDefintion* pObjDef = (CJS_ObjDefintion*)pArray->GetAt(nObjDefnID); |
| 172 v8::Local<v8::ObjectTemplate> objTemp = |
| 173 v8::Local<v8::ObjectTemplate>::New(isolate, pObjDef->m_objTemplate); |
| 174 objTemp->SetNamedPropertyHandler(pPropGet, pPropPut, pPropQurey, pPropDel); |
| 175 pObjDef->m_objTemplate.Reset(isolate, objTemp); |
| 176 return 0; |
| 177 } |
| 178 |
| 179 int JS_DefineObjConst(IJS_Runtime* pJSRuntime, |
| 180 int nObjDefnID, |
| 181 const wchar_t* sConstName, |
| 182 v8::Handle<v8::Value> pDefault) { |
| 183 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; |
| 184 v8::Isolate::Scope isolate_scope(isolate); |
| 185 v8::HandleScope handle_scope(isolate); |
| 186 |
| 187 CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(0); |
| 188 if (!pArray) |
| 189 return 0; |
| 190 |
| 191 CFX_WideString ws = CFX_WideString((FX_LPCWSTR)sConstName); |
| 192 CFX_ByteString bsConstName = ws.UTF8Encode(); |
| 193 |
| 194 if (nObjDefnID < 0 || nObjDefnID >= pArray->GetSize()) |
| 195 return 0; |
| 196 CJS_ObjDefintion* pObjDef = (CJS_ObjDefintion*)pArray->GetAt(nObjDefnID); |
| 197 v8::Local<v8::ObjectTemplate> objTemp = |
| 198 v8::Local<v8::ObjectTemplate>::New(isolate, pObjDef->m_objTemplate); |
| 199 objTemp->Set(isolate, FX_LPCSTR(bsConstName), pDefault); |
| 200 pObjDef->m_objTemplate.Reset(isolate, objTemp); |
| 201 return 0; |
| 202 } |
| 203 |
| 204 static v8::Persistent<v8::ObjectTemplate>& _getGlobalObjectTemplate( |
| 205 IJS_Runtime* pJSRuntime) { |
| 206 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; |
| 207 v8::Isolate::Scope isolate_scope(isolate); |
| 208 v8::HandleScope handle_scope(isolate); |
| 209 |
| 210 CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(0); |
| 211 ASSERT(pArray != NULL); |
| 212 for (int i = 0; i < pArray->GetSize(); i++) { |
| 213 CJS_ObjDefintion* pObjDef = (CJS_ObjDefintion*)pArray->GetAt(i); |
| 214 if (pObjDef->m_bSetAsGlobalObject) |
| 215 return pObjDef->m_objTemplate; |
| 216 } |
| 217 static v8::Persistent<v8::ObjectTemplate> gloabalObjectTemplate; |
| 218 return gloabalObjectTemplate; |
| 219 } |
| 220 |
| 221 int JS_DefineGlobalMethod(IJS_Runtime* pJSRuntime, |
| 222 const wchar_t* sMethodName, |
| 223 v8::FunctionCallback pMethodCall, |
| 224 unsigned nParamNum) { |
| 225 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; |
| 226 v8::Isolate::Scope isolate_scope(isolate); |
| 227 v8::HandleScope handle_scope(isolate); |
| 228 |
| 229 CFX_WideString ws = CFX_WideString((FX_LPCWSTR)sMethodName); |
| 230 CFX_ByteString bsMethodName = ws.UTF8Encode(); |
| 231 |
| 232 v8::Local<v8::FunctionTemplate> funTempl = |
| 233 v8::FunctionTemplate::New(isolate, pMethodCall); |
| 234 v8::Local<v8::ObjectTemplate> objTemp; |
| 235 |
| 236 v8::Persistent<v8::ObjectTemplate>& globalObjTemp = |
| 237 _getGlobalObjectTemplate(pJSRuntime); |
| 238 if (globalObjTemp.IsEmpty()) |
| 239 objTemp = v8::ObjectTemplate::New(isolate); |
| 240 else |
| 241 objTemp = v8::Local<v8::ObjectTemplate>::New(isolate, globalObjTemp); |
| 242 objTemp->Set(v8::String::NewFromUtf8(isolate, FX_LPCSTR(bsMethodName)), |
| 243 funTempl, |
| 244 v8::ReadOnly); |
| 245 |
| 246 globalObjTemp.Reset(isolate, objTemp); |
| 247 |
| 248 return 0; |
| 249 } |
| 250 |
| 251 int JS_DefineGlobalConst(IJS_Runtime* pJSRuntime, |
| 252 const wchar_t* sConstName, |
| 253 v8::Handle<v8::Value> pDefault) { |
| 254 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; |
| 255 v8::Isolate::Scope isolate_scope(isolate); |
| 256 v8::HandleScope handle_scope(isolate); |
| 257 |
| 258 CFX_WideString ws = CFX_WideString((FX_LPCWSTR)sConstName); |
| 259 CFX_ByteString bsConst = ws.UTF8Encode(); |
| 260 |
| 261 v8::Local<v8::ObjectTemplate> objTemp; |
| 262 |
| 263 v8::Persistent<v8::ObjectTemplate>& globalObjTemp = |
| 264 _getGlobalObjectTemplate(pJSRuntime); |
| 265 if (globalObjTemp.IsEmpty()) |
| 266 objTemp = v8::ObjectTemplate::New(isolate); |
| 267 else |
| 268 objTemp = v8::Local<v8::ObjectTemplate>::New(isolate, globalObjTemp); |
| 269 objTemp->Set(v8::String::NewFromUtf8(isolate, FX_LPCSTR(bsConst)), |
| 270 pDefault, |
| 271 v8::ReadOnly); |
| 272 |
| 273 globalObjTemp.Reset(isolate, objTemp); |
| 274 |
| 275 return 0; |
| 276 } |
| 277 |
| 278 void JS_InitialRuntime(IJS_Runtime* pJSRuntime, |
| 279 IFXJS_Runtime* pFXRuntime, |
| 280 IFXJS_Context* context, |
| 281 v8::Persistent<v8::Context>& v8PersistentContext) { |
| 282 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; |
| 283 v8::Isolate::Scope isolate_scope(isolate); |
| 284 v8::HandleScope handle_scope(isolate); |
| 285 |
| 286 v8::Persistent<v8::ObjectTemplate>& globalObjTemp = |
| 287 _getGlobalObjectTemplate(pJSRuntime); |
| 288 v8::Handle<v8::Context> v8Context = v8::Context::New( |
| 289 isolate, |
| 290 NULL, |
| 291 v8::Local<v8::ObjectTemplate>::New(isolate, globalObjTemp)); |
| 292 v8::Context::Scope context_scope(v8Context); |
| 293 |
| 294 v8::Handle<v8::External> ptr = v8::External::New(isolate, pFXRuntime); |
| 295 v8Context->SetEmbedderData(1, ptr); |
| 296 |
| 297 CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(0); |
| 298 if (!pArray) |
| 299 return; |
| 300 |
| 301 for (int i = 0; i < pArray->GetSize(); i++) { |
| 302 CJS_ObjDefintion* pObjDef = (CJS_ObjDefintion*)pArray->GetAt(i); |
| 303 CFX_WideString ws = CFX_WideString(pObjDef->objName); |
| 304 CFX_ByteString bs = ws.UTF8Encode(); |
| 305 v8::Handle<v8::String> objName = v8::String::NewFromUtf8( |
| 306 isolate, (FX_LPCSTR)bs, v8::String::kNormalString, bs.GetLength()); |
| 307 |
| 308 if (pObjDef->objType == JS_DYNAMIC) { |
| 309 // Document is set as global object, need to construct it first. |
| 310 if (ws.Equal(L"Document")) { |
| 311 CJS_PrivateData* pPrivateData = FX_NEW CJS_PrivateData; |
| 312 pPrivateData->ObjDefID = i; |
| 313 v8::Handle<v8::External> ptr = v8::External::New(isolate, pPrivateData); |
| 314 |
| 315 v8Context->Global()->GetPrototype()->ToObject()->SetInternalField(0, |
| 316 ptr); |
| 317 |
| 318 if (pObjDef->m_pConstructor) |
| 319 pObjDef->m_pConstructor( |
| 320 context, |
| 321 v8Context->Global()->GetPrototype()->ToObject(), |
| 322 v8Context->Global()->GetPrototype()->ToObject()); |
| 323 } |
| 324 } else { |
| 325 v8::Handle<v8::Object> obj = JS_NewFxDynamicObj(pJSRuntime, context, i); |
| 326 v8Context->Global()->Set(objName, obj); |
| 327 pObjDef->m_StaticObj.Reset(isolate, obj); |
| 328 } |
| 329 } |
| 330 v8PersistentContext.Reset(isolate, v8Context); |
| 331 } |
| 332 |
| 333 void JS_ReleaseRuntime(IJS_Runtime* pJSRuntime, |
| 334 v8::Persistent<v8::Context>& v8PersistentContext) { |
| 335 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; |
| 336 v8::Isolate::Scope isolate_scope(isolate); |
| 337 v8::HandleScope handle_scope(isolate); |
| 338 v8::Local<v8::Context> context = |
| 339 v8::Local<v8::Context>::New(isolate, v8PersistentContext); |
| 340 v8::Context::Scope context_scope(context); |
| 341 |
| 342 CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(0); |
| 343 if (!pArray) |
| 344 return; |
| 345 |
| 346 for (int i = 0; i < pArray->GetSize(); i++) { |
| 347 CJS_ObjDefintion* pObjDef = (CJS_ObjDefintion*)pArray->GetAt(i); |
| 348 if (!pObjDef->m_StaticObj.IsEmpty()) { |
| 349 v8::Local<v8::Object> pObj = |
| 350 v8::Local<v8::Object>::New(isolate, pObjDef->m_StaticObj); |
| 351 if (pObjDef->m_pDestructor) |
| 352 pObjDef->m_pDestructor(pObj); |
| 353 JS_FreePrivate(pObj); |
| 354 } |
| 355 delete pObjDef; |
| 356 } |
| 357 delete pArray; |
| 358 isolate->SetData(0, NULL); |
| 359 } |
| 360 |
| 361 void JS_Initial() { |
| 362 #ifndef FOXIT_CHROME_BUILD |
| 363 v8::V8::InitializeICU(); |
| 364 #endif |
| 365 } |
| 366 void JS_Release() { |
| 367 } |
| 368 int JS_Parse(IJS_Runtime* pJSRuntime, |
| 369 IFXJS_Context* pJSContext, |
| 370 const wchar_t* script, |
| 371 long length, |
| 372 FXJSErr* perror) { |
| 373 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; |
| 374 v8::Isolate::Scope isolate_scope(isolate); |
| 375 v8::TryCatch try_catch; |
| 376 |
| 377 CFX_WideString wsScript(script); |
| 378 CFX_ByteString bsScript = wsScript.UTF8Encode(); |
| 379 |
| 380 v8::Handle<v8::Script> compiled_script = |
| 381 v8::Script::Compile(v8::String::NewFromUtf8(isolate, |
| 382 (FX_LPCSTR)bsScript, |
| 383 v8::String::kNormalString, |
| 384 bsScript.GetLength())); |
| 385 if (compiled_script.IsEmpty()) { |
| 386 v8::String::Utf8Value error(try_catch.Exception()); |
| 387 return -1; |
| 388 } |
| 389 return 0; |
| 390 } |
| 391 |
| 392 int JS_Execute(IJS_Runtime* pJSRuntime, |
| 393 IFXJS_Context* pJSContext, |
| 394 const wchar_t* script, |
| 395 long length, |
| 396 FXJSErr* perror) { |
| 397 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; |
| 398 v8::Isolate::Scope isolate_scope(isolate); |
| 399 v8::TryCatch try_catch; |
| 400 |
| 401 CFX_WideString wsScript(script); |
| 402 CFX_ByteString bsScript = wsScript.UTF8Encode(); |
| 403 |
| 404 v8::Handle<v8::Script> compiled_script = |
| 405 v8::Script::Compile(v8::String::NewFromUtf8(isolate, |
| 406 (FX_LPCSTR)bsScript, |
| 407 v8::String::kNormalString, |
| 408 bsScript.GetLength())); |
| 409 if (compiled_script.IsEmpty()) { |
| 410 v8::String::Utf8Value error(try_catch.Exception()); |
| 411 return -1; |
| 412 } |
| 413 |
| 414 v8::Handle<v8::Value> result = compiled_script->Run(); |
| 415 if (result.IsEmpty()) { |
| 416 v8::String::Utf8Value error(try_catch.Exception()); |
| 417 return -1; |
| 418 } |
| 419 return 0; |
| 420 } |
| 421 |
| 422 v8::Handle<v8::Object> JS_NewFxDynamicObj(IJS_Runtime* pJSRuntime, |
| 423 IFXJS_Context* pJSContext, |
| 424 int nObjDefnID) { |
| 425 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; |
| 426 v8::Isolate::Scope isolate_scope(isolate); |
| 427 if (-1 == nObjDefnID) { |
| 428 v8::Local<v8::ObjectTemplate> objTempl = v8::ObjectTemplate::New(isolate); |
| 429 return objTempl->NewInstance(); |
| 430 } |
| 431 |
| 432 CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(0); |
| 433 if (!pArray) |
| 434 return v8::Handle<v8::Object>(); |
| 435 |
| 436 if (nObjDefnID < 0 || nObjDefnID >= pArray->GetSize()) |
| 437 return v8::Handle<v8::Object>(); |
| 438 CJS_ObjDefintion* pObjDef = (CJS_ObjDefintion*)pArray->GetAt(nObjDefnID); |
| 439 |
| 440 v8::Local<v8::Context> context = isolate->GetCurrentContext(); |
| 441 v8::Local<v8::ObjectTemplate> objTemp = |
| 442 v8::Local<v8::ObjectTemplate>::New(isolate, pObjDef->m_objTemplate); |
| 443 |
| 444 v8::Local<v8::Object> obj = objTemp->NewInstance(); |
| 445 |
| 446 CJS_PrivateData* pPrivateData = FX_NEW CJS_PrivateData; |
| 447 pPrivateData->ObjDefID = nObjDefnID; |
| 448 v8::Handle<v8::External> ptr = v8::External::New(isolate, pPrivateData); |
| 449 obj->SetInternalField(0, ptr); |
| 450 |
| 451 if (pObjDef->m_pConstructor) |
| 452 pObjDef->m_pConstructor( |
| 453 pJSContext, obj, context->Global()->GetPrototype()->ToObject()); |
| 454 |
| 455 return obj; |
| 456 } |
| 457 |
| 458 v8::Handle<v8::Object> JS_GetStaticObj(IJS_Runtime* pJSRuntime, |
| 459 int nObjDefnID) { |
| 460 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; |
| 461 v8::Isolate::Scope isolate_scope(isolate); |
| 462 |
| 463 CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(0); |
| 464 if (!pArray) |
| 465 return v8::Handle<v8::Object>(); |
| 466 |
| 467 if (nObjDefnID < 0 || nObjDefnID >= pArray->GetSize()) |
| 468 return v8::Handle<v8::Object>(); |
| 469 CJS_ObjDefintion* pObjDef = (CJS_ObjDefintion*)pArray->GetAt(nObjDefnID); |
| 470 v8::Local<v8::Object> obj = |
| 471 v8::Local<v8::Object>::New(isolate, pObjDef->m_StaticObj); |
| 472 return obj; |
| 473 } |
| 474 |
| 475 void JS_SetThisObj(IJS_Runtime* pJSRuntime, int nThisObjID) { |
| 476 // Do nothing. |
| 477 } |
| 478 v8::Handle<v8::Object> JS_GetThisObj(IJS_Runtime* pJSRuntime) { |
| 479 // Return the global object. |
| 480 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; |
| 481 v8::Isolate::Scope isolate_scope(isolate); |
| 482 |
| 483 CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(0); |
| 484 if (!pArray) |
| 485 return v8::Handle<v8::Object>(); |
| 486 |
| 487 v8::Local<v8::Context> context = isolate->GetCurrentContext(); |
| 488 return context->Global()->GetPrototype()->ToObject(); |
| 489 } |
| 490 |
| 491 int JS_GetObjDefnID(v8::Handle<v8::Object> pObj) { |
| 492 if (pObj.IsEmpty() || !pObj->InternalFieldCount()) |
| 493 return -1; |
| 494 v8::Handle<v8::External> field = |
| 495 v8::Handle<v8::External>::Cast(pObj->GetInternalField(0)); |
| 496 CJS_PrivateData* pPrivateData = (CJS_PrivateData*)field->Value(); |
| 497 if (pPrivateData) |
| 498 return pPrivateData->ObjDefID; |
| 499 return -1; |
| 500 } |
| 501 |
| 502 IJS_Runtime* JS_GetRuntime(v8::Handle<v8::Object> pObj) { |
| 503 if (pObj.IsEmpty()) |
| 504 return NULL; |
| 505 v8::Local<v8::Context> context = pObj->CreationContext(); |
| 506 if (context.IsEmpty()) |
| 507 return NULL; |
| 508 return context->GetIsolate(); |
| 509 } |
| 510 |
| 511 int JS_GetObjDefnID(IJS_Runtime* pJSRuntime, const wchar_t* pObjName) { |
| 512 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; |
| 513 v8::Isolate::Scope isolate_scope(isolate); |
| 514 |
| 515 CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(0); |
| 516 if (!pArray) |
| 517 return -1; |
| 518 |
| 519 for (int i = 0; i < pArray->GetSize(); i++) { |
| 520 CJS_ObjDefintion* pObjDef = (CJS_ObjDefintion*)pArray->GetAt(i); |
| 521 if (FXSYS_wcscmp(pObjDef->objName, pObjName) == 0) |
| 522 return i; |
| 523 } |
| 524 return -1; |
| 525 } |
| 526 |
| 527 void JS_Error(v8::Value* pError, const wchar_t* main, const wchar_t* sub) { |
| 528 } |
| 529 |
| 530 unsigned JS_CalcHash(const wchar_t* main, unsigned nLen) { |
| 531 return (unsigned)FX_HashCode_String_GetW(main, nLen); |
| 532 } |
| 533 |
| 534 unsigned JS_CalcHash(const wchar_t* main) { |
| 535 return (unsigned)FX_HashCode_String_GetW(main, FXSYS_wcslen(main)); |
| 536 } |
| 537 const wchar_t* JS_GetTypeof(v8::Handle<v8::Value> pObj) { |
| 538 if (pObj.IsEmpty()) |
| 539 return NULL; |
| 540 if (pObj->IsString()) |
| 541 return VALUE_NAME_STRING; |
| 542 if (pObj->IsNumber()) |
| 543 return VALUE_NAME_NUMBER; |
| 544 if (pObj->IsBoolean()) |
| 545 return VALUE_NAME_BOOLEAN; |
| 546 if (pObj->IsDate()) |
| 547 return VALUE_NAME_DATE; |
| 548 if (pObj->IsObject()) |
| 549 return VALUE_NAME_OBJECT; |
| 550 if (pObj->IsNull()) |
| 551 return VALUE_NAME_NULL; |
| 552 if (pObj->IsUndefined()) |
| 553 return VALUE_NAME_UNDEFINED; |
| 554 return NULL; |
| 555 } |
| 556 const wchar_t* JS_GetClassname(v8::Handle<v8::Object> pObj) { |
| 557 return NULL; |
| 558 } |
| 559 |
| 560 void JS_SetPrivate(v8::Handle<v8::Object> pObj, void* p) { |
| 561 JS_SetPrivate(NULL, pObj, p); |
| 562 } |
| 563 |
| 564 void* JS_GetPrivate(v8::Handle<v8::Object> pObj) { |
| 565 return JS_GetPrivate(NULL, pObj); |
| 566 } |
| 567 |
| 568 void JS_SetPrivate(IJS_Runtime* pJSRuntime, |
| 569 v8::Handle<v8::Object> pObj, |
| 570 void* p) { |
| 571 if (pObj.IsEmpty() || !pObj->InternalFieldCount()) |
| 572 return; |
| 573 v8::Handle<v8::External> ptr = |
| 574 v8::Handle<v8::External>::Cast(pObj->GetInternalField(0)); |
| 575 CJS_PrivateData* pPrivateData = (CJS_PrivateData*)ptr->Value(); |
| 576 if (!pPrivateData) |
| 577 return; |
| 578 pPrivateData->pPrivate = p; |
| 579 } |
| 580 |
| 581 void* JS_GetPrivate(IJS_Runtime* pJSRuntime, v8::Handle<v8::Object> pObj) { |
| 582 if (pObj.IsEmpty()) |
| 583 return NULL; |
| 584 v8::Local<v8::Value> value; |
| 585 if (pObj->InternalFieldCount()) |
| 586 value = pObj->GetInternalField(0); |
| 587 else { |
| 588 // It could be a global proxy object. |
| 589 v8::Local<v8::Value> v = pObj->GetPrototype(); |
| 590 if (v->IsObject()) |
| 591 value = v->ToObject()->GetInternalField(0); |
| 592 } |
| 593 if (value.IsEmpty() || value->IsUndefined()) |
| 594 return NULL; |
| 595 v8::Handle<v8::External> ptr = v8::Handle<v8::External>::Cast(value); |
| 596 CJS_PrivateData* pPrivateData = (CJS_PrivateData*)ptr->Value(); |
| 597 if (!pPrivateData) |
| 598 return NULL; |
| 599 return pPrivateData->pPrivate; |
| 600 } |
| 601 |
| 602 void JS_FreePrivate(v8::Handle<v8::Object> pObj) { |
| 603 if (pObj.IsEmpty() || !pObj->InternalFieldCount()) |
| 604 return; |
| 605 v8::Handle<v8::External> ptr = |
| 606 v8::Handle<v8::External>::Cast(pObj->GetInternalField(0)); |
| 607 delete (CJS_PrivateData*)ptr->Value(); |
| 608 v8::Local<v8::Context> context = pObj->CreationContext(); |
| 609 |
| 610 pObj->SetInternalField(0, v8::External::New(context->GetIsolate(), NULL)); |
| 611 } |
| 612 |
| 613 v8::Handle<v8::Value> JS_GetObjectValue(v8::Handle<v8::Object> pObj) { |
| 614 return pObj; |
| 615 } |
| 616 |
| 617 v8::Handle<v8::String> WSToJSString(IJS_Runtime* pJSRuntime, |
| 618 const wchar_t* PropertyName, |
| 619 int Len = -1) { |
| 620 CFX_WideString ws = CFX_WideString(PropertyName, Len); |
| 621 CFX_ByteString bs = ws.UTF8Encode(); |
| 622 if (!pJSRuntime) |
| 623 pJSRuntime = v8::Isolate::GetCurrent(); |
| 624 return v8::String::NewFromUtf8(pJSRuntime, (FX_LPCSTR)bs); |
| 625 } |
| 626 |
| 627 v8::Handle<v8::Value> JS_GetObjectElement(IJS_Runtime* pJSRuntime, |
| 628 v8::Handle<v8::Object> pObj, |
| 629 const wchar_t* PropertyName) { |
| 630 if (pObj.IsEmpty()) |
| 631 return v8::Handle<v8::Value>(); |
| 632 return pObj->Get(WSToJSString(pJSRuntime, PropertyName)); |
| 633 } |
| 634 |
| 635 v8::Handle<v8::Array> JS_GetObjectElementNames(v8::Handle<v8::Object> pObj) { |
| 636 if (pObj.IsEmpty()) |
| 637 return v8::Handle<v8::Array>(); |
| 638 return pObj->GetPropertyNames(); |
| 639 } |
| 640 |
| 641 void JS_PutObjectString(IJS_Runtime* pJSRuntime, |
| 642 v8::Handle<v8::Object> pObj, |
| 643 const wchar_t* PropertyName, |
| 644 const wchar_t* sValue) // VT_string |
29 { | 645 { |
30 public: | 646 if (pObj.IsEmpty()) |
31 CJS_PrivateData():ObjDefID(-1), pPrivate(NULL) {} | 647 return; |
32 int ObjDefID; | 648 pObj->Set(WSToJSString(pJSRuntime, PropertyName), |
33 FX_LPVOID pPrivate; | 649 WSToJSString(pJSRuntime, sValue)); |
34 }; | 650 } |
35 | 651 |
36 | 652 void JS_PutObjectNumber(IJS_Runtime* pJSRuntime, |
37 class CJS_ObjDefintion: public CFX_Object | 653 v8::Handle<v8::Object> pObj, |
38 { | 654 const wchar_t* PropertyName, |
39 public: | 655 int nValue) { |
40 CJS_ObjDefintion(v8::Isolate* isolate, const wchar_t* sObjName, FXJSOBJT
YPE eObjType, LP_CONSTRUCTOR pConstructor, LP_DESTRUCTOR pDestructor, unsigned b
ApplyNew): | 656 if (pObj.IsEmpty()) |
41 objName(sObjName), objType(eObjType), m_pConstructor(pConstructor), m_
pDestructor(pDestructor),m_bApplyNew(bApplyNew),m_bSetAsGlobalObject(FALSE) | 657 return; |
42 { | 658 pObj->Set(WSToJSString(pJSRuntime, PropertyName), |
43 v8::Isolate::Scope isolate_scope(isolate); | 659 v8::Int32::New(pJSRuntime, nValue)); |
44 v8::HandleScope handle_scope(isolate); | 660 } |
45 | 661 |
46 v8::Handle<v8::ObjectTemplate> objTemplate = v8::ObjectTemplat
e::New(isolate); | 662 void JS_PutObjectNumber(IJS_Runtime* pJSRuntime, |
47 objTemplate->SetInternalFieldCount(1); | 663 v8::Handle<v8::Object> pObj, |
48 m_objTemplate.Reset(isolate, objTemplate); | 664 const wchar_t* PropertyName, |
49 | 665 float fValue) { |
50 //Document as the global object. | 666 if (pObj.IsEmpty()) |
51 if(FXSYS_wcscmp(sObjName, L"Document") == 0) | 667 return; |
52 { | 668 pObj->Set(WSToJSString(pJSRuntime, PropertyName), |
53 m_bSetAsGlobalObject = TRUE; | 669 v8::Number::New(pJSRuntime, (double)fValue)); |
54 } | 670 } |
55 | 671 |
56 } | 672 void JS_PutObjectNumber(IJS_Runtime* pJSRuntime, |
57 ~CJS_ObjDefintion() | 673 v8::Handle<v8::Object> pObj, |
58 { | 674 const wchar_t* PropertyName, |
59 m_objTemplate.Reset(); | 675 double dValue) { |
60 m_StaticObj.Reset(); | 676 if (pObj.IsEmpty()) |
61 } | 677 return; |
62 public: | 678 pObj->Set(WSToJSString(pJSRuntime, PropertyName), |
63 const wchar_t* objName; | 679 v8::Number::New(pJSRuntime, (double)dValue)); |
64 FXJSOBJTYPE objType; | 680 } |
65 LP_CONSTRUCTOR m_pConstructor; | 681 |
66 LP_DESTRUCTOR m_pDestructor; | 682 void JS_PutObjectBoolean(IJS_Runtime* pJSRuntime, |
67 unsigned m_bApplyNew; | 683 v8::Handle<v8::Object> pObj, |
68 FX_BOOL m_bSetAsGlobalObject; | 684 const wchar_t* PropertyName, |
69 | 685 bool bValue) { |
70 v8::Persistent<v8::ObjectTemplate> m_objTemplate; | 686 if (pObj.IsEmpty()) |
71 v8::Persistent<v8::Object> m_StaticObj; | 687 return; |
72 }; | 688 pObj->Set(WSToJSString(pJSRuntime, PropertyName), |
73 | 689 v8::Boolean::New(pJSRuntime, bValue)); |
74 int JS_DefineObj(IJS_Runtime* pJSRuntime, const wchar_t* sObjName, FXJSOBJTYPE e
ObjType, LP_CONSTRUCTOR pConstructor, LP_DESTRUCTOR pDestructor, unsigned bApply
New) | 690 } |
75 { | 691 |
76 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; | 692 void JS_PutObjectObject(IJS_Runtime* pJSRuntime, |
77 v8::Isolate::Scope isolate_scope(isolate); | 693 v8::Handle<v8::Object> pObj, |
78 v8::HandleScope handle_scope(isolate); | 694 const wchar_t* PropertyName, |
79 CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(0); | 695 v8::Handle<v8::Object> pPut) { |
80 if(!pArray) | 696 if (pObj.IsEmpty()) |
81 { | 697 return; |
82 pArray = FX_NEW CFX_PtrArray(); | 698 pObj->Set(WSToJSString(pJSRuntime, PropertyName), pPut); |
83 isolate->SetData(0, pArray); | 699 } |
84 } | 700 |
85 CJS_ObjDefintion* pObjDef = FX_NEW CJS_ObjDefintion(isolate, sObjName, e
ObjType, pConstructor, pDestructor, bApplyNew); | 701 void JS_PutObjectNull(IJS_Runtime* pJSRuntime, |
86 pArray->Add(pObjDef); | 702 v8::Handle<v8::Object> pObj, |
87 return pArray->GetSize()-1; | 703 const wchar_t* PropertyName) { |
88 } | 704 if (pObj.IsEmpty()) |
89 | 705 return; |
90 int JS_DefineObjMethod(IJS_Runtime* pJSRuntime, int nObjDefnID, const wchar_t* s
MethodName, v8::FunctionCallback pMethodCall, unsigned nParamNum) | 706 pObj->Set(WSToJSString(pJSRuntime, PropertyName), v8::Handle<v8::Object>()); |
91 { | 707 } |
92 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; | 708 |
93 v8::Isolate::Scope isolate_scope(isolate); | 709 v8::Handle<v8::Array> JS_NewArray(IJS_Runtime* pJSRuntime) { |
94 v8::HandleScope handle_scope(isolate); | 710 return v8::Array::New(pJSRuntime); |
95 | 711 } |
96 CFX_WideString ws = CFX_WideString((FX_LPCWSTR)sMethodName); | 712 |
97 CFX_ByteString bsMethodName = ws.UTF8Encode(); | 713 unsigned JS_PutArrayElement(v8::Handle<v8::Array> pArray, |
98 | 714 unsigned index, |
99 CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(0); | 715 v8::Handle<v8::Value> pValue, |
100 if(!pArray) return 0; | 716 FXJSVALUETYPE eType) { |
101 | 717 if (pArray.IsEmpty()) |
102 if(nObjDefnID<0 || nObjDefnID>= pArray->GetSize()) return 0; | 718 return 0; |
103 CJS_ObjDefintion* pObjDef = (CJS_ObjDefintion*)pArray->GetAt(nObjDefnID)
; | 719 pArray->Set(index, pValue); |
104 v8::Local<v8::ObjectTemplate> objTemp = v8::Local<v8::ObjectTemplate>::N
ew(isolate, pObjDef->m_objTemplate); | 720 return 1; |
105 objTemp->Set(v8::String::NewFromUtf8(isolate, FX_LPCSTR(bsMethodName)),
v8::FunctionTemplate::New(isolate, pMethodCall), v8::ReadOnly); | 721 } |
106 pObjDef->m_objTemplate.Reset(isolate,objTemp); | 722 |
107 return 0; | 723 v8::Handle<v8::Value> JS_GetArrayElemnet(v8::Handle<v8::Array> pArray, |
108 } | 724 unsigned index) { |
109 | 725 if (pArray.IsEmpty()) |
110 int JS_DefineObjProperty(IJS_Runtime* pJSRuntime, int nObjDefnID, const wchar_t*
sPropName, v8::AccessorGetterCallback pPropGet, v8::AccessorSetterCallback pPro
pPut) | 726 return v8::Handle<v8::Value>(); |
111 { | 727 return pArray->Get(index); |
112 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; | 728 } |
113 v8::Isolate::Scope isolate_scope(isolate); | 729 |
114 v8::HandleScope handle_scope(isolate); | 730 unsigned JS_GetArrayLength(v8::Handle<v8::Array> pArray) { |
115 | 731 if (pArray.IsEmpty()) |
116 CFX_WideString ws = CFX_WideString((FX_LPCWSTR)sPropName); | 732 return 0; |
117 CFX_ByteString bsPropertyName = ws.UTF8Encode(); | 733 return pArray->Length(); |
118 | 734 } |
119 CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(0); | 735 |
120 if(!pArray) return 0; | 736 v8::Handle<v8::Value> JS_NewNumber(IJS_Runtime* pJSRuntime, int number) { |
121 | 737 return v8::Int32::New(pJSRuntime, number); |
122 if(nObjDefnID<0 || nObjDefnID>= pArray->GetSize()) return 0; | 738 } |
123 CJS_ObjDefintion* pObjDef = (CJS_ObjDefintion*)pArray->GetAt(nObjDefnID)
; | 739 |
124 v8::Local<v8::ObjectTemplate> objTemp = v8::Local<v8::ObjectTemplate>::N
ew(isolate, pObjDef->m_objTemplate); | 740 v8::Handle<v8::Value> JS_NewNumber(IJS_Runtime* pJSRuntime, double number) { |
125 objTemp->SetAccessor(v8::String::NewFromUtf8(isolate, FX_LPCSTR(bsProper
tyName)), pPropGet, pPropPut); | 741 return v8::Number::New(pJSRuntime, number); |
126 pObjDef->m_objTemplate.Reset(isolate,objTemp); | 742 } |
127 return 0; | 743 |
128 } | 744 v8::Handle<v8::Value> JS_NewNumber(IJS_Runtime* pJSRuntime, float number) { |
129 | 745 return v8::Number::New(pJSRuntime, (float)number); |
130 int JS_DefineObjAllProperties(IJS_Runtime* pJSRuntime, int nObjDefnID, v8::N
amedPropertyQueryCallback pPropQurey, v8::NamedPropertyGetterCallback pPropGet,
v8::NamedPropertySetterCallback pPropPut, v8::NamedPropertyDeleterCallback pProp
Del) | 746 } |
131 { | 747 |
132 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; | 748 v8::Handle<v8::Value> JS_NewBoolean(IJS_Runtime* pJSRuntime, bool b) { |
133 v8::Isolate::Scope isolate_scope(isolate); | 749 return v8::Boolean::New(pJSRuntime, b); |
134 v8::HandleScope handle_scope(isolate); | 750 } |
135 | 751 |
136 CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(0); | 752 v8::Handle<v8::Value> JS_NewObject(IJS_Runtime* pJSRuntime, |
137 if(!pArray) return 0; | 753 v8::Handle<v8::Object> pObj) { |
138 | 754 if (pObj.IsEmpty()) |
139 if(nObjDefnID<0 || nObjDefnID>= pArray->GetSize()) return 0; | 755 return v8::Handle<v8::Value>(); |
140 CJS_ObjDefintion* pObjDef = (CJS_ObjDefintion*)pArray->GetAt(nObjDefnID)
; | 756 return pObj->Clone(); |
141 v8::Local<v8::ObjectTemplate> objTemp = v8::Local<v8::ObjectTemplate>::N
ew(isolate, pObjDef->m_objTemplate); | 757 } |
142 objTemp->SetNamedPropertyHandler(pPropGet, pPropPut, pPropQurey, pPropDe
l); | 758 |
143 pObjDef->m_objTemplate.Reset(isolate,objTemp); | 759 v8::Handle<v8::Value> JS_NewObject2(IJS_Runtime* pJSRuntime, |
144 return 0; | 760 v8::Handle<v8::Array> pObj) { |
145 } | 761 if (pObj.IsEmpty()) |
146 | 762 return v8::Handle<v8::Value>(); |
147 int JS_DefineObjConst(IJS_Runtime* pJSRuntime, int nObjDefnID, const wchar_t* sC
onstName, v8::Handle<v8::Value> pDefault) | 763 return pObj->Clone(); |
148 { | 764 } |
149 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; | 765 |
150 v8::Isolate::Scope isolate_scope(isolate); | 766 v8::Handle<v8::Value> JS_NewString(IJS_Runtime* pJSRuntime, |
151 v8::HandleScope handle_scope(isolate); | 767 const wchar_t* string) { |
152 | 768 return WSToJSString(pJSRuntime, string); |
153 CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(0); | 769 } |
154 if(!pArray) return 0; | 770 |
155 | 771 v8::Handle<v8::Value> JS_NewString(IJS_Runtime* pJSRuntime, |
156 CFX_WideString ws = CFX_WideString((FX_LPCWSTR)sConstName); | 772 const wchar_t* string, |
157 CFX_ByteString bsConstName = ws.UTF8Encode(); | 773 unsigned nLen) { |
158 | 774 return WSToJSString(pJSRuntime, string, nLen); |
159 if(nObjDefnID<0 || nObjDefnID>= pArray->GetSize()) return 0; | 775 } |
160 CJS_ObjDefintion* pObjDef = (CJS_ObjDefintion*)pArray->GetAt(nObjDefnID)
; | 776 |
161 v8::Local<v8::ObjectTemplate> objTemp = v8::Local<v8::ObjectTemplate>::N
ew(isolate, pObjDef->m_objTemplate); | 777 v8::Handle<v8::Value> JS_NewNull() { |
162 objTemp->Set(isolate, FX_LPCSTR(bsConstName), pDefault); | 778 return v8::Handle<v8::Value>(); |
163 pObjDef->m_objTemplate.Reset(isolate,objTemp); | 779 } |
164 return 0; | 780 |
165 } | 781 v8::Handle<v8::Value> JS_NewDate(IJS_Runtime* pJSRuntime, double d) { |
166 | 782 return v8::Date::New(pJSRuntime, d); |
167 static v8::Persistent<v8::ObjectTemplate>& _getGlobalObjectTemplate(IJS_Runtime*
pJSRuntime) | 783 } |
168 { | 784 |
169 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; | 785 v8::Handle<v8::Value> JS_NewValue(IJS_Runtime* pJSRuntime) { |
170 v8::Isolate::Scope isolate_scope(isolate); | 786 return v8::Handle<v8::Value>(); |
171 v8::HandleScope handle_scope(isolate); | 787 } |
172 | 788 |
173 CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(0); | 789 v8::Handle<v8::Value> JS_GetListValue(v8::Handle<v8::Value> pList, int index) { |
174 ASSERT(pArray != NULL); | 790 if (!pList.IsEmpty() && pList->IsObject()) { |
175 for(int i=0; i<pArray->GetSize(); i++) | 791 v8::Local<v8::Object> obj = pList->ToObject(); |
176 { | 792 return obj->Get(index); |
177 CJS_ObjDefintion* pObjDef = (CJS_ObjDefintion*)pArray->GetAt(i); | 793 } |
178 if(pObjDef->m_bSetAsGlobalObject) | 794 return v8::Handle<v8::Value>(); |
179 return pObjDef->m_objTemplate; | 795 } |
180 } | 796 |
181 static v8::Persistent<v8::ObjectTemplate> gloabalObjectTemplate; | 797 int JS_ToInt32(v8::Handle<v8::Value> pValue) { |
182 return gloabalObjectTemplate; | 798 if (pValue.IsEmpty()) |
183 } | 799 return 0; |
184 | 800 return pValue->ToInt32()->Value(); |
185 int JS_DefineGlobalMethod(IJS_Runtime* pJSRuntime, const wchar_t* sMethodName, v
8::FunctionCallback pMethodCall, unsigned nParamNum) | 801 } |
186 { | 802 |
187 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; | 803 bool JS_ToBoolean(v8::Handle<v8::Value> pValue) { |
188 v8::Isolate::Scope isolate_scope(isolate); | 804 if (pValue.IsEmpty()) |
189 v8::HandleScope handle_scope(isolate); | 805 return false; |
190 | 806 return pValue->ToBoolean()->Value(); |
191 CFX_WideString ws = CFX_WideString((FX_LPCWSTR)sMethodName); | 807 } |
192 CFX_ByteString bsMethodName = ws.UTF8Encode(); | 808 |
193 | 809 double JS_ToNumber(v8::Handle<v8::Value> pValue) { |
194 v8::Local<v8::FunctionTemplate> funTempl = v8::FunctionTemplate::New(iso
late, pMethodCall); | 810 if (pValue.IsEmpty()) |
195 v8::Local<v8::ObjectTemplate> objTemp; | 811 return 0.0; |
196 | 812 return pValue->ToNumber()->Value(); |
197 v8::Persistent<v8::ObjectTemplate>& globalObjTemp = _getGlobalObjectTemp
late(pJSRuntime); | 813 } |
198 if(globalObjTemp.IsEmpty()) | 814 |
199 objTemp = v8::ObjectTemplate::New(isolate); | 815 v8::Handle<v8::Object> JS_ToObject(v8::Handle<v8::Value> pValue) { |
200 else | 816 if (pValue.IsEmpty()) |
201 objTemp = v8::Local<v8::ObjectTemplate>::New(isolate, globalObjT
emp); | 817 return v8::Handle<v8::Object>(); |
202 objTemp->Set(v8::String::NewFromUtf8(isolate, FX_LPCSTR(bsMethodName)),
funTempl, v8::ReadOnly); | 818 return pValue->ToObject(); |
203 | 819 } |
204 globalObjTemp.Reset(isolate,objTemp); | 820 |
205 | 821 CFX_WideString JS_ToString(v8::Handle<v8::Value> pValue) { |
206 return 0; | 822 if (pValue.IsEmpty()) |
207 } | 823 return L""; |
208 | 824 v8::String::Utf8Value s(pValue->ToString()); |
209 int JS_DefineGlobalConst(IJS_Runtime* pJSRuntime, const wchar_t* sConstName, v8:
:Handle<v8::Value> pDefault) | 825 return CFX_WideString::FromUTF8(*s, s.length()); |
210 { | 826 } |
211 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; | 827 |
212 v8::Isolate::Scope isolate_scope(isolate); | 828 v8::Handle<v8::Array> JS_ToArray(v8::Handle<v8::Value> pValue) { |
213 v8::HandleScope handle_scope(isolate); | 829 if (pValue.IsEmpty()) |
214 | 830 return v8::Handle<v8::Array>(); |
215 CFX_WideString ws = CFX_WideString((FX_LPCWSTR)sConstName); | 831 return v8::Handle<v8::Array>::Cast(pValue->ToObject()); |
216 CFX_ByteString bsConst= ws.UTF8Encode(); | 832 } |
217 | 833 |
218 v8::Local<v8::ObjectTemplate> objTemp; | 834 void JS_ValueCopy(v8::Handle<v8::Value>& pTo, v8::Handle<v8::Value> pFrom) { |
219 | 835 pTo = pFrom; |
220 v8::Persistent<v8::ObjectTemplate>& globalObjTemp = _getGlobalObjectTemp
late(pJSRuntime); | 836 } |
221 if(globalObjTemp.IsEmpty()) | 837 |
222 objTemp = v8::ObjectTemplate::New(isolate); | 838 // JavaScript time implement begin. |
223 else | 839 |
224 objTemp = v8::Local<v8::ObjectTemplate>::New(isolate, globalObjT
emp); | 840 double _getLocalTZA() { |
225 objTemp->Set(v8::String::NewFromUtf8(isolate, FX_LPCSTR(bsConst)), pDefa
ult, v8::ReadOnly); | 841 if (!FSDK_IsSandBoxPolicyEnabled(FPDF_POLICY_MACHINETIME_ACCESS)) |
226 | 842 return 0; |
227 globalObjTemp.Reset(isolate,objTemp); | 843 time_t t = 0; |
228 | 844 time(&t); |
229 return 0; | 845 localtime(&t); |
230 } | 846 return (double)(-(timezone * 1000)); |
231 | 847 } |
232 | 848 |
233 void JS_InitialRuntime(IJS_Runtime* pJSRuntime,IFXJS_Runtime* pFXRuntime, IFXJS_
Context* context, v8::Persistent<v8::Context>& v8PersistentContext) | 849 int _getDaylightSavingTA(double d) { |
234 { | 850 if (!FSDK_IsSandBoxPolicyEnabled(FPDF_POLICY_MACHINETIME_ACCESS)) |
235 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; | 851 return 0; |
236 v8::Isolate::Scope isolate_scope(isolate); | 852 time_t t = (time_t)(d / 1000); |
237 v8::HandleScope handle_scope(isolate); | 853 struct tm* tmp = localtime(&t); |
238 | 854 if (tmp == NULL) |
239 v8::Persistent<v8::ObjectTemplate>& globalObjTemp = _getGlobalObjectTemp
late(pJSRuntime); | 855 return 0; |
240 v8::Handle<v8::Context> v8Context = v8::Context::New(isolate, NULL, v8::
Local<v8::ObjectTemplate>::New(isolate, globalObjTemp)); | 856 if (tmp->tm_isdst > 0) |
241 v8::Context::Scope context_scope(v8Context); | 857 // One hour. |
242 | 858 return (int)60 * 60 * 1000; |
243 v8::Handle<v8::External> ptr = v8::External::New(isolate, pFXRuntime); | 859 return 0; |
244 v8Context->SetEmbedderData(1, ptr); | 860 } |
245 | 861 |
246 CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(0); | 862 double _Mod(double x, double y) { |
247 if(!pArray) return; | 863 double r = fmod(x, y); |
248 | 864 if (r < 0) |
249 for(int i=0; i<pArray->GetSize(); i++) | 865 r += y; |
250 { | 866 return r; |
251 CJS_ObjDefintion* pObjDef = (CJS_ObjDefintion*)pArray->GetAt(i); | 867 } |
252 CFX_WideString ws = CFX_WideString(pObjDef->objName); | 868 |
253 CFX_ByteString bs = ws.UTF8Encode(); | 869 int _isfinite(double v) { |
254 v8::Handle<v8::String> objName = v8::String::NewFromUtf8(isolate
,(FX_LPCSTR)bs, v8::String::kNormalString, bs.GetLength()); | 870 #if _MSC_VER |
255 | 871 return ::_finite(v); |
256 | 872 #else |
257 if(pObjDef->objType == JS_DYNAMIC) | 873 return std::fabs(v) < std::numeric_limits<double>::max(); |
258 { | |
259 //Document is set as global object, need to construct it
first. | |
260 if(ws.Equal(L"Document")) | |
261 { | |
262 | |
263 CJS_PrivateData* pPrivateData = FX_NEW CJS_Priva
teData; | |
264 pPrivateData->ObjDefID = i; | |
265 v8::Handle<v8::External> ptr = v8::External::New
(isolate, pPrivateData); | |
266 | |
267 v8Context->Global()->GetPrototype()->ToObject()-
>SetInternalField(0, ptr); | |
268 | |
269 if(pObjDef->m_pConstructor) | |
270 pObjDef->m_pConstructor(context, v8Conte
xt->Global()->GetPrototype()->ToObject(), v8Context->Global()->GetPrototype()->T
oObject()); | |
271 } | |
272 } | |
273 else | |
274 { | |
275 v8::Handle<v8::Object> obj = JS_NewFxDynamicObj(pJSRunti
me, context, i); | |
276 v8Context->Global()->Set(objName, obj); | |
277 pObjDef->m_StaticObj.Reset(isolate, obj); | |
278 } | |
279 } | |
280 v8PersistentContext.Reset(isolate, v8Context); | |
281 } | |
282 | |
283 void JS_ReleaseRuntime(IJS_Runtime* pJSRuntime, v8::Persistent<v8::Context>& v8P
ersistentContext) | |
284 { | |
285 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; | |
286 v8::Isolate::Scope isolate_scope(isolate); | |
287 v8::HandleScope handle_scope(isolate); | |
288 v8::Local<v8::Context> context = v8::Local<v8::Context>::New(isolate, v8
PersistentContext); | |
289 v8::Context::Scope context_scope(context); | |
290 | |
291 CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(0); | |
292 if(!pArray) return ; | |
293 | |
294 for(int i=0; i<pArray->GetSize(); i++) | |
295 { | |
296 CJS_ObjDefintion* pObjDef = (CJS_ObjDefintion*)pArray->GetAt(i); | |
297 if(!pObjDef->m_StaticObj.IsEmpty()) | |
298 { | |
299 v8::Local<v8::Object> pObj = v8::Local<v8::Object>::New(
isolate, pObjDef->m_StaticObj); | |
300 if(pObjDef->m_pDestructor) | |
301 pObjDef->m_pDestructor(pObj); | |
302 JS_FreePrivate(pObj); | |
303 } | |
304 delete pObjDef; | |
305 } | |
306 delete pArray; | |
307 isolate->SetData(0,NULL); | |
308 } | |
309 | |
310 void JS_Initial() | |
311 { | |
312 #ifndef FOXIT_CHROME_BUILD | |
313 v8::V8::InitializeICU(); | |
314 #endif | 874 #endif |
315 } | 875 } |
316 void JS_Release() | 876 |
317 { | 877 double _toInteger(double n) { |
318 | 878 return (n >= 0) ? FXSYS_floor(n) : -FXSYS_floor(-n); |
319 } | 879 } |
320 int JS_Parse(IJS_Runtime* pJSRuntime, IFXJS_Context* pJSContext, const wchar_t*
script, long length, FXJSErr* perror) | 880 |
321 { | 881 bool _isLeapYear(int year) { |
322 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; | 882 return (year % 4 == 0) && ((year % 100 != 0) || (year % 400 != 0)); |
323 v8::Isolate::Scope isolate_scope(isolate); | 883 } |
324 v8::TryCatch try_catch; | 884 |
325 | 885 int _DayFromYear(int y) { |
326 CFX_WideString wsScript(script); | 886 return (int)(365 * (y - 1970.0) + FXSYS_floor((y - 1969.0) / 4) - |
327 CFX_ByteString bsScript = wsScript.UTF8Encode(); | 887 FXSYS_floor((y - 1901.0) / 100) + |
328 | 888 FXSYS_floor((y - 1601.0) / 400)); |
329 | 889 } |
330 v8::Handle<v8::Script> compiled_script = v8::Script::Compile(v8::String:
:NewFromUtf8(isolate,(FX_LPCSTR)bsScript,v8::String::kNormalString, bsScript.Get
Length())); | 890 |
331 if (compiled_script.IsEmpty()) { | 891 double _TimeFromYear(int y) { |
332 v8::String::Utf8Value error(try_catch.Exception()); | 892 return ((double)86400000) * _DayFromYear(y); |
333 return -1; | 893 } |
334 } | 894 |
335 return 0; | 895 double _TimeFromYearMonth(int y, int m) { |
336 } | 896 static int daysMonth[12] = { 0, 31, 59, 90, 120, 151, |
337 | 897 181, 212, 243, 273, 304, 334 }; |
338 int JS_Execute(IJS_Runtime* pJSRuntime, IFXJS_Context* pJSContext, const wchar_t
* script, long length, FXJSErr* perror) | 898 static int leapDaysMonth[12] = { 0, 31, 60, 91, 121, 152, |
339 { | 899 182, 213, 244, 274, 305, 335 }; |
340 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; | 900 int* pMonth = daysMonth; |
341 v8::Isolate::Scope isolate_scope(isolate); | 901 if (_isLeapYear(y)) |
342 v8::TryCatch try_catch; | 902 pMonth = leapDaysMonth; |
343 | 903 return _TimeFromYear(y) + ((double)pMonth[m]) * 86400000; |
344 CFX_WideString wsScript(script); | 904 } |
345 CFX_ByteString bsScript = wsScript.UTF8Encode(); | 905 |
346 | 906 int _Day(double t) { |
347 v8::Handle<v8::Script> compiled_script = v8::Script::Compile(v8::String:
:NewFromUtf8(isolate,(FX_LPCSTR)bsScript,v8::String::kNormalString, bsScript.Get
Length())); | 907 return (int)FXSYS_floor(t / 86400000); |
348 if (compiled_script.IsEmpty()) { | 908 } |
349 v8::String::Utf8Value error(try_catch.Exception()); | 909 |
350 return -1; | 910 int _YearFromTime(double t) { |
351 } | 911 // estimate the time. |
352 | 912 int y = 1970 + (int)(t / (365.0 * 86400000)); |
353 v8::Handle<v8::Value> result = compiled_script->Run(); | 913 if (_TimeFromYear(y) <= t) { |
354 if (result.IsEmpty()) { | 914 while (_TimeFromYear(y + 1) <= t) |
355 v8::String::Utf8Value error(try_catch.Exception()); | 915 y++; |
356 return -1; | 916 } else |
357 } | 917 while (_TimeFromYear(y - 1) > t) |
358 return 0; | 918 y--; |
359 } | 919 return y; |
360 | 920 } |
361 v8::Handle<v8::Object> JS_NewFxDynamicObj(IJS_Runtime* pJSRuntime, IFXJS_Context
* pJSContext, int nObjDefnID) | 921 |
362 { | 922 int _DayWithinYear(double t) { |
363 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; | 923 int year = _YearFromTime(t); |
364 v8::Isolate::Scope isolate_scope(isolate); | 924 int day = _Day(t); |
365 if(-1 == nObjDefnID) | 925 return day - _DayFromYear(year); |
366 { | 926 } |
367 v8::Local<v8::ObjectTemplate> objTempl = v8::ObjectTemplate::New
(isolate); | 927 |
368 return objTempl->NewInstance(); | 928 int _MonthFromTime(double t) { |
369 } | 929 int day = _DayWithinYear(t); |
370 | 930 int year = _YearFromTime(t); |
371 CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(0); | 931 if (0 <= day && day < 31) |
372 if(!pArray) return v8::Handle<v8::Object>(); | 932 return 0; |
373 | 933 if (31 <= day && day < 59 + _isLeapYear(year)) |
374 | 934 return 1; |
375 if(nObjDefnID<0 || nObjDefnID>= pArray->GetSize()) return v8::Handle<v8:
:Object>(); | 935 if ((59 + _isLeapYear(year)) <= day && day < (90 + _isLeapYear(year))) |
376 CJS_ObjDefintion* pObjDef = (CJS_ObjDefintion*)pArray->GetAt(nObjDefnID)
; | 936 return 2; |
377 | 937 if ((90 + _isLeapYear(year)) <= day && day < (120 + _isLeapYear(year))) |
378 v8::Local<v8::Context> context = isolate->GetCurrentContext(); | 938 return 3; |
379 v8::Local<v8::ObjectTemplate> objTemp = v8::Local<v8::ObjectTemplate>::N
ew(isolate, pObjDef->m_objTemplate); | 939 if ((120 + _isLeapYear(year)) <= day && day < (151 + _isLeapYear(year))) |
380 | 940 return 4; |
381 v8::Local<v8::Object> obj = objTemp->NewInstance(); | 941 if ((151 + _isLeapYear(year)) <= day && day < (181 + _isLeapYear(year))) |
382 | 942 return 5; |
383 CJS_PrivateData* pPrivateData = FX_NEW CJS_PrivateData; | 943 if ((181 + _isLeapYear(year)) <= day && day < (212 + _isLeapYear(year))) |
384 pPrivateData->ObjDefID = nObjDefnID; | 944 return 6; |
385 v8::Handle<v8::External> ptr = v8::External::New(isolate, pPrivateData); | 945 if ((212 + _isLeapYear(year)) <= day && day < (243 + _isLeapYear(year))) |
386 obj->SetInternalField(0, ptr); | 946 return 7; |
387 | 947 if ((243 + _isLeapYear(year)) <= day && day < (273 + _isLeapYear(year))) |
388 if(pObjDef->m_pConstructor) | 948 return 8; |
389 pObjDef->m_pConstructor(pJSContext, obj, context->Global()->GetP
rototype()->ToObject()); | 949 if ((273 + _isLeapYear(year)) <= day && day < (304 + _isLeapYear(year))) |
390 | 950 return 9; |
391 return obj; | 951 if ((304 + _isLeapYear(year)) <= day && day < (334 + _isLeapYear(year))) |
392 } | 952 return 10; |
393 | 953 if ((334 + _isLeapYear(year)) <= day && day < (365 + _isLeapYear(year))) |
394 v8::Handle<v8::Object> JS_GetStaticObj(IJS_Runtime* pJSRuntime, int nObjDefnID) | 954 return 11; |
395 { | 955 |
396 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; | 956 return -1; |
397 v8::Isolate::Scope isolate_scope(isolate); | 957 } |
398 | 958 |
399 CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(0); | 959 int _DateFromTime(double t) { |
400 if(!pArray) return v8::Handle<v8::Object>(); | 960 int day = _DayWithinYear(t); |
401 | 961 int year = _YearFromTime(t); |
402 if(nObjDefnID<0 || nObjDefnID>= pArray->GetSize()) return v8::Handle<v8:
:Object>(); | 962 bool leap = _isLeapYear(year); |
403 CJS_ObjDefintion* pObjDef = (CJS_ObjDefintion*)pArray->GetAt(nObjDefnID)
; | 963 int month = _MonthFromTime(t); |
404 v8::Local<v8::Object> obj = v8::Local<v8::Object>::New(isolate,pObjDef->
m_StaticObj); | 964 switch (month) { |
405 return obj; | 965 case 0: |
406 } | 966 return day + 1; |
407 | 967 case 1: |
408 void JS_SetThisObj(IJS_Runtime* pJSRuntime, int nThisObjID) | 968 return day - 30; |
409 { | 969 case 2: |
410 //Do nothing. | 970 return day - 58 - leap; |
411 } | 971 case 3: |
412 v8::Handle<v8::Object> JS_GetThisObj(IJS_Runtime * pJSRuntime) | 972 return day - 89 - leap; |
413 { | 973 case 4: |
414 //Return the global object. | 974 return day - 119 - leap; |
415 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; | 975 case 5: |
416 v8::Isolate::Scope isolate_scope(isolate); | 976 return day - 150 - leap; |
417 | 977 case 6: |
418 CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(0); | 978 return day - 180 - leap; |
419 if(!pArray) return v8::Handle<v8::Object>(); | 979 case 7: |
420 | 980 return day - 211 - leap; |
421 v8::Local<v8::Context> context = isolate->GetCurrentContext(); | 981 case 8: |
422 return context->Global()->GetPrototype()->ToObject(); | 982 return day - 242 - leap; |
423 } | 983 case 9: |
424 | 984 return day - 272 - leap; |
425 int JS_GetObjDefnID(v8::Handle<v8::Object> pObj) | 985 case 10: |
426 { | 986 return day - 303 - leap; |
427 if(pObj.IsEmpty() || !pObj->InternalFieldCount()) return -1; | 987 case 11: |
428 v8::Handle<v8::External> field = v8::Handle<v8::External>::Cast(pObj->Ge
tInternalField(0)); | 988 return day - 333 - leap; |
429 CJS_PrivateData* pPrivateData = (CJS_PrivateData*)field->Value(); | 989 default: |
430 if(pPrivateData) | 990 return 0; |
431 return pPrivateData->ObjDefID; | 991 } |
432 return -1; | 992 } |
433 } | 993 |
434 | 994 double JS_GetDateTime() { |
435 IJS_Runtime* JS_GetRuntime(v8::Handle<v8::Object> pObj) | 995 if (!FSDK_IsSandBoxPolicyEnabled(FPDF_POLICY_MACHINETIME_ACCESS)) |
436 { | 996 return 0; |
437 if(pObj.IsEmpty()) return NULL; | 997 time_t t = time(NULL); |
438 v8::Local<v8::Context> context = pObj->CreationContext(); | 998 struct tm* pTm = localtime(&t); |
439 if(context.IsEmpty()) return NULL; | 999 |
440 return context->GetIsolate(); | 1000 int year = pTm->tm_year + 1900; |
441 } | 1001 double t1 = _TimeFromYear(year); |
442 | 1002 |
443 int JS_GetObjDefnID(IJS_Runtime * pJSRuntime, const wchar_t* pObjName) | 1003 return t1 + pTm->tm_yday * 86400000.0 + pTm->tm_hour * 3600000.0 + |
444 { | 1004 pTm->tm_min * 60000.0 + pTm->tm_sec * 1000.0; |
445 v8::Isolate* isolate = (v8::Isolate*)pJSRuntime; | 1005 } |
446 v8::Isolate::Scope isolate_scope(isolate); | 1006 |
447 | 1007 int JS_GetYearFromTime(double dt) { |
448 CFX_PtrArray* pArray = (CFX_PtrArray*)isolate->GetData(0); | 1008 return _YearFromTime(dt); |
449 if(!pArray) return -1; | 1009 } |
450 | 1010 |
451 for(int i=0; i<pArray->GetSize(); i++) | 1011 int JS_GetMonthFromTime(double dt) { |
452 { | 1012 return _MonthFromTime(dt); |
453 CJS_ObjDefintion* pObjDef = (CJS_ObjDefintion*)pArray->GetAt(i); | 1013 } |
454 if(FXSYS_wcscmp(pObjDef->objName, pObjName) == 0) | 1014 |
455 return i; | 1015 int JS_GetDayFromTime(double dt) { |
456 } | 1016 return _DateFromTime(dt); |
457 return -1; | 1017 } |
458 } | 1018 |
459 | 1019 int JS_GetHourFromTime(double dt) { |
460 void JS_Error(v8::Value * pError,const wchar_t * main,const wchar_t * sub) | 1020 return (int)_Mod(FXSYS_floor((double)(dt / (60 * 60 * 1000))), 24); |
461 { | 1021 } |
462 | 1022 |
463 } | 1023 int JS_GetMinFromTime(double dt) { |
464 | 1024 return (int)_Mod(FXSYS_floor((double)(dt / (60 * 1000))), 60); |
465 unsigned JS_CalcHash(const wchar_t* main, unsigned nLen) | 1025 } |
466 { | 1026 |
467 return (unsigned)FX_HashCode_String_GetW(main, nLen); | 1027 int JS_GetSecFromTime(double dt) { |
468 } | 1028 return (int)_Mod(FXSYS_floor((double)(dt / 1000)), 60); |
469 | 1029 } |
470 unsigned JS_CalcHash(const wchar_t* main) | 1030 |
471 { | 1031 double JS_DateParse(const wchar_t* string) { |
472 return (unsigned)FX_HashCode_String_GetW(main, FXSYS_wcslen(main)); | 1032 v8::Isolate* pIsolate = v8::Isolate::GetCurrent(); |
473 } | 1033 v8::Isolate::Scope isolate_scope(pIsolate); |
474 const wchar_t* JS_GetTypeof(v8::Handle<v8::Value> pObj) | 1034 v8::HandleScope scope(pIsolate); |
475 { | 1035 |
476 if(pObj.IsEmpty()) return NULL; | 1036 v8::Local<v8::Context> context = pIsolate->GetCurrentContext(); |
477 if(pObj->IsString()) | 1037 |
478 return VALUE_NAME_STRING; | 1038 // Use the built-in object method. |
479 if(pObj->IsNumber()) | 1039 v8::Local<v8::Value> v = |
480 return VALUE_NAME_NUMBER; | 1040 context->Global()->Get(v8::String::NewFromUtf8(pIsolate, "Date")); |
481 if(pObj->IsBoolean()) | 1041 if (v->IsObject()) { |
482 return VALUE_NAME_BOOLEAN; | 1042 v8::Local<v8::Object> o = v->ToObject(); |
483 if(pObj->IsDate()) | 1043 v = o->Get(v8::String::NewFromUtf8(pIsolate, "parse")); |
484 return VALUE_NAME_DATE; | 1044 if (v->IsFunction()) { |
485 if(pObj->IsObject()) | 1045 v8::Local<v8::Function> funC = v8::Handle<v8::Function>::Cast(v); |
486 return VALUE_NAME_OBJECT; | 1046 |
487 if(pObj->IsNull()) | 1047 const int argc = 1; |
488 return VALUE_NAME_NULL; | 1048 v8::Local<v8::String> timeStr = WSToJSString(pIsolate, string); |
489 if(pObj->IsUndefined()) | 1049 v8::Handle<v8::Value> argv[argc] = { timeStr }; |
490 return VALUE_NAME_UNDEFINED; | 1050 v = funC->Call(context->Global(), argc, argv); |
491 return NULL; | 1051 if (v->IsNumber()) { |
492 | 1052 double date = v->ToNumber()->Value(); |
493 } | 1053 if (!_isfinite(date)) |
494 const wchar_t* JS_GetClassname(v8::Handle<v8::Object> pObj) | 1054 return date; |
495 { | 1055 return date + _getLocalTZA() + _getDaylightSavingTA(date); |
496 return NULL; | 1056 } |
497 } | 1057 } |
498 | 1058 } |
499 void JS_SetPrivate(v8::Handle<v8::Object> pObj, void* p) | 1059 return 0; |
500 { | 1060 } |
501 JS_SetPrivate(NULL, pObj, p); | 1061 |
502 } | 1062 double JS_MakeDay(int nYear, int nMonth, int nDate) { |
503 | 1063 if (!_isfinite(nYear) || !_isfinite(nMonth) || !_isfinite(nDate)) |
504 void* JS_GetPrivate(v8::Handle<v8::Object> pObj) | 1064 return g_NaN; |
505 { | 1065 double y = _toInteger(nYear); |
506 return JS_GetPrivate(NULL,pObj); | 1066 double m = _toInteger(nMonth); |
507 } | 1067 double dt = _toInteger(nDate); |
508 | 1068 double ym = y + FXSYS_floor((double)m / 12); |
509 void JS_SetPrivate(IJS_Runtime* pJSRuntime, v8::Handle<v8::Object> pObj, void* p
) | 1069 double mn = _Mod(m, 12); |
510 { | 1070 |
511 if(pObj.IsEmpty() || !pObj->InternalFieldCount()) return; | 1071 double t = _TimeFromYearMonth((int)ym, (int)mn); |
512 v8::Handle<v8::External> ptr = v8::Handle<v8::External>::Cast(pObj->GetI
nternalField(0)); | 1072 |
513 CJS_PrivateData* pPrivateData = (CJS_PrivateData*)ptr->Value(); | 1073 if (_YearFromTime(t) != ym || _MonthFromTime(t) != mn || |
514 if(!pPrivateData) return; | 1074 _DateFromTime(t) != 1) |
515 pPrivateData->pPrivate = p; | 1075 return g_NaN; |
516 } | 1076 return _Day(t) + dt - 1; |
517 | 1077 } |
518 void* JS_GetPrivate(IJS_Runtime* pJSRuntime, v8::Handle<v8::Object> pObj) | 1078 |
519 { | 1079 double JS_MakeTime(int nHour, int nMin, int nSec, int nMs) { |
520 if(pObj.IsEmpty()) return NULL; | 1080 if (!_isfinite(nHour) || !_isfinite(nMin) || !_isfinite(nSec) || |
521 v8::Local<v8::Value> value; | 1081 !_isfinite(nMs)) |
522 if(pObj->InternalFieldCount()) | 1082 return g_NaN; |
523 value = pObj->GetInternalField(0); | 1083 |
524 else | 1084 double h = _toInteger(nHour); |
525 { | 1085 double m = _toInteger(nMin); |
526 //It could be a global proxy object. | 1086 double s = _toInteger(nSec); |
527 v8::Local<v8::Value> v = pObj->GetPrototype(); | 1087 double milli = _toInteger(nMs); |
528 if(v->IsObject()) | 1088 |
529 value = v->ToObject()->GetInternalField(0); | 1089 return h * 3600000 + m * 60000 + s * 1000 + milli; |
530 } | 1090 } |
531 if(value.IsEmpty() || value->IsUndefined()) return NULL; | 1091 |
532 v8::Handle<v8::External> ptr = v8::Handle<v8::External>::Cast(value); | 1092 double JS_MakeDate(double day, double time) { |
533 CJS_PrivateData* pPrivateData = (CJS_PrivateData*)ptr->Value(); | 1093 if (!_isfinite(day) || !_isfinite(time)) |
534 if(!pPrivateData) return NULL; | 1094 return g_NaN; |
535 return pPrivateData->pPrivate; | 1095 |
536 } | 1096 return day * 86400000 + time; |
537 | 1097 } |
538 void JS_FreePrivate(v8::Handle<v8::Object> pObj) | 1098 |
539 { | 1099 bool JS_PortIsNan(double d) { |
540 if(pObj.IsEmpty() || !pObj->InternalFieldCount()) return; | 1100 return d != d; |
541 v8::Handle<v8::External> ptr = v8::Handle<v8::External>::Cast(pObj->GetI
nternalField(0)); | 1101 } |
542 delete (CJS_PrivateData*)ptr->Value(); | 1102 |
543 v8::Local<v8::Context> context = pObj->CreationContext(); | 1103 double JS_LocalTime(double d) { |
544 | 1104 return JS_GetDateTime() + _getDaylightSavingTA(d); |
545 pObj->SetInternalField(0, v8::External::New(context->GetIsolate(), NULL)
); | 1105 } |
546 } | 1106 |
547 | 1107 // JavaScript time implement End. |
548 | |
549 v8::Handle<v8::Value> JS_GetObjectValue(v8::Handle<v8::Object> pObj) | |
550 { | |
551 return pObj; | |
552 } | |
553 | |
554 v8::Handle<v8::String> WSToJSString(IJS_Runtime* pJSRuntime, const wchar_t* Prop
ertyName, int Len = -1) | |
555 { | |
556 CFX_WideString ws = CFX_WideString(PropertyName,Len); | |
557 CFX_ByteString bs = ws.UTF8Encode(); | |
558 if(!pJSRuntime) pJSRuntime = v8::Isolate::GetCurrent(); | |
559 return v8::String::NewFromUtf8(pJSRuntime, (FX_LPCSTR)bs); | |
560 } | |
561 | |
562 v8::Handle<v8::Value> JS_GetObjectElement(IJS_Runtime* pJSRuntime, v8::Handle<v8
::Object> pObj,const wchar_t* PropertyName) | |
563 { | |
564 if(pObj.IsEmpty()) return v8::Handle<v8::Value>(); | |
565 return pObj->Get(WSToJSString(pJSRuntime,PropertyName)); | |
566 } | |
567 | |
568 v8::Handle<v8::Array> JS_GetObjectElementNames(v8::Handle<v8::Object> pObj) | |
569 { | |
570 if(pObj.IsEmpty()) return v8::Handle<v8::Array>(); | |
571 return pObj->GetPropertyNames(); | |
572 } | |
573 | |
574 void JS_PutObjectString(IJS_Runtime* pJSRuntime,v8::Handle<v8::Object> pObj, con
st wchar_t* PropertyName, const wchar_t* sValue) //VT_string | |
575 { | |
576 if(pObj.IsEmpty()) return; | |
577 pObj->Set(WSToJSString(pJSRuntime, PropertyName), WSToJSString(pJSRuntim
e, sValue)); | |
578 } | |
579 | |
580 void JS_PutObjectNumber(IJS_Runtime* pJSRuntime,v8::Handle<v8::Object> pObj, con
st wchar_t* PropertyName, int nValue) | |
581 { | |
582 if(pObj.IsEmpty()) return; | |
583 pObj->Set(WSToJSString(pJSRuntime,PropertyName),v8::Int32::New(pJSRuntim
e, nValue)); | |
584 } | |
585 | |
586 void JS_PutObjectNumber(IJS_Runtime* pJSRuntime,v8::Handle<v8::Object> pObj, con
st wchar_t* PropertyName, float fValue) | |
587 { | |
588 if(pObj.IsEmpty()) return; | |
589 pObj->Set(WSToJSString(pJSRuntime,PropertyName),v8::Number::New(pJSRunti
me, (double)fValue)); | |
590 } | |
591 | |
592 void JS_PutObjectNumber(IJS_Runtime* pJSRuntime,v8::Handle<v8::Object> pObj, con
st wchar_t* PropertyName, double dValue) | |
593 { | |
594 if(pObj.IsEmpty()) return; | |
595 pObj->Set(WSToJSString(pJSRuntime,PropertyName),v8::Number::New(pJSRunti
me, (double)dValue)); | |
596 } | |
597 | |
598 void JS_PutObjectBoolean(IJS_Runtime* pJSRuntime,v8::Handle<v8::Object> pObj, co
nst wchar_t* PropertyName, bool bValue) | |
599 { | |
600 if(pObj.IsEmpty()) return; | |
601 pObj->Set(WSToJSString(pJSRuntime,PropertyName),v8::Boolean::New(pJSRunt
ime, bValue)); | |
602 } | |
603 | |
604 void JS_PutObjectObject(IJS_Runtime* pJSRuntime,v8::Handle<v8::Object> pObj, con
st wchar_t* PropertyName, v8::Handle<v8::Object> pPut) | |
605 { | |
606 if(pObj.IsEmpty()) return; | |
607 pObj->Set(WSToJSString(pJSRuntime,PropertyName),pPut); | |
608 } | |
609 | |
610 void JS_PutObjectNull(IJS_Runtime* pJSRuntime,v8::Handle<v8::Object> pObj, const
wchar_t* PropertyName) | |
611 { | |
612 if(pObj.IsEmpty()) return; | |
613 pObj->Set(WSToJSString(pJSRuntime,PropertyName),v8::Handle<v8::Object>()
); | |
614 } | |
615 | |
616 v8::Handle<v8::Array> JS_NewArray(IJS_Runtime* pJSRuntime) | |
617 { | |
618 return v8::Array::New(pJSRuntime); | |
619 } | |
620 | |
621 unsigned JS_PutArrayElement(v8::Handle<v8::Array> pArray,unsigned index,v8::Hand
le<v8::Value> pValue,FXJSVALUETYPE eType) | |
622 { | |
623 if(pArray.IsEmpty()) return 0; | |
624 pArray->Set(index, pValue); | |
625 return 1; | |
626 } | |
627 | |
628 v8::Handle<v8::Value> JS_GetArrayElemnet(v8::Handle<v8::Array> pArray,unsigned i
ndex) | |
629 { | |
630 if(pArray.IsEmpty()) return v8::Handle<v8::Value>(); | |
631 return pArray->Get(index); | |
632 } | |
633 | |
634 unsigned JS_GetArrayLength(v8::Handle<v8::Array> pArray) | |
635 { | |
636 if(pArray.IsEmpty()) return 0; | |
637 return pArray->Length(); | |
638 } | |
639 | |
640 v8::Handle<v8::Value> JS_NewNumber(IJS_Runtime* pJSRuntime,int number) | |
641 { | |
642 return v8::Int32::New(pJSRuntime, number); | |
643 } | |
644 | |
645 v8::Handle<v8::Value> JS_NewNumber(IJS_Runtime* pJSRuntime,double number) | |
646 { | |
647 return v8::Number::New(pJSRuntime, number); | |
648 } | |
649 | |
650 v8::Handle<v8::Value> JS_NewNumber(IJS_Runtime* pJSRuntime,float number) | |
651 { | |
652 return v8::Number::New(pJSRuntime, (float)number); | |
653 } | |
654 | |
655 v8::Handle<v8::Value> JS_NewBoolean(IJS_Runtime* pJSRuntime,bool b) | |
656 { | |
657 return v8::Boolean::New(pJSRuntime, b); | |
658 } | |
659 | |
660 v8::Handle<v8::Value> JS_NewObject(IJS_Runtime* pJSRuntime,v8::Handle<v8::Object
> pObj) | |
661 { | |
662 if(pObj.IsEmpty()) return v8::Handle<v8::Value>(); | |
663 return pObj->Clone(); | |
664 } | |
665 | |
666 v8::Handle<v8::Value> JS_NewObject2(IJS_Runtime* pJSRuntime,v8::Handle<v8::Array
> pObj) | |
667 { | |
668 if(pObj.IsEmpty()) return v8::Handle<v8::Value>(); | |
669 return pObj->Clone(); | |
670 } | |
671 | |
672 | |
673 v8::Handle<v8::Value> JS_NewString(IJS_Runtime* pJSRuntime,const wchar_t* string
) | |
674 { | |
675 return WSToJSString(pJSRuntime, string); | |
676 } | |
677 | |
678 v8::Handle<v8::Value> JS_NewString(IJS_Runtime* pJSRuntime,const wchar_t* string
, unsigned nLen) | |
679 { | |
680 return WSToJSString(pJSRuntime, string, nLen); | |
681 } | |
682 | |
683 v8::Handle<v8::Value> JS_NewNull() | |
684 { | |
685 return v8::Handle<v8::Value>(); | |
686 } | |
687 | |
688 v8::Handle<v8::Value> JS_NewDate(IJS_Runtime* pJSRuntime,double d) | |
689 { | |
690 return v8::Date::New(pJSRuntime, d); | |
691 } | |
692 | |
693 v8::Handle<v8::Value> JS_NewValue(IJS_Runtime* pJSRuntime) | |
694 { | |
695 return v8::Handle<v8::Value>(); | |
696 } | |
697 | |
698 v8::Handle<v8::Value> JS_GetListValue(v8::Handle<v8::Value> pList, int index) | |
699 { | |
700 | |
701 if(!pList.IsEmpty() && pList->IsObject()) | |
702 { | |
703 v8::Local<v8::Object> obj = pList->ToObject(); | |
704 return obj->Get(index); | |
705 } | |
706 return v8::Handle<v8::Value>(); | |
707 } | |
708 | |
709 int JS_ToInt32(v8::Handle<v8::Value> pValue) | |
710 { | |
711 if(pValue.IsEmpty()) return 0; | |
712 return pValue->ToInt32()->Value(); | |
713 } | |
714 | |
715 bool JS_ToBoolean(v8::Handle<v8::Value> pValue) | |
716 { | |
717 if(pValue.IsEmpty()) return false; | |
718 return pValue->ToBoolean()->Value(); | |
719 } | |
720 | |
721 double JS_ToNumber(v8::Handle<v8::Value> pValue) | |
722 { | |
723 if(pValue.IsEmpty()) return 0.0; | |
724 return pValue->ToNumber()->Value(); | |
725 } | |
726 | |
727 v8::Handle<v8::Object> JS_ToObject(v8::Handle<v8::Value> pValue) | |
728 { | |
729 if(pValue.IsEmpty()) return v8::Handle<v8::Object>(); | |
730 return pValue->ToObject(); | |
731 } | |
732 | |
733 CFX_WideString JS_ToString(v8::Handle<v8::Value> pValue) | |
734 { | |
735 if(pValue.IsEmpty()) return L""; | |
736 v8::String::Utf8Value s(pValue->ToString()); | |
737 return CFX_WideString::FromUTF8(*s, s.length()); | |
738 } | |
739 | |
740 v8::Handle<v8::Array> JS_ToArray(v8::Handle<v8::Value> pValue) | |
741 { | |
742 if(pValue.IsEmpty()) return v8::Handle<v8::Array>(); | |
743 return v8::Handle<v8::Array>::Cast(pValue->ToObject()); | |
744 } | |
745 | |
746 void JS_ValueCopy(v8::Handle<v8::Value>& pTo, v8::Handle<v8::Value> pFrom) | |
747 { | |
748 pTo = pFrom; | |
749 } | |
750 | |
751 | |
752 //JavaScript time implement begin. | |
753 | |
754 double _getLocalTZA() | |
755 { | |
756 if(!FSDK_IsSandBoxPolicyEnabled(FPDF_POLICY_MACHINETIME_ACCESS)) | |
757 return 0; | |
758 time_t t = 0; | |
759 time(&t); | |
760 localtime(&t); | |
761 return (double)(-(timezone * 1000)); | |
762 } | |
763 | |
764 int _getDaylightSavingTA(double d) | |
765 { | |
766 if(!FSDK_IsSandBoxPolicyEnabled(FPDF_POLICY_MACHINETIME_ACCESS)) | |
767 return 0; | |
768 time_t t = (time_t)(d/1000); | |
769 struct tm * tmp = localtime(&t); | |
770 if (tmp == NULL) | |
771 return 0; | |
772 if (tmp->tm_isdst > 0) | |
773 //One hour. | |
774 return (int)60*60*1000; | |
775 return 0; | |
776 } | |
777 | |
778 double _Mod(double x, double y) | |
779 { | |
780 double r = fmod(x, y); | |
781 if (r < 0) r += y; | |
782 return r; | |
783 } | |
784 | |
785 int _isfinite(double v) | |
786 { | |
787 #if _MSC_VER | |
788 return ::_finite(v); | |
789 #else | |
790 return std::fabs(v) < std::numeric_limits<double>::max(); | |
791 #endif | |
792 } | |
793 | |
794 double _toInteger(double n) | |
795 { | |
796 return (n >= 0)? FXSYS_floor(n): -FXSYS_floor(-n); | |
797 } | |
798 | |
799 bool _isLeapYear(int year) | |
800 { | |
801 return (year%4==0)&&((year%100!=0)||(year%400!=0)); | |
802 } | |
803 | |
804 int _DayFromYear(int y) | |
805 { | |
806 return (int)(365*(y - 1970.0) + FXSYS_floor((y - 1969.0)/4) - FXSYS_floo
r((y - 1901.0)/100)+FXSYS_floor((y - 1601.0)/400)); | |
807 } | |
808 | |
809 double _TimeFromYear(int y) | |
810 { | |
811 return ((double)86400000) * _DayFromYear(y); | |
812 } | |
813 | |
814 double _TimeFromYearMonth(int y, int m) | |
815 { | |
816 static int daysMonth[12] ={ 0,31,59,90,120,151,181,212,243,273,304,334}; | |
817 static int leapDaysMonth[12] = { 0,31,60,91,121,152,182,213,244,274,305,
335}; | |
818 int* pMonth = daysMonth; | |
819 if(_isLeapYear(y)) | |
820 pMonth = leapDaysMonth; | |
821 return _TimeFromYear(y) + ((double)pMonth[m])*86400000; | |
822 } | |
823 | |
824 int _Day(double t) | |
825 { | |
826 return (int)FXSYS_floor(t / 86400000); | |
827 } | |
828 | |
829 int _YearFromTime(double t) | |
830 { | |
831 //estimate the time. | |
832 int y = 1970 +(int)(t/(365.0*86400000)); | |
833 if (_TimeFromYear(y) <= t) | |
834 { | |
835 while(_TimeFromYear(y+1) <= t) y++; | |
836 } | |
837 else | |
838 while(_TimeFromYear(y-1) > t) y--; | |
839 return y; | |
840 } | |
841 | |
842 int _DayWithinYear(double t) | |
843 { | |
844 int year = _YearFromTime(t); | |
845 int day = _Day(t); | |
846 return day-_DayFromYear(year); | |
847 } | |
848 | |
849 int _MonthFromTime(double t) | |
850 { | |
851 int day = _DayWithinYear(t); | |
852 int year = _YearFromTime(t); | |
853 if(0<=day && day <31) | |
854 return 0; | |
855 if(31<=day && day< 59+_isLeapYear(year)) | |
856 return 1; | |
857 if((59+_isLeapYear(year))<=day && day<(90+_isLeapYear(year))) | |
858 return 2; | |
859 if((90+_isLeapYear(year))<=day && day<(120+_isLeapYear(year))) | |
860 return 3; | |
861 if((120+_isLeapYear(year))<=day && day<(151+_isLeapYear(year))) | |
862 return 4; | |
863 if((151+_isLeapYear(year))<=day && day<(181+_isLeapYear(year))) | |
864 return 5; | |
865 if((181+_isLeapYear(year))<=day && day<(212+_isLeapYear(year))) | |
866 return 6; | |
867 if((212+_isLeapYear(year))<=day && day<(243+_isLeapYear(year))) | |
868 return 7; | |
869 if((243+_isLeapYear(year))<=day && day<(273+_isLeapYear(year))) | |
870 return 8; | |
871 if((273+_isLeapYear(year))<=day && day<(304+_isLeapYear(year))) | |
872 return 9; | |
873 if((304+_isLeapYear(year))<=day && day<(334+_isLeapYear(year))) | |
874 return 10; | |
875 if((334+_isLeapYear(year))<=day && day<(365+_isLeapYear(year))) | |
876 return 11; | |
877 | |
878 return -1; | |
879 } | |
880 | |
881 int _DateFromTime(double t) | |
882 { | |
883 int day = _DayWithinYear(t); | |
884 int year = _YearFromTime(t); | |
885 bool leap = _isLeapYear(year); | |
886 int month = _MonthFromTime(t); | |
887 switch (month) | |
888 { | |
889 case 0: | |
890 return day+1; | |
891 case 1: | |
892 return day-30; | |
893 case 2: | |
894 return day-58-leap; | |
895 case 3: | |
896 return day-89-leap; | |
897 case 4: | |
898 return day-119-leap; | |
899 case 5: | |
900 return day-150-leap; | |
901 case 6: | |
902 return day-180-leap; | |
903 case 7: | |
904 return day-211-leap; | |
905 case 8: | |
906 return day-242-leap; | |
907 case 9: | |
908 return day-272-leap; | |
909 case 10: | |
910 return day-303-leap; | |
911 case 11: | |
912 return day-333-leap; | |
913 default: | |
914 return 0; | |
915 } | |
916 } | |
917 | |
918 double JS_GetDateTime() | |
919 { | |
920 if(!FSDK_IsSandBoxPolicyEnabled(FPDF_POLICY_MACHINETIME_ACCESS)) | |
921 return 0; | |
922 time_t t = time(NULL); | |
923 struct tm* pTm = localtime(&t); | |
924 | |
925 int year = pTm->tm_year+1900; | |
926 double t1 = _TimeFromYear(year); | |
927 | |
928 return t1 + pTm->tm_yday*86400000.0 + pTm->tm_hour*3600000.0+pTm->tm_min
*60000.0+pTm->tm_sec*1000.0; | |
929 } | |
930 | |
931 int JS_GetYearFromTime(double dt) | |
932 { | |
933 return _YearFromTime(dt); | |
934 } | |
935 | |
936 int JS_GetMonthFromTime(double dt) | |
937 { | |
938 return _MonthFromTime(dt); | |
939 } | |
940 | |
941 int JS_GetDayFromTime(double dt) | |
942 { | |
943 return _DateFromTime(dt); | |
944 } | |
945 | |
946 int JS_GetHourFromTime(double dt) | |
947 { | |
948 return (int)_Mod(FXSYS_floor((double)(dt/(60*60*1000))), 24); | |
949 } | |
950 | |
951 int JS_GetMinFromTime(double dt) | |
952 { | |
953 return (int)_Mod(FXSYS_floor((double)(dt/(60*1000))), 60); | |
954 } | |
955 | |
956 int JS_GetSecFromTime(double dt) | |
957 { | |
958 return (int)_Mod(FXSYS_floor((double)(dt/1000)), 60); | |
959 } | |
960 | |
961 double JS_DateParse(const wchar_t* string) | |
962 { | |
963 v8::Isolate* pIsolate = v8::Isolate::GetCurrent(); | |
964 v8::Isolate::Scope isolate_scope(pIsolate); | |
965 v8::HandleScope scope(pIsolate); | |
966 | |
967 v8::Local<v8::Context> context = pIsolate->GetCurrentContext(); | |
968 | |
969 //Use the built-in object method. | |
970 v8::Local<v8::Value> v = context->Global()->Get(v8::String::NewFromUtf8(
pIsolate, "Date")); | |
971 if(v->IsObject()) | |
972 { | |
973 v8::Local<v8::Object> o = v->ToObject(); | |
974 v = o->Get(v8::String::NewFromUtf8(pIsolate, "parse")); | |
975 if(v->IsFunction()) | |
976 { | |
977 v8::Local<v8::Function> funC = v8::Handle<v8::Function>:
:Cast(v); | |
978 | |
979 const int argc = 1; | |
980 v8::Local<v8::String> timeStr = WSToJSString(pIsolate, s
tring); | |
981 v8::Handle<v8::Value> argv[argc] = {timeStr}; | |
982 v = funC->Call(context->Global(), argc, argv); | |
983 if(v->IsNumber()) | |
984 { | |
985 double date = v->ToNumber()->Value(); | |
986 if(!_isfinite(date)) return date; | |
987 return date + _getLocalTZA() + _getDaylightSavin
gTA(date); | |
988 } | |
989 | |
990 } | |
991 } | |
992 return 0; | |
993 } | |
994 | |
995 double JS_MakeDay(int nYear, int nMonth, int nDate) | |
996 { | |
997 if (!_isfinite(nYear) || !_isfinite(nMonth) ||!_isfinite(nDate)) | |
998 return g_NaN; | |
999 double y = _toInteger(nYear); | |
1000 double m = _toInteger(nMonth); | |
1001 double dt = _toInteger(nDate); | |
1002 double ym = y + FXSYS_floor((double)m/12); | |
1003 double mn = _Mod(m ,12); | |
1004 | |
1005 double t = _TimeFromYearMonth((int)ym,(int)mn); | |
1006 | |
1007 if (_YearFromTime(t) != ym || _MonthFromTime(t) != mn ||_DateFromTime(t)
!= 1) | |
1008 return g_NaN; | |
1009 return _Day(t)+dt-1; | |
1010 } | |
1011 | |
1012 double JS_MakeTime(int nHour, int nMin, int nSec, int nMs) | |
1013 { | |
1014 if (!_isfinite(nHour) ||!_isfinite(nMin) ||!_isfinite(nSec) ||!_isfinite
(nMs)) | |
1015 return g_NaN; | |
1016 | |
1017 double h = _toInteger(nHour); | |
1018 double m = _toInteger(nMin); | |
1019 double s = _toInteger(nSec); | |
1020 double milli = _toInteger(nMs); | |
1021 | |
1022 return h * 3600000 + m * 60000 + s * 1000 + milli; | |
1023 } | |
1024 | |
1025 double JS_MakeDate(double day, double time) | |
1026 { | |
1027 if (!_isfinite(day) ||!_isfinite(time)) | |
1028 return g_NaN; | |
1029 | |
1030 return day * 86400000 + time; | |
1031 } | |
1032 | |
1033 bool JS_PortIsNan(double d) | |
1034 { | |
1035 return d != d; | |
1036 } | |
1037 | |
1038 double JS_LocalTime(double d) | |
1039 { | |
1040 return JS_GetDateTime() + _getDaylightSavingTA(d); | |
1041 } | |
1042 | |
1043 //JavaScript time implement End. | |
OLD | NEW |