| Index: src/d8.cc
|
| diff --git a/src/d8.cc b/src/d8.cc
|
| index 120496eccce5921f887eafadf6ebd71e59867edc..5a162929c247b59e1b1ee65072490c9afd8c3dad 100644
|
| --- a/src/d8.cc
|
| +++ b/src/d8.cc
|
| @@ -176,8 +176,8 @@ bool Shell::ExecuteString(Handle<String> source,
|
| // If all went well and the result wasn't undefined then print
|
| // the returned value.
|
| v8::String::Utf8Value str(result);
|
| - const char* cstr = ToCString(str);
|
| - printf("%s\n", cstr);
|
| + fwrite(*str, sizeof(**str), str.length(), stdout);
|
| + printf("\n");
|
| }
|
| return true;
|
| }
|
| @@ -210,6 +210,18 @@ Handle<Value> Shell::Write(const Arguments& args) {
|
| }
|
|
|
|
|
| +Handle<Value> Shell::EnableProfiler(const Arguments& args) {
|
| + V8::ResumeProfiler();
|
| + return Undefined();
|
| +}
|
| +
|
| +
|
| +Handle<Value> Shell::DisableProfiler(const Arguments& args) {
|
| + V8::PauseProfiler();
|
| + return Undefined();
|
| +}
|
| +
|
| +
|
| Handle<Value> Shell::Read(const Arguments& args) {
|
| String::Utf8Value file(args[0]);
|
| if (*file == NULL) {
|
| @@ -656,6 +668,10 @@ Handle<ObjectTemplate> Shell::CreateGlobalTemplate() {
|
| global_template->Set(String::New("load"), FunctionTemplate::New(Load));
|
| global_template->Set(String::New("quit"), FunctionTemplate::New(Quit));
|
| global_template->Set(String::New("version"), FunctionTemplate::New(Version));
|
| + global_template->Set(String::New("enableProfiler"),
|
| + FunctionTemplate::New(EnableProfiler));
|
| + global_template->Set(String::New("disableProfiler"),
|
| + FunctionTemplate::New(DisableProfiler));
|
|
|
| // Bind the handlers for external arrays.
|
| global_template->Set(String::New("Int8Array"),
|
| @@ -678,12 +694,12 @@ Handle<ObjectTemplate> Shell::CreateGlobalTemplate() {
|
| FunctionTemplate::New(PixelArray));
|
|
|
| #ifdef LIVE_OBJECT_LIST
|
| - global_template->Set(String::New("lol_is_enabled"), Boolean::New(true));
|
| + global_template->Set(String::New("lol_is_enabled"), True());
|
| #else
|
| - global_template->Set(String::New("lol_is_enabled"), Boolean::New(false));
|
| + global_template->Set(String::New("lol_is_enabled"), False());
|
| #endif
|
|
|
| -#ifndef V8_SHARED
|
| +#if !defined(V8_SHARED) && !defined(_WIN32) && !defined(_WIN64)
|
| Handle<ObjectTemplate> os_templ = ObjectTemplate::New();
|
| AddOSMethods(os_templ);
|
| global_template->Set(String::New("os"), os_templ);
|
| @@ -864,7 +880,7 @@ Handle<String> Shell::ReadFile(const char* name) {
|
| void Shell::RunShell() {
|
| Locker locker;
|
| Context::Scope context_scope(evaluation_context_);
|
| - HandleScope handle_scope;
|
| + HandleScope outer_scope;
|
| Handle<String> name = String::New("(d8)");
|
| #ifndef V8_SHARED
|
| LineEditor* editor = LineEditor::Get();
|
| @@ -877,6 +893,7 @@ void Shell::RunShell() {
|
| i::SmartPointer<char> input = editor->Prompt(Shell::kPrompt);
|
| if (input.is_empty()) break;
|
| editor->AddHistory(*input);
|
| + HandleScope inner_scope;
|
| ExecuteString(String::New(*input), name, true, true);
|
| }
|
| editor->Close();
|
| @@ -887,6 +904,7 @@ void Shell::RunShell() {
|
| char buffer[kBufferSize];
|
| printf("%s", Shell::kPrompt);
|
| if (fgets(buffer, kBufferSize, stdin) == NULL) break;
|
| + HandleScope inner_scope;
|
| ExecuteString(String::New(buffer), name, true, true);
|
| }
|
| #endif // V8_SHARED
|
|
|