Commit 1776dffa authored by ishell@chromium.org's avatar ishell@chromium.org

Make `String.prototype.{starts,ends}With` throw when passing a regular expression

Contributed by Mathias Bynens <mathiasb@opera.com>.

TEST=mjsunit/harmony
BUG=v8:3070
LOG=Y
R=arv@chromium.org, ishell@chromium.org

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

Patch from Mathias Bynens <mathiasb@opera.com>.

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@18870 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 9e462504
// Copyright 2013 the V8 project authors. All rights reserved. // Copyright 2014 the V8 project authors. All rights reserved.
// Redistribution and use in source and binary forms, with or without // Redistribution and use in source and binary forms, with or without
// modification, are permitted provided that the following conditions are // modification, are permitted provided that the following conditions are
// met: // met:
...@@ -34,12 +34,9 @@ ...@@ -34,12 +34,9 @@
// ------------------------------------------------------------------- // -------------------------------------------------------------------
// ES6 draft 07-15-13, section 15.5.3.21 // ES6 draft 01-20-14, section 21.1.3.13
function StringRepeat(count) { function StringRepeat(count) {
if (IS_NULL_OR_UNDEFINED(this) && !IS_UNDETECTABLE(this)) { CHECK_OBJECT_COERCIBLE(this, "String.prototype.repeat");
throw MakeTypeError("called_on_null_or_undefined",
["String.prototype.repeat"]);
}
var s = TO_STRING_INLINE(this); var s = TO_STRING_INLINE(this);
var n = ToInteger(count); var n = ToInteger(count);
...@@ -56,14 +53,17 @@ function StringRepeat(count) { ...@@ -56,14 +53,17 @@ function StringRepeat(count) {
} }
// ES6 draft 07-15-13, section 15.5.3.22 // ES6 draft 01-20-14, section 21.1.3.18
function StringStartsWith(searchString /* position */) { // length == 1 function StringStartsWith(searchString /* position */) { // length == 1
if (IS_NULL_OR_UNDEFINED(this) && !IS_UNDETECTABLE(this)) { CHECK_OBJECT_COERCIBLE(this, "String.prototype.startsWith");
throw MakeTypeError("called_on_null_or_undefined",
var s = TO_STRING_INLINE(this);
if (IS_REGEXP(searchString)) {
throw MakeTypeError("first_argument_not_regexp",
["String.prototype.startsWith"]); ["String.prototype.startsWith"]);
} }
var s = TO_STRING_INLINE(this);
var ss = TO_STRING_INLINE(searchString); var ss = TO_STRING_INLINE(searchString);
var pos = 0; var pos = 0;
if (%_ArgumentsLength() > 1) { if (%_ArgumentsLength() > 1) {
...@@ -82,14 +82,17 @@ function StringStartsWith(searchString /* position */) { // length == 1 ...@@ -82,14 +82,17 @@ function StringStartsWith(searchString /* position */) { // length == 1
} }
// ES6 draft 07-15-13, section 15.5.3.23 // ES6 draft 01-20-14, section 21.1.3.7
function StringEndsWith(searchString /* position */) { // length == 1 function StringEndsWith(searchString /* position */) { // length == 1
if (IS_NULL_OR_UNDEFINED(this) && !IS_UNDETECTABLE(this)) { CHECK_OBJECT_COERCIBLE(this, "String.prototype.endsWith");
throw MakeTypeError("called_on_null_or_undefined",
var s = TO_STRING_INLINE(this);
if (IS_REGEXP(searchString)) {
throw MakeTypeError("first_argument_not_regexp",
["String.prototype.endsWith"]); ["String.prototype.endsWith"]);
} }
var s = TO_STRING_INLINE(this);
var ss = TO_STRING_INLINE(searchString); var ss = TO_STRING_INLINE(searchString);
var s_len = s.length; var s_len = s.length;
var pos = s_len; var pos = s_len;
...@@ -111,12 +114,9 @@ function StringEndsWith(searchString /* position */) { // length == 1 ...@@ -111,12 +114,9 @@ function StringEndsWith(searchString /* position */) { // length == 1
} }
// ES6 draft 07-15-13, section 15.5.3.24 // ES6 draft 01-20-14, section 21.1.3.6
function StringContains(searchString /* position */) { // length == 1 function StringContains(searchString /* position */) { // length == 1
if (IS_NULL_OR_UNDEFINED(this) && !IS_UNDETECTABLE(this)) { CHECK_OBJECT_COERCIBLE(this, "String.prototype.contains");
throw MakeTypeError("called_on_null_or_undefined",
["String.prototype.contains"]);
}
var s = TO_STRING_INLINE(this); var s = TO_STRING_INLINE(this);
var ss = TO_STRING_INLINE(searchString); var ss = TO_STRING_INLINE(searchString);
......
...@@ -114,6 +114,7 @@ var kMessages = { ...@@ -114,6 +114,7 @@ var kMessages = {
promise_cyclic: ["Chaining cycle detected for promise ", "%0"], promise_cyclic: ["Chaining cycle detected for promise ", "%0"],
array_functions_on_frozen: ["Cannot modify frozen array elements"], array_functions_on_frozen: ["Cannot modify frozen array elements"],
array_functions_change_sealed: ["Cannot add/remove sealed array elements"], array_functions_change_sealed: ["Cannot add/remove sealed array elements"],
first_argument_not_regexp: ["First argument to ", "%0", " must not be a regular expression"],
// RangeError // RangeError
invalid_array_length: ["Invalid array length"], invalid_array_length: ["Invalid array length"],
invalid_array_buffer_length: ["Invalid array buffer length"], invalid_array_buffer_length: ["Invalid array buffer length"],
......
This diff is collapsed.
This diff is collapsed.
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