Commit 7d987b37 authored by yangguo@chromium.org's avatar yangguo@chromium.org

Allow GetScriptNameOrSourceURL to be called with exception pending.

R=jarin@chromium.org, ishell@chromium.org

Review URL: https://codereview.chromium.org/235943006

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@20705 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent c1a3ab6b
...@@ -399,10 +399,11 @@ Handle<Object> GetScriptNameOrSourceURL(Handle<Script> script) { ...@@ -399,10 +399,11 @@ Handle<Object> GetScriptNameOrSourceURL(Handle<Script> script) {
ASSERT(property->IsJSFunction()); ASSERT(property->IsJSFunction());
Handle<JSFunction> method = Handle<JSFunction>::cast(property); Handle<JSFunction> method = Handle<JSFunction>::cast(property);
Handle<Object> result; Handle<Object> result;
ASSIGN_RETURN_ON_EXCEPTION_VALUE( // Do not check against pending exception, since this function may be called
isolate, result, // when an exception has already been pending.
Execution::TryCall(method, script_wrapper, 0, NULL), if (!Execution::TryCall(method, script_wrapper, 0, NULL).ToHandle(&result)) {
isolate->factory()->undefined_value()); return isolate->factory()->undefined_value();
}
return result; return result;
} }
......
...@@ -22428,3 +22428,16 @@ TEST(Regress354123) { ...@@ -22428,3 +22428,16 @@ TEST(Regress354123) {
CompileRun("Object.getPrototypeOf(friend);"); CompileRun("Object.getPrototypeOf(friend);");
CHECK_EQ(2, named_access_count); CHECK_EQ(2, named_access_count);
} }
TEST(CaptureStackTraceForStackOverflow) {
v8::internal::FLAG_stack_size = 150;
LocalContext current;
v8::Isolate* isolate = current->GetIsolate();
v8::HandleScope scope(isolate);
V8::SetCaptureStackTraceForUncaughtExceptions(
true, 10, v8::StackTrace::kDetailed);
v8::TryCatch try_catch;
CompileRun("(function f(x) { f(x+1); })(0)");
CHECK(try_catch.HasCaught());
}
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