mirror of
https://github.com/SerenityOS/serenity
synced 2024-10-15 12:23:15 +00:00
LibJS: Optimize insertion order in the Exception constructor
By inserting the stack frames in the correct order we can improve the runtime for the test-js test suite by about 20%.
This commit is contained in:
parent
bc8d16ad28
commit
8b449214af
|
@ -18,18 +18,18 @@ Exception::Exception(Value value)
|
||||||
{
|
{
|
||||||
auto& vm = this->vm();
|
auto& vm = this->vm();
|
||||||
m_traceback.ensure_capacity(vm.call_stack().size());
|
m_traceback.ensure_capacity(vm.call_stack().size());
|
||||||
for (auto* call_frame : vm.call_stack()) {
|
for (ssize_t i = vm.call_stack().size() - 1; i >= 0; i--) {
|
||||||
|
auto* call_frame = vm.call_stack()[i];
|
||||||
auto function_name = call_frame->function_name;
|
auto function_name = call_frame->function_name;
|
||||||
if (function_name.is_empty())
|
if (function_name.is_empty())
|
||||||
function_name = "<anonymous>";
|
function_name = "<anonymous>";
|
||||||
m_traceback.prepend({
|
m_traceback.empend(
|
||||||
.function_name = move(function_name),
|
move(function_name),
|
||||||
// We might not have an AST node associated with the call frame, e.g. in promise
|
// We might not have an AST node associated with the call frame, e.g. in promise
|
||||||
// reaction jobs (which aren't called anywhere from the source code).
|
// reaction jobs (which aren't called anywhere from the source code).
|
||||||
// They're not going to generate any _unhandled_ exceptions though, so a meaningless
|
// They're not going to generate any _unhandled_ exceptions though, so a meaningless
|
||||||
// source range is fine.
|
// source range is fine.
|
||||||
.source_range = call_frame->current_node ? call_frame->current_node->source_range() : SourceRange {},
|
call_frame->current_node ? call_frame->current_node->source_range() : SourceRange {});
|
||||||
});
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue