Commit ff2993bb authored by Clemens Backes's avatar Clemens Backes Committed by Commit Bot

[inspector][test] Exit properly on internal errors

Calling {Exit} does not stop execution in the current thread (or
process), it just tells the two task runners to stop. Hence following
code would still be executed.
This CL replaces the calls to {Exit} to {FATAL} for internal errors
where we want to stop immediately.

R=szuend@chromium.org

Bug: chromium:1142437
Change-Id: I70c1c39da28a3cd040214d46eddf61f05a12bce7
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2519568Reviewed-by: 's avatarSimon Zünd <szuend@chromium.org>
Commit-Queue: Clemens Backes <clemensb@chromium.org>
Cr-Commit-Position: refs/heads/master@{#70984}
parent 77a77f05
...@@ -49,12 +49,6 @@ void Terminate() { ...@@ -49,12 +49,6 @@ void Terminate() {
task_runners.swap(empty); task_runners.swap(empty);
} }
void Exit() {
fflush(stdout);
fflush(stderr);
Terminate();
}
class UtilsExtension : public IsolateData::SetupGlobalTask { class UtilsExtension : public IsolateData::SetupGlobalTask {
public: public:
~UtilsExtension() override = default; ~UtilsExtension() override = default;
...@@ -151,20 +145,22 @@ class UtilsExtension : public IsolateData::SetupGlobalTask { ...@@ -151,20 +145,22 @@ class UtilsExtension : public IsolateData::SetupGlobalTask {
int n = int n =
static_cast<int>(fwrite(*str, sizeof(**str), str.length(), stdout)); static_cast<int>(fwrite(*str, sizeof(**str), str.length(), stdout));
if (n != str.length()) { if (n != str.length()) {
printf("Error in fwrite\n"); FATAL("Error in fwrite\n");
Quit(args);
} }
} }
printf("\n"); printf("\n");
fflush(stdout); fflush(stdout);
} }
static void Quit(const v8::FunctionCallbackInfo<v8::Value>& args) { Exit(); } static void Quit(const v8::FunctionCallbackInfo<v8::Value>& args) {
fflush(stdout);
fflush(stderr);
Terminate();
}
static void Setlocale(const v8::FunctionCallbackInfo<v8::Value>& args) { static void Setlocale(const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 1 || !args[0]->IsString()) { if (args.Length() != 1 || !args[0]->IsString()) {
fprintf(stderr, "Internal error: setlocale get one string argument."); FATAL("Internal error: setlocale get one string argument.");
Exit();
} }
v8::String::Utf8Value str(args.GetIsolate(), args[1]); v8::String::Utf8Value str(args.GetIsolate(), args[1]);
...@@ -186,8 +182,7 @@ class UtilsExtension : public IsolateData::SetupGlobalTask { ...@@ -186,8 +182,7 @@ class UtilsExtension : public IsolateData::SetupGlobalTask {
static void Read(const v8::FunctionCallbackInfo<v8::Value>& args) { static void Read(const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 1 || !args[0]->IsString()) { if (args.Length() != 1 || !args[0]->IsString()) {
fprintf(stderr, "Internal error: read gets one string argument."); FATAL("Internal error: read gets one string argument.");
Exit();
} }
std::string chars; std::string chars;
v8::Isolate* isolate = args.GetIsolate(); v8::Isolate* isolate = args.GetIsolate();
...@@ -198,8 +193,7 @@ class UtilsExtension : public IsolateData::SetupGlobalTask { ...@@ -198,8 +193,7 @@ class UtilsExtension : public IsolateData::SetupGlobalTask {
static void Load(const v8::FunctionCallbackInfo<v8::Value>& args) { static void Load(const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 1 || !args[0]->IsString()) { if (args.Length() != 1 || !args[0]->IsString()) {
fprintf(stderr, "Internal error: load gets one string argument."); FATAL("Internal error: load gets one string argument.");
Exit();
} }
std::string chars; std::string chars;
v8::Isolate* isolate = args.GetIsolate(); v8::Isolate* isolate = args.GetIsolate();
...@@ -216,11 +210,9 @@ class UtilsExtension : public IsolateData::SetupGlobalTask { ...@@ -216,11 +210,9 @@ class UtilsExtension : public IsolateData::SetupGlobalTask {
if (args.Length() != 6 || !args[0]->IsInt32() || !args[1]->IsString() || if (args.Length() != 6 || !args[0]->IsInt32() || !args[1]->IsString() ||
!args[2]->IsString() || !args[3]->IsInt32() || !args[4]->IsInt32() || !args[2]->IsString() || !args[3]->IsInt32() || !args[4]->IsInt32() ||
!args[5]->IsBoolean()) { !args[5]->IsBoolean()) {
fprintf(stderr, FATAL(
"Internal error: compileAndRunWithOrigin(context_group_id, " "Internal error: compileAndRunWithOrigin(context_group_id, source, "
"source, name, line, " "name, line, column, is_module).");
"column, is_module).");
Exit();
} }
backend_runner_->Append(new ExecuteStringTask( backend_runner_->Append(new ExecuteStringTask(
...@@ -233,8 +225,7 @@ class UtilsExtension : public IsolateData::SetupGlobalTask { ...@@ -233,8 +225,7 @@ class UtilsExtension : public IsolateData::SetupGlobalTask {
static void SetCurrentTimeMSForTest( static void SetCurrentTimeMSForTest(
const v8::FunctionCallbackInfo<v8::Value>& args) { const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 1 || !args[0]->IsNumber()) { if (args.Length() != 1 || !args[0]->IsNumber()) {
fprintf(stderr, "Internal error: setCurrentTimeMSForTest(time)."); FATAL("Internal error: setCurrentTimeMSForTest(time).");
Exit();
} }
backend_runner_->data()->SetCurrentTimeMS( backend_runner_->data()->SetCurrentTimeMS(
args[0].As<v8::Number>()->Value()); args[0].As<v8::Number>()->Value());
...@@ -243,8 +234,7 @@ class UtilsExtension : public IsolateData::SetupGlobalTask { ...@@ -243,8 +234,7 @@ class UtilsExtension : public IsolateData::SetupGlobalTask {
static void SetMemoryInfoForTest( static void SetMemoryInfoForTest(
const v8::FunctionCallbackInfo<v8::Value>& args) { const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 1) { if (args.Length() != 1) {
fprintf(stderr, "Internal error: setMemoryInfoForTest(value)."); FATAL("Internal error: setMemoryInfoForTest(value).");
Exit();
} }
backend_runner_->data()->SetMemoryInfo(args[0]); backend_runner_->data()->SetMemoryInfo(args[0]);
} }
...@@ -253,10 +243,9 @@ class UtilsExtension : public IsolateData::SetupGlobalTask { ...@@ -253,10 +243,9 @@ class UtilsExtension : public IsolateData::SetupGlobalTask {
const v8::FunctionCallbackInfo<v8::Value>& args) { const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 3 || !args[0]->IsInt32() || !args[1]->IsString() || if (args.Length() != 3 || !args[0]->IsInt32() || !args[1]->IsString() ||
!args[2]->IsString()) { !args[2]->IsString()) {
fprintf(stderr, FATAL(
"Internal error: schedulePauseOnNextStatement(context_group_id, " "Internal error: schedulePauseOnNextStatement(context_group_id, "
"'reason', 'details')."); "'reason', 'details').");
Exit();
} }
std::vector<uint16_t> reason = std::vector<uint16_t> reason =
ToVector(args.GetIsolate(), args[1].As<v8::String>()); ToVector(args.GetIsolate(), args[1].As<v8::String>());
...@@ -275,9 +264,7 @@ class UtilsExtension : public IsolateData::SetupGlobalTask { ...@@ -275,9 +264,7 @@ class UtilsExtension : public IsolateData::SetupGlobalTask {
static void CancelPauseOnNextStatement( static void CancelPauseOnNextStatement(
const v8::FunctionCallbackInfo<v8::Value>& args) { const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 1 || !args[0]->IsInt32()) { if (args.Length() != 1 || !args[0]->IsInt32()) {
fprintf(stderr, FATAL("Internal error: cancelPauseOnNextStatement(context_group_id).");
"Internal error: cancelPauseOnNextStatement(context_group_id).");
Exit();
} }
int context_group_id = args[0].As<v8::Int32>()->Value(); int context_group_id = args[0].As<v8::Int32>()->Value();
RunSyncTask(backend_runner_, [&context_group_id](IsolateData* data) { RunSyncTask(backend_runner_, [&context_group_id](IsolateData* data) {
...@@ -288,8 +275,7 @@ class UtilsExtension : public IsolateData::SetupGlobalTask { ...@@ -288,8 +275,7 @@ class UtilsExtension : public IsolateData::SetupGlobalTask {
static void SetLogConsoleApiMessageCalls( static void SetLogConsoleApiMessageCalls(
const v8::FunctionCallbackInfo<v8::Value>& args) { const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 1 || !args[0]->IsBoolean()) { if (args.Length() != 1 || !args[0]->IsBoolean()) {
fprintf(stderr, "Internal error: setLogConsoleApiMessageCalls(bool)."); FATAL("Internal error: setLogConsoleApiMessageCalls(bool).");
Exit();
} }
backend_runner_->data()->SetLogConsoleApiMessageCalls( backend_runner_->data()->SetLogConsoleApiMessageCalls(
args[0].As<v8::Boolean>()->Value()); args[0].As<v8::Boolean>()->Value());
...@@ -298,9 +284,7 @@ class UtilsExtension : public IsolateData::SetupGlobalTask { ...@@ -298,9 +284,7 @@ class UtilsExtension : public IsolateData::SetupGlobalTask {
static void SetLogMaxAsyncCallStackDepthChanged( static void SetLogMaxAsyncCallStackDepthChanged(
const v8::FunctionCallbackInfo<v8::Value>& args) { const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 1 || !args[0]->IsBoolean()) { if (args.Length() != 1 || !args[0]->IsBoolean()) {
fprintf(stderr, FATAL("Internal error: setLogMaxAsyncCallStackDepthChanged(bool).");
"Internal error: setLogMaxAsyncCallStackDepthChanged(bool).");
Exit();
} }
backend_runner_->data()->SetLogMaxAsyncCallStackDepthChanged( backend_runner_->data()->SetLogMaxAsyncCallStackDepthChanged(
args[0].As<v8::Boolean>()->Value()); args[0].As<v8::Boolean>()->Value());
...@@ -309,8 +293,7 @@ class UtilsExtension : public IsolateData::SetupGlobalTask { ...@@ -309,8 +293,7 @@ class UtilsExtension : public IsolateData::SetupGlobalTask {
static void SetAdditionalConsoleApi( static void SetAdditionalConsoleApi(
const v8::FunctionCallbackInfo<v8::Value>& args) { const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 1 || !args[0]->IsString()) { if (args.Length() != 1 || !args[0]->IsString()) {
fprintf(stderr, "Internal error: SetAdditionalConsoleApi(string)."); FATAL("Internal error: SetAdditionalConsoleApi(string).");
Exit();
} }
std::vector<uint16_t> script = std::vector<uint16_t> script =
ToVector(args.GetIsolate(), args[0].As<v8::String>()); ToVector(args.GetIsolate(), args[0].As<v8::String>());
...@@ -323,8 +306,7 @@ class UtilsExtension : public IsolateData::SetupGlobalTask { ...@@ -323,8 +306,7 @@ class UtilsExtension : public IsolateData::SetupGlobalTask {
static void CreateContextGroup( static void CreateContextGroup(
const v8::FunctionCallbackInfo<v8::Value>& args) { const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 0) { if (args.Length() != 0) {
fprintf(stderr, "Internal error: createContextGroup()."); FATAL("Internal error: createContextGroup().");
Exit();
} }
int context_group_id = 0; int context_group_id = 0;
RunSyncTask(backend_runner_, [&context_group_id](IsolateData* data) { RunSyncTask(backend_runner_, [&context_group_id](IsolateData* data) {
...@@ -336,8 +318,7 @@ class UtilsExtension : public IsolateData::SetupGlobalTask { ...@@ -336,8 +318,7 @@ class UtilsExtension : public IsolateData::SetupGlobalTask {
static void CreateContext(const v8::FunctionCallbackInfo<v8::Value>& args) { static void CreateContext(const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 2) { if (args.Length() != 2) {
fprintf(stderr, "Internal error: createContext(context, name)."); FATAL("Internal error: createContext(context, name).");
Exit();
} }
int context_group_id = args[0].As<v8::Int32>()->Value(); int context_group_id = args[0].As<v8::Int32>()->Value();
std::vector<uint16_t> name = std::vector<uint16_t> name =
...@@ -352,8 +333,7 @@ class UtilsExtension : public IsolateData::SetupGlobalTask { ...@@ -352,8 +333,7 @@ class UtilsExtension : public IsolateData::SetupGlobalTask {
static void ResetContextGroup( static void ResetContextGroup(
const v8::FunctionCallbackInfo<v8::Value>& args) { const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 1 || !args[0]->IsInt32()) { if (args.Length() != 1 || !args[0]->IsInt32()) {
fprintf(stderr, "Internal error: resetContextGroup(context_group_id)."); FATAL("Internal error: resetContextGroup(context_group_id).");
Exit();
} }
int context_group_id = args[0].As<v8::Int32>()->Value(); int context_group_id = args[0].As<v8::Int32>()->Value();
RunSyncTask(backend_runner_, [&context_group_id](IsolateData* data) { RunSyncTask(backend_runner_, [&context_group_id](IsolateData* data) {
...@@ -364,10 +344,9 @@ class UtilsExtension : public IsolateData::SetupGlobalTask { ...@@ -364,10 +344,9 @@ class UtilsExtension : public IsolateData::SetupGlobalTask {
static void ConnectSession(const v8::FunctionCallbackInfo<v8::Value>& args) { static void ConnectSession(const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 3 || !args[0]->IsInt32() || !args[1]->IsString() || if (args.Length() != 3 || !args[0]->IsInt32() || !args[1]->IsString() ||
!args[2]->IsFunction()) { !args[2]->IsFunction()) {
fprintf(stderr, FATAL(
"Internal error: connectionSession(context_group_id, state, " "Internal error: connectionSession(context_group_id, state, "
"dispatch)."); "dispatch).");
Exit();
} }
v8::Local<v8::Context> context = args.GetIsolate()->GetCurrentContext(); v8::Local<v8::Context> context = args.GetIsolate()->GetCurrentContext();
FrontendChannelImpl* channel = new FrontendChannelImpl( FrontendChannelImpl* channel = new FrontendChannelImpl(
...@@ -394,8 +373,7 @@ class UtilsExtension : public IsolateData::SetupGlobalTask { ...@@ -394,8 +373,7 @@ class UtilsExtension : public IsolateData::SetupGlobalTask {
static void DisconnectSession( static void DisconnectSession(
const v8::FunctionCallbackInfo<v8::Value>& args) { const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 1 || !args[0]->IsInt32()) { if (args.Length() != 1 || !args[0]->IsInt32()) {
fprintf(stderr, "Internal error: disconnectionSession(session_id)."); FATAL("Internal error: disconnectionSession(session_id).");
Exit();
} }
int session_id = args[0].As<v8::Int32>()->Value(); int session_id = args[0].As<v8::Int32>()->Value();
std::vector<uint8_t> state; std::vector<uint8_t> state;
...@@ -409,9 +387,7 @@ class UtilsExtension : public IsolateData::SetupGlobalTask { ...@@ -409,9 +387,7 @@ class UtilsExtension : public IsolateData::SetupGlobalTask {
static void SendMessageToBackend( static void SendMessageToBackend(
const v8::FunctionCallbackInfo<v8::Value>& args) { const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 2 || !args[0]->IsInt32() || !args[1]->IsString()) { if (args.Length() != 2 || !args[0]->IsInt32() || !args[1]->IsString()) {
fprintf(stderr, FATAL("Internal error: sendMessageToBackend(session_id, message).");
"Internal error: sendMessageToBackend(session_id, message).");
Exit();
} }
backend_runner_->Append(new SendMessageToBackendTask( backend_runner_->Append(new SendMessageToBackendTask(
args[0].As<v8::Int32>()->Value(), args[0].As<v8::Int32>()->Value(),
...@@ -524,9 +500,7 @@ class InspectorExtension : public IsolateData::SetupGlobalTask { ...@@ -524,9 +500,7 @@ class InspectorExtension : public IsolateData::SetupGlobalTask {
static void AddInspectedObject( static void AddInspectedObject(
const v8::FunctionCallbackInfo<v8::Value>& args) { const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 2 || !args[0]->IsInt32()) { if (args.Length() != 2 || !args[0]->IsInt32()) {
fprintf(stderr, FATAL("Internal error: addInspectedObject(session_id, object).");
"Internal error: addInspectedObject(session_id, object).");
Exit();
} }
v8::Local<v8::Context> context = args.GetIsolate()->GetCurrentContext(); v8::Local<v8::Context> context = args.GetIsolate()->GetCurrentContext();
IsolateData* data = IsolateData::FromContext(context); IsolateData* data = IsolateData::FromContext(context);
...@@ -536,8 +510,7 @@ class InspectorExtension : public IsolateData::SetupGlobalTask { ...@@ -536,8 +510,7 @@ class InspectorExtension : public IsolateData::SetupGlobalTask {
static void SetMaxAsyncTaskStacks( static void SetMaxAsyncTaskStacks(
const v8::FunctionCallbackInfo<v8::Value>& args) { const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 1 || !args[0]->IsInt32()) { if (args.Length() != 1 || !args[0]->IsInt32()) {
fprintf(stderr, "Internal error: setMaxAsyncTaskStacks(max)."); FATAL("Internal error: setMaxAsyncTaskStacks(max).");
Exit();
} }
IsolateData::FromContext(args.GetIsolate()->GetCurrentContext()) IsolateData::FromContext(args.GetIsolate()->GetCurrentContext())
->SetMaxAsyncTaskStacksForTest(args[0].As<v8::Int32>()->Value()); ->SetMaxAsyncTaskStacksForTest(args[0].As<v8::Int32>()->Value());
...@@ -546,8 +519,7 @@ class InspectorExtension : public IsolateData::SetupGlobalTask { ...@@ -546,8 +519,7 @@ class InspectorExtension : public IsolateData::SetupGlobalTask {
static void DumpAsyncTaskStacksStateForTest( static void DumpAsyncTaskStacksStateForTest(
const v8::FunctionCallbackInfo<v8::Value>& args) { const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 0) { if (args.Length() != 0) {
fprintf(stderr, "Internal error: dumpAsyncTaskStacksStateForTest()."); FATAL("Internal error: dumpAsyncTaskStacksStateForTest().");
Exit();
} }
IsolateData::FromContext(args.GetIsolate()->GetCurrentContext()) IsolateData::FromContext(args.GetIsolate()->GetCurrentContext())
->DumpAsyncTaskStacksStateForTest(); ->DumpAsyncTaskStacksStateForTest();
...@@ -555,8 +527,7 @@ class InspectorExtension : public IsolateData::SetupGlobalTask { ...@@ -555,8 +527,7 @@ class InspectorExtension : public IsolateData::SetupGlobalTask {
static void BreakProgram(const v8::FunctionCallbackInfo<v8::Value>& args) { static void BreakProgram(const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 2 || !args[0]->IsString() || !args[1]->IsString()) { if (args.Length() != 2 || !args[0]->IsString() || !args[1]->IsString()) {
fprintf(stderr, "Internal error: breakProgram('reason', 'details')."); FATAL("Internal error: breakProgram('reason', 'details').");
Exit();
} }
v8::Local<v8::Context> context = args.GetIsolate()->GetCurrentContext(); v8::Local<v8::Context> context = args.GetIsolate()->GetCurrentContext();
IsolateData* data = IsolateData::FromContext(context); IsolateData* data = IsolateData::FromContext(context);
...@@ -573,8 +544,7 @@ class InspectorExtension : public IsolateData::SetupGlobalTask { ...@@ -573,8 +544,7 @@ class InspectorExtension : public IsolateData::SetupGlobalTask {
static void CreateObjectWithStrictCheck( static void CreateObjectWithStrictCheck(
const v8::FunctionCallbackInfo<v8::Value>& args) { const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 0) { if (args.Length() != 0) {
fprintf(stderr, "Internal error: createObjectWithStrictCheck()."); FATAL("Internal error: createObjectWithStrictCheck().");
Exit();
} }
v8::Local<v8::ObjectTemplate> templ = v8::Local<v8::ObjectTemplate> templ =
v8::ObjectTemplate::New(args.GetIsolate()); v8::ObjectTemplate::New(args.GetIsolate());
...@@ -588,9 +558,7 @@ class InspectorExtension : public IsolateData::SetupGlobalTask { ...@@ -588,9 +558,7 @@ class InspectorExtension : public IsolateData::SetupGlobalTask {
const v8::FunctionCallbackInfo<v8::Value>& args) { const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 3 || !args[0]->IsFunction() || !args[1]->IsString() || if (args.Length() != 3 || !args[0]->IsFunction() || !args[1]->IsString() ||
!args[2]->IsString()) { !args[2]->IsString()) {
fprintf(stderr, FATAL("Internal error: callWithScheduledBreak('reason', 'details').");
"Internal error: callWithScheduledBreak('reason', 'details').");
Exit();
} }
std::vector<uint16_t> reason = std::vector<uint16_t> reason =
ToVector(args.GetIsolate(), args[1].As<v8::String>()); ToVector(args.GetIsolate(), args[1].As<v8::String>());
...@@ -612,8 +580,7 @@ class InspectorExtension : public IsolateData::SetupGlobalTask { ...@@ -612,8 +580,7 @@ class InspectorExtension : public IsolateData::SetupGlobalTask {
static void AllowAccessorFormatting( static void AllowAccessorFormatting(
const v8::FunctionCallbackInfo<v8::Value>& args) { const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 1 || !args[0]->IsObject()) { if (args.Length() != 1 || !args[0]->IsObject()) {
fprintf(stderr, "Internal error: allowAccessorFormatting('object')."); FATAL("Internal error: allowAccessorFormatting('object').");
Exit();
} }
v8::Local<v8::Object> object = args[0].As<v8::Object>(); v8::Local<v8::Object> object = args[0].As<v8::Object>();
v8::Isolate* isolate = args.GetIsolate(); v8::Isolate* isolate = args.GetIsolate();
...@@ -628,8 +595,7 @@ class InspectorExtension : public IsolateData::SetupGlobalTask { ...@@ -628,8 +595,7 @@ class InspectorExtension : public IsolateData::SetupGlobalTask {
static void MarkObjectAsNotInspectable( static void MarkObjectAsNotInspectable(
const v8::FunctionCallbackInfo<v8::Value>& args) { const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 1 || !args[0]->IsObject()) { if (args.Length() != 1 || !args[0]->IsObject()) {
fprintf(stderr, "Internal error: markObjectAsNotInspectable(object)."); FATAL("Internal error: markObjectAsNotInspectable(object).");
Exit();
} }
v8::Local<v8::Object> object = args[0].As<v8::Object>(); v8::Local<v8::Object> object = args[0].As<v8::Object>();
v8::Isolate* isolate = args.GetIsolate(); v8::Isolate* isolate = args.GetIsolate();
...@@ -644,10 +610,9 @@ class InspectorExtension : public IsolateData::SetupGlobalTask { ...@@ -644,10 +610,9 @@ class InspectorExtension : public IsolateData::SetupGlobalTask {
static void CreateObjectWithAccessor( static void CreateObjectWithAccessor(
const v8::FunctionCallbackInfo<v8::Value>& args) { const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 2 || !args[0]->IsString() || !args[1]->IsBoolean()) { if (args.Length() != 2 || !args[0]->IsString() || !args[1]->IsBoolean()) {
fprintf(stderr, FATAL(
"Internal error: createObjectWithAccessor('accessor name', " "Internal error: createObjectWithAccessor('accessor name', "
"hasSetter)\n"); "hasSetter)\n");
Exit();
} }
v8::Isolate* isolate = args.GetIsolate(); v8::Isolate* isolate = args.GetIsolate();
v8::Local<v8::ObjectTemplate> templ = v8::ObjectTemplate::New(isolate); v8::Local<v8::ObjectTemplate> templ = v8::ObjectTemplate::New(isolate);
...@@ -677,9 +642,7 @@ class InspectorExtension : public IsolateData::SetupGlobalTask { ...@@ -677,9 +642,7 @@ class InspectorExtension : public IsolateData::SetupGlobalTask {
static void StoreCurrentStackTrace( static void StoreCurrentStackTrace(
const v8::FunctionCallbackInfo<v8::Value>& args) { const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 1 || !args[0]->IsString()) { if (args.Length() != 1 || !args[0]->IsString()) {
fprintf(stderr, FATAL("Internal error: storeCurrentStackTrace('description')\n");
"Internal error: storeCurrentStackTrace('description')\n");
Exit();
} }
v8::Isolate* isolate = args.GetIsolate(); v8::Isolate* isolate = args.GetIsolate();
v8::Local<v8::Context> context = isolate->GetCurrentContext(); v8::Local<v8::Context> context = isolate->GetCurrentContext();
...@@ -700,8 +663,7 @@ class InspectorExtension : public IsolateData::SetupGlobalTask { ...@@ -700,8 +663,7 @@ class InspectorExtension : public IsolateData::SetupGlobalTask {
static void ExternalAsyncTaskStarted( static void ExternalAsyncTaskStarted(
const v8::FunctionCallbackInfo<v8::Value>& args) { const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 1 || !args[0]->IsArrayBuffer()) { if (args.Length() != 1 || !args[0]->IsArrayBuffer()) {
fprintf(stderr, "Internal error: externalAsyncTaskStarted(id)\n"); FATAL("Internal error: externalAsyncTaskStarted(id)\n");
Exit();
} }
v8::Local<v8::Context> context = args.GetIsolate()->GetCurrentContext(); v8::Local<v8::Context> context = args.GetIsolate()->GetCurrentContext();
IsolateData* data = IsolateData::FromContext(context); IsolateData* data = IsolateData::FromContext(context);
...@@ -714,8 +676,7 @@ class InspectorExtension : public IsolateData::SetupGlobalTask { ...@@ -714,8 +676,7 @@ class InspectorExtension : public IsolateData::SetupGlobalTask {
static void ExternalAsyncTaskFinished( static void ExternalAsyncTaskFinished(
const v8::FunctionCallbackInfo<v8::Value>& args) { const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 1 || !args[0]->IsArrayBuffer()) { if (args.Length() != 1 || !args[0]->IsArrayBuffer()) {
fprintf(stderr, "Internal error: externalAsyncTaskFinished(id)\n"); FATAL("Internal error: externalAsyncTaskFinished(id)\n");
Exit();
} }
v8::Local<v8::Context> context = args.GetIsolate()->GetCurrentContext(); v8::Local<v8::Context> context = args.GetIsolate()->GetCurrentContext();
IsolateData* data = IsolateData::FromContext(context); IsolateData* data = IsolateData::FromContext(context);
...@@ -729,10 +690,9 @@ class InspectorExtension : public IsolateData::SetupGlobalTask { ...@@ -729,10 +690,9 @@ class InspectorExtension : public IsolateData::SetupGlobalTask {
const v8::FunctionCallbackInfo<v8::Value>& args) { const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 3 || !args[0]->IsFunction() || !args[1]->IsString() || if (args.Length() != 3 || !args[0]->IsFunction() || !args[1]->IsString() ||
!args[2]->IsBoolean()) { !args[2]->IsBoolean()) {
fprintf(stderr, FATAL(
"Internal error: scheduleWithAsyncStack(function, " "Internal error: scheduleWithAsyncStack(function, 'task-name', "
"'task-name', with_empty_stack)."); "with_empty_stack).");
Exit();
} }
v8::Isolate* isolate = args.GetIsolate(); v8::Isolate* isolate = args.GetIsolate();
v8::Local<v8::Context> context = isolate->GetCurrentContext(); v8::Local<v8::Context> context = isolate->GetCurrentContext();
...@@ -754,9 +714,7 @@ class InspectorExtension : public IsolateData::SetupGlobalTask { ...@@ -754,9 +714,7 @@ class InspectorExtension : public IsolateData::SetupGlobalTask {
static void SetAllowCodeGenerationFromStrings( static void SetAllowCodeGenerationFromStrings(
const v8::FunctionCallbackInfo<v8::Value>& args) { const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 1 || !args[0]->IsBoolean()) { if (args.Length() != 1 || !args[0]->IsBoolean()) {
fprintf(stderr, FATAL("Internal error: setAllowCodeGenerationFromStrings(allow).");
"Internal error: setAllowCodeGenerationFromStrings(allow).");
Exit();
} }
args.GetIsolate()->GetCurrentContext()->AllowCodeGenerationFromStrings( args.GetIsolate()->GetCurrentContext()->AllowCodeGenerationFromStrings(
args[0].As<v8::Boolean>()->Value()); args[0].As<v8::Boolean>()->Value());
...@@ -765,8 +723,7 @@ class InspectorExtension : public IsolateData::SetupGlobalTask { ...@@ -765,8 +723,7 @@ class InspectorExtension : public IsolateData::SetupGlobalTask {
static void SetResourceNamePrefix( static void SetResourceNamePrefix(
const v8::FunctionCallbackInfo<v8::Value>& args) { const v8::FunctionCallbackInfo<v8::Value>& args) {
if (args.Length() != 1 || !args[0]->IsString()) { if (args.Length() != 1 || !args[0]->IsString()) {
fprintf(stderr, "Internal error: setResourceNamePrefix('prefix')."); FATAL("Internal error: setResourceNamePrefix('prefix').");
Exit();
} }
v8::Isolate* isolate = args.GetIsolate(); v8::Isolate* isolate = args.GetIsolate();
v8::Local<v8::Context> context = isolate->GetCurrentContext(); v8::Local<v8::Context> context = isolate->GetCurrentContext();
...@@ -831,9 +788,7 @@ int InspectorTestMain(int argc, char* argv[]) { ...@@ -831,9 +788,7 @@ int InspectorTestMain(int argc, char* argv[]) {
bool exists = false; bool exists = false;
std::string chars = ReadFile(argv[i], &exists, true); std::string chars = ReadFile(argv[i], &exists, true);
if (!exists) { if (!exists) {
fprintf(stderr, "Internal error: script file doesn't exists: %s\n", FATAL("Internal error: script file doesn't exists: %s\n", argv[i]);
argv[i]);
Exit();
} }
frontend_runner.Append( frontend_runner.Append(
new ExecuteStringTask(chars, frontend_context_group_id)); new ExecuteStringTask(chars, frontend_context_group_id));
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment