| OLD | NEW |
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project 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 #include "src/api.h" | 5 #include "src/api.h" |
| 6 | 6 |
| 7 #include <string.h> // For memcpy, strlen. | 7 #include <string.h> // For memcpy, strlen. |
| 8 #ifdef V8_USE_ADDRESS_SANITIZER | 8 #ifdef V8_USE_ADDRESS_SANITIZER |
| 9 #include <sanitizer/asan_interface.h> | 9 #include <sanitizer/asan_interface.h> |
| 10 #endif // V8_USE_ADDRESS_SANITIZER | 10 #endif // V8_USE_ADDRESS_SANITIZER |
| (...skipping 310 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 321 } | 321 } |
| 322 | 322 |
| 323 | 323 |
| 324 void V8::SetSnapshotDataBlob(StartupData* snapshot_blob) { | 324 void V8::SetSnapshotDataBlob(StartupData* snapshot_blob) { |
| 325 i::V8::SetSnapshotBlob(snapshot_blob); | 325 i::V8::SetSnapshotBlob(snapshot_blob); |
| 326 } | 326 } |
| 327 | 327 |
| 328 | 328 |
| 329 bool RunExtraCode(Isolate* isolate, const char* utf8_source) { | 329 bool RunExtraCode(Isolate* isolate, const char* utf8_source) { |
| 330 // Run custom script if provided. | 330 // Run custom script if provided. |
| 331 base::ElapsedTimer timer; |
| 332 timer.Start(); |
| 331 TryCatch try_catch; | 333 TryCatch try_catch; |
| 332 Local<String> source_string = String::NewFromUtf8(isolate, utf8_source); | 334 Local<String> source_string = String::NewFromUtf8(isolate, utf8_source); |
| 333 if (try_catch.HasCaught()) return false; | 335 if (try_catch.HasCaught()) return false; |
| 334 ScriptOrigin origin(String::NewFromUtf8(isolate, "<embedded script>")); | 336 ScriptOrigin origin(String::NewFromUtf8(isolate, "<embedded script>")); |
| 335 ScriptCompiler::Source source(source_string, origin); | 337 ScriptCompiler::Source source(source_string, origin); |
| 336 Local<Script> script = ScriptCompiler::Compile(isolate, &source); | 338 Local<Script> script = ScriptCompiler::Compile(isolate, &source); |
| 337 if (try_catch.HasCaught()) return false; | 339 if (try_catch.HasCaught()) return false; |
| 338 script->Run(); | 340 script->Run(); |
| 341 if (i::FLAG_profile_deserialization) { |
| 342 i::PrintF("Executing custom snapshot script took %0.3f ms\n", |
| 343 timer.Elapsed().InMillisecondsF()); |
| 344 } |
| 345 timer.Stop(); |
| 339 return !try_catch.HasCaught(); | 346 return !try_catch.HasCaught(); |
| 340 } | 347 } |
| 341 | 348 |
| 342 | 349 |
| 343 StartupData V8::CreateSnapshotDataBlob(const char* custom_source) { | 350 StartupData V8::CreateSnapshotDataBlob(const char* custom_source) { |
| 344 i::Isolate* internal_isolate = new i::Isolate(true); | 351 i::Isolate* internal_isolate = new i::Isolate(true); |
| 345 Isolate* isolate = reinterpret_cast<Isolate*>(internal_isolate); | 352 Isolate* isolate = reinterpret_cast<Isolate*>(internal_isolate); |
| 346 StartupData result = {NULL, 0}; | 353 StartupData result = {NULL, 0}; |
| 347 { | 354 { |
| 355 base::ElapsedTimer timer; |
| 356 timer.Start(); |
| 348 Isolate::Scope isolate_scope(isolate); | 357 Isolate::Scope isolate_scope(isolate); |
| 349 internal_isolate->Init(NULL); | 358 internal_isolate->Init(NULL); |
| 350 Persistent<Context> context; | 359 Persistent<Context> context; |
| 351 i::Snapshot::Metadata metadata; | 360 i::Snapshot::Metadata metadata; |
| 352 { | 361 { |
| 353 HandleScope handle_scope(isolate); | 362 HandleScope handle_scope(isolate); |
| 354 Handle<Context> new_context = Context::New(isolate); | 363 Handle<Context> new_context = Context::New(isolate); |
| 355 context.Reset(isolate, new_context); | 364 context.Reset(isolate, new_context); |
| 356 if (custom_source != NULL) { | 365 if (custom_source != NULL) { |
| 357 metadata.set_embeds_script(true); | 366 metadata.set_embeds_script(true); |
| (...skipping 19 matching lines...) Expand all Loading... |
| 377 i::StartupSerializer ser(internal_isolate, &snapshot_sink); | 386 i::StartupSerializer ser(internal_isolate, &snapshot_sink); |
| 378 ser.SerializeStrongReferences(); | 387 ser.SerializeStrongReferences(); |
| 379 | 388 |
| 380 i::SnapshotByteSink context_sink; | 389 i::SnapshotByteSink context_sink; |
| 381 i::PartialSerializer context_ser(internal_isolate, &ser, &context_sink); | 390 i::PartialSerializer context_ser(internal_isolate, &ser, &context_sink); |
| 382 context_ser.Serialize(&raw_context); | 391 context_ser.Serialize(&raw_context); |
| 383 ser.SerializeWeakReferences(); | 392 ser.SerializeWeakReferences(); |
| 384 | 393 |
| 385 result = i::Snapshot::CreateSnapshotBlob(ser, context_ser, metadata); | 394 result = i::Snapshot::CreateSnapshotBlob(ser, context_ser, metadata); |
| 386 } | 395 } |
| 396 if (i::FLAG_profile_deserialization) { |
| 397 i::PrintF("Creating snapshot took %0.3f ms\n", |
| 398 timer.Elapsed().InMillisecondsF()); |
| 399 } |
| 400 timer.Stop(); |
| 387 } | 401 } |
| 388 isolate->Dispose(); | 402 isolate->Dispose(); |
| 389 return result; | 403 return result; |
| 390 } | 404 } |
| 391 | 405 |
| 392 | 406 |
| 393 void V8::SetFlagsFromString(const char* str, int length) { | 407 void V8::SetFlagsFromString(const char* str, int length) { |
| 394 i::FlagList::SetFlagsFromString(str, length); | 408 i::FlagList::SetFlagsFromString(str, length); |
| 395 } | 409 } |
| 396 | 410 |
| (...skipping 7579 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 7976 Isolate* isolate = reinterpret_cast<Isolate*>(info.GetIsolate()); | 7990 Isolate* isolate = reinterpret_cast<Isolate*>(info.GetIsolate()); |
| 7977 Address callback_address = | 7991 Address callback_address = |
| 7978 reinterpret_cast<Address>(reinterpret_cast<intptr_t>(callback)); | 7992 reinterpret_cast<Address>(reinterpret_cast<intptr_t>(callback)); |
| 7979 VMState<EXTERNAL> state(isolate); | 7993 VMState<EXTERNAL> state(isolate); |
| 7980 ExternalCallbackScope call_scope(isolate, callback_address); | 7994 ExternalCallbackScope call_scope(isolate, callback_address); |
| 7981 callback(info); | 7995 callback(info); |
| 7982 } | 7996 } |
| 7983 | 7997 |
| 7984 | 7998 |
| 7985 } } // namespace v8::internal | 7999 } } // namespace v8::internal |
| OLD | NEW |