OLD | NEW |
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
4 // met: | 4 // met: |
5 // | 5 // |
6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
(...skipping 187 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
198 #else | 198 #else |
199 bool FLAG_debugger = false; | 199 bool FLAG_debugger = false; |
200 #endif // !V8_SHARED && ENABLE_DEBUGGER_SUPPORT | 200 #endif // !V8_SHARED && ENABLE_DEBUGGER_SUPPORT |
201 HandleScope handle_scope(isolate); | 201 HandleScope handle_scope(isolate); |
202 TryCatch try_catch; | 202 TryCatch try_catch; |
203 options.script_executed = true; | 203 options.script_executed = true; |
204 if (FLAG_debugger) { | 204 if (FLAG_debugger) { |
205 // When debugging make exceptions appear to be uncaught. | 205 // When debugging make exceptions appear to be uncaught. |
206 try_catch.SetVerbose(true); | 206 try_catch.SetVerbose(true); |
207 } | 207 } |
208 ScriptOrigin origin(name); | 208 Handle<Script> script = Script::New(source, name); |
209 Handle<UnboundScript> script = ScriptCompiler::CompileUnbound( | |
210 isolate, ScriptCompiler::Source(source, origin)); | |
211 if (script.IsEmpty()) { | 209 if (script.IsEmpty()) { |
212 // Print errors that happened during compilation. | 210 // Print errors that happened during compilation. |
213 if (report_exceptions && !FLAG_debugger) | 211 if (report_exceptions && !FLAG_debugger) |
214 ReportException(isolate, &try_catch); | 212 ReportException(isolate, &try_catch); |
215 return false; | 213 return false; |
216 } else { | 214 } else { |
217 PerIsolateData* data = PerIsolateData::Get(isolate); | 215 PerIsolateData* data = PerIsolateData::Get(isolate); |
218 Local<Context> realm = | 216 Local<Context> realm = |
219 Local<Context>::New(isolate, data->realms_[data->realm_current_]); | 217 Local<Context>::New(isolate, data->realms_[data->realm_current_]); |
220 realm->Enter(); | 218 realm->Enter(); |
221 Handle<Value> result = script->BindToCurrentContext()->Run(); | 219 Handle<Value> result = script->Run(); |
222 realm->Exit(); | 220 realm->Exit(); |
223 data->realm_current_ = data->realm_switch_; | 221 data->realm_current_ = data->realm_switch_; |
224 if (result.IsEmpty()) { | 222 if (result.IsEmpty()) { |
225 ASSERT(try_catch.HasCaught()); | 223 ASSERT(try_catch.HasCaught()); |
226 // Print errors that happened during execution. | 224 // Print errors that happened during execution. |
227 if (report_exceptions && !FLAG_debugger) | 225 if (report_exceptions && !FLAG_debugger) |
228 ReportException(isolate, &try_catch); | 226 ReportException(isolate, &try_catch); |
229 return false; | 227 return false; |
230 } else { | 228 } else { |
231 ASSERT(!try_catch.HasCaught()); | 229 ASSERT(!try_catch.HasCaught()); |
(...skipping 168 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
400 // Realm.eval(i, s) evaluates s in realm i and returns the result. | 398 // Realm.eval(i, s) evaluates s in realm i and returns the result. |
401 void Shell::RealmEval(const v8::FunctionCallbackInfo<v8::Value>& args) { | 399 void Shell::RealmEval(const v8::FunctionCallbackInfo<v8::Value>& args) { |
402 Isolate* isolate = args.GetIsolate(); | 400 Isolate* isolate = args.GetIsolate(); |
403 PerIsolateData* data = PerIsolateData::Get(isolate); | 401 PerIsolateData* data = PerIsolateData::Get(isolate); |
404 int index = data->RealmIndexOrThrow(args, 0); | 402 int index = data->RealmIndexOrThrow(args, 0); |
405 if (index == -1) return; | 403 if (index == -1) return; |
406 if (args.Length() < 2 || !args[1]->IsString()) { | 404 if (args.Length() < 2 || !args[1]->IsString()) { |
407 Throw(args.GetIsolate(), "Invalid argument"); | 405 Throw(args.GetIsolate(), "Invalid argument"); |
408 return; | 406 return; |
409 } | 407 } |
410 Handle<UnboundScript> script = ScriptCompiler::CompileUnbound( | 408 Handle<Script> script = Script::New(args[1]->ToString()); |
411 isolate, ScriptCompiler::Source(args[1]->ToString())); | |
412 if (script.IsEmpty()) return; | 409 if (script.IsEmpty()) return; |
413 Local<Context> realm = Local<Context>::New(isolate, data->realms_[index]); | 410 Local<Context> realm = Local<Context>::New(isolate, data->realms_[index]); |
414 realm->Enter(); | 411 realm->Enter(); |
415 Handle<Value> result = script->BindToCurrentContext()->Run(); | 412 Handle<Value> result = script->Run(); |
416 realm->Exit(); | 413 realm->Exit(); |
417 args.GetReturnValue().Set(result); | 414 args.GetReturnValue().Set(result); |
418 } | 415 } |
419 | 416 |
420 | 417 |
421 // Realm.shared is an accessor for a single shared value across realms. | 418 // Realm.shared is an accessor for a single shared value across realms. |
422 void Shell::RealmSharedGet(Local<String> property, | 419 void Shell::RealmSharedGet(Local<String> property, |
423 const PropertyCallbackInfo<Value>& info) { | 420 const PropertyCallbackInfo<Value>& info) { |
424 Isolate* isolate = info.GetIsolate(); | 421 Isolate* isolate = info.GetIsolate(); |
425 PerIsolateData* data = PerIsolateData::Get(isolate); | 422 PerIsolateData* data = PerIsolateData::Get(isolate); |
(...skipping 376 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
802 i::Vector<const char> shell_source = | 799 i::Vector<const char> shell_source = |
803 i::NativesCollection<i::D8>::GetRawScriptSource(source_index); | 800 i::NativesCollection<i::D8>::GetRawScriptSource(source_index); |
804 i::Vector<const char> shell_source_name = | 801 i::Vector<const char> shell_source_name = |
805 i::NativesCollection<i::D8>::GetScriptName(source_index); | 802 i::NativesCollection<i::D8>::GetScriptName(source_index); |
806 Handle<String> source = | 803 Handle<String> source = |
807 String::NewFromUtf8(isolate, shell_source.start(), String::kNormalString, | 804 String::NewFromUtf8(isolate, shell_source.start(), String::kNormalString, |
808 shell_source.length()); | 805 shell_source.length()); |
809 Handle<String> name = | 806 Handle<String> name = |
810 String::NewFromUtf8(isolate, shell_source_name.start(), | 807 String::NewFromUtf8(isolate, shell_source_name.start(), |
811 String::kNormalString, shell_source_name.length()); | 808 String::kNormalString, shell_source_name.length()); |
812 ScriptOrigin origin(name); | 809 Handle<Script> script = Script::Compile(source, name); |
813 Handle<Script> script = Script::Compile(source, &origin); | |
814 script->Run(); | 810 script->Run(); |
815 // Mark the d8 shell script as native to avoid it showing up as normal source | 811 // Mark the d8 shell script as native to avoid it showing up as normal source |
816 // in the debugger. | 812 // in the debugger. |
817 i::Handle<i::Object> compiled_script = Utils::OpenHandle(*script); | 813 i::Handle<i::Object> compiled_script = Utils::OpenHandle(*script); |
818 i::Handle<i::Script> script_object = compiled_script->IsJSFunction() | 814 i::Handle<i::Script> script_object = compiled_script->IsJSFunction() |
819 ? i::Handle<i::Script>(i::Script::cast( | 815 ? i::Handle<i::Script>(i::Script::cast( |
820 i::JSFunction::cast(*compiled_script)->shared()->script())) | 816 i::JSFunction::cast(*compiled_script)->shared()->script())) |
821 : i::Handle<i::Script>(i::Script::cast( | 817 : i::Handle<i::Script>(i::Script::cast( |
822 i::SharedFunctionInfo::cast(*compiled_script)->script())); | 818 i::SharedFunctionInfo::cast(*compiled_script)->script())); |
823 script_object->set_type(i::Smi::FromInt(i::Script::TYPE_NATIVE)); | 819 script_object->set_type(i::Smi::FromInt(i::Script::TYPE_NATIVE)); |
(...skipping 943 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1767 } | 1763 } |
1768 | 1764 |
1769 } // namespace v8 | 1765 } // namespace v8 |
1770 | 1766 |
1771 | 1767 |
1772 #ifndef GOOGLE3 | 1768 #ifndef GOOGLE3 |
1773 int main(int argc, char* argv[]) { | 1769 int main(int argc, char* argv[]) { |
1774 return v8::Shell::Main(argc, argv); | 1770 return v8::Shell::Main(argc, argv); |
1775 } | 1771 } |
1776 #endif | 1772 #endif |
OLD | NEW |