Show user script source line that caused exception intead of a line in a native script. When an error is reported as one happened in a native script it's hard to track the original cause. See chromium issue: http://crbug.com/25305
Review URL: http://codereview.chromium.org/555170 git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@3753 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
This commit is contained in:
parent
f03e42b133
commit
4963f13f22
@ -176,7 +176,7 @@ StackFrame* StackFrameIterator::SingletonFor(StackFrame::Type type) {
|
||||
|
||||
|
||||
StackTraceFrameIterator::StackTraceFrameIterator() {
|
||||
if (!done() && !frame()->function()->IsJSFunction()) Advance();
|
||||
if (!done() && !IsValidFrame()) Advance();
|
||||
}
|
||||
|
||||
|
||||
@ -184,10 +184,18 @@ void StackTraceFrameIterator::Advance() {
|
||||
while (true) {
|
||||
JavaScriptFrameIterator::Advance();
|
||||
if (done()) return;
|
||||
if (frame()->function()->IsJSFunction()) return;
|
||||
if (IsValidFrame()) return;
|
||||
}
|
||||
}
|
||||
|
||||
bool StackTraceFrameIterator::IsValidFrame() {
|
||||
if (!frame()->function()->IsJSFunction()) return false;
|
||||
Object* script = JSFunction::cast(frame()->function())->shared()->script();
|
||||
// Don't show functions from native scripts to user.
|
||||
return (script->IsScript() &&
|
||||
Script::TYPE_NATIVE != Script::cast(script)->type()->value());
|
||||
}
|
||||
|
||||
|
||||
// -------------------------------------------------------------------------
|
||||
|
||||
|
@ -589,6 +589,9 @@ class StackTraceFrameIterator: public JavaScriptFrameIterator {
|
||||
public:
|
||||
StackTraceFrameIterator();
|
||||
void Advance();
|
||||
|
||||
private:
|
||||
bool IsValidFrame();
|
||||
};
|
||||
|
||||
|
||||
|
@ -3602,6 +3602,37 @@ TEST(ApiUncaughtException) {
|
||||
v8::V8::RemoveMessageListeners(ApiUncaughtExceptionTestListener);
|
||||
}
|
||||
|
||||
static const char* script_resource_name = "ExceptionInNativeScript.js";
|
||||
static void ExceptionInNativeScriptTestListener(v8::Handle<v8::Message> message,
|
||||
v8::Handle<Value>) {
|
||||
v8::Handle<v8::Value> name_val = message->GetScriptResourceName();
|
||||
CHECK(!name_val.IsEmpty() && name_val->IsString());
|
||||
v8::String::AsciiValue name(message->GetScriptResourceName());
|
||||
CHECK_EQ(script_resource_name, *name);
|
||||
CHECK_EQ(3, message->GetLineNumber());
|
||||
v8::String::AsciiValue source_line(message->GetSourceLine());
|
||||
CHECK_EQ(" new o.foo();", *source_line);
|
||||
}
|
||||
|
||||
TEST(ExceptionInNativeScript) {
|
||||
v8::HandleScope scope;
|
||||
LocalContext env;
|
||||
v8::V8::AddMessageListener(ExceptionInNativeScriptTestListener);
|
||||
|
||||
Local<v8::FunctionTemplate> fun = v8::FunctionTemplate::New(TroubleCallback);
|
||||
v8::Local<v8::Object> global = env->Global();
|
||||
global->Set(v8_str("trouble"), fun->GetFunction());
|
||||
|
||||
Script::Compile(v8_str("function trouble() {\n"
|
||||
" var o = {};\n"
|
||||
" new o.foo();\n"
|
||||
"};"), v8::String::New(script_resource_name))->Run();
|
||||
Local<Value> trouble = global->Get(v8_str("trouble"));
|
||||
CHECK(trouble->IsFunction());
|
||||
Function::Cast(*trouble)->Call(global, 0, NULL);
|
||||
v8::V8::RemoveMessageListeners(ExceptionInNativeScriptTestListener);
|
||||
}
|
||||
|
||||
|
||||
TEST(CompilationErrorUsingTryCatchHandler) {
|
||||
v8::HandleScope scope;
|
||||
|
Loading…
Reference in New Issue
Block a user