Commit e9acaed6 authored by Maya Lekova's avatar Maya Lekova Committed by V8 LUCI CQ

[turbofan] Fix correctness issue in startsWith

This CL fixes a previous change in String.prototype.startsWith which
didn't throw an exception (in the optimized version) when `undefined`
was passed as a receiver and the search string was the empty string.

Bug: chromium:1230260
Change-Id: I835bd409b09b78bf7235c77596f62b588c95611d
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3040841
Commit-Queue: Maya Lekova <mslekova@chromium.org>
Commit-Queue: Georg Neis <neis@chromium.org>
Auto-Submit: Maya Lekova <mslekova@chromium.org>
Reviewed-by: 's avatarGeorg Neis <neis@chromium.org>
Cr-Commit-Position: refs/heads/master@{#75818}
parent 334b94e1
......@@ -6424,19 +6424,18 @@ Reduction JSCallReducer::ReduceStringPrototypeStartsWith(Node* node) {
if (target_ref.IsString()) {
StringRef str = target_ref.AsString();
if (str.length().has_value()) {
receiver = effect = graph()->NewNode(
simplified()->CheckString(p.feedback()), receiver, effect, control);
position = effect = graph()->NewNode(
simplified()->CheckSmi(p.feedback()), position, effect, control);
if (str.length().value() == 0) {
Node* value = jsgraph()->TrueConstant();
ReplaceWithValue(node, value, effect, control);
return Replace(value);
}
if (str.length().value() == 1) {
receiver = effect =
graph()->NewNode(simplified()->CheckString(p.feedback()),
receiver, effect, control);
position = effect = graph()->NewNode(
simplified()->CheckSmi(p.feedback()), position, effect, control);
Node* string_length =
graph()->NewNode(simplified()->StringLength(), receiver);
Node* unsigned_position = graph()->NewNode(
......
// Copyright 2021 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
// Flags: --allow-natives-syntax --no-lazy-feedback-allocation
function foo() {
String.prototype.startsWith.call(undefined, "");
}
%PrepareFunctionForOptimization(foo);
assertThrows(foo);
%OptimizeFunctionOnNextCall(foo);
assertThrows(foo);
function bar() {
"bla".startsWith("", Symbol(''));
}
%PrepareFunctionForOptimization(bar);
assertThrows(bar);
%OptimizeFunctionOnNextCall(bar);
assertThrows(bar);
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