978f41a1da
The bug would occur when we try to Reset() to a position already at the end. This happens e.g., when the regexp ends with \u. What used to happen in that case: 1) Advance past \ and u (to the end) (which wouldn't increase next_pos_ enough) 2) Try to parse 4 hex digits 3) When that failed, Reset() to the position which should've been at the end but wasn't. To be able to properly Reset() to a position at the end, we need to allow next_pos_ to move beyond the end (since position() is next_pos_ - 1). Minimal repro case: var r = /foo\u/ r.test("foou") // should be true, was false. (Note that \u not followed by 4 hex didits should be interpreted as an identity escape. It already worked unless \u was at the end of the regexp.) BUG=v8:3756 LOG=NO Review URL: https://codereview.chromium.org/802313003 Cr-Commit-Position: refs/heads/master@{#25838}
75 lines
1.9 KiB
JavaScript
75 lines
1.9 KiB
JavaScript
// Copyright 2014 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.
|
|
|
|
(function TestIdentityEscapes() {
|
|
// \u not followed by 4 hex digits is treated as an identity escape.
|
|
var r0 = /\u/;
|
|
assertTrue(r0.test("u"));
|
|
|
|
r0 = RegExp("\\u");
|
|
assertTrue(r0.test("u"));
|
|
|
|
var r1 = /\usecond/;
|
|
assertTrue(r1.test("usecond"));
|
|
|
|
r1 = RegExp("\\usecond");
|
|
assertTrue(r1.test("usecond"));
|
|
|
|
var r2 = /first\u/;
|
|
assertTrue(r2.test("firstu"));
|
|
// This used to return true (which was a bug).
|
|
assertFalse(r2.test("first\\u"));
|
|
|
|
r2 = RegExp("first\\u");
|
|
assertTrue(r2.test("firstu"));
|
|
// This used to return true (which was a bug).
|
|
assertFalse(r2.test("first\\u"));
|
|
|
|
var r3 = /first\usecond/;
|
|
assertTrue(r3.test("firstusecond"));
|
|
assertFalse(r3.test("first\\usecond"));
|
|
|
|
r3 = RegExp("first\\usecond");
|
|
assertTrue(r3.test("firstusecond"));
|
|
assertFalse(r3.test("first\\usecond"));
|
|
|
|
var r4 = /first\u123second/;
|
|
assertTrue(r4.test("firstu123second"));
|
|
assertFalse(r4.test("first\\u123second"));
|
|
|
|
r4 = RegExp("first\\u123second");
|
|
assertTrue(r4.test("firstu123second"));
|
|
assertFalse(r4.test("first\\u123second"));
|
|
|
|
// \X where X is not a legal escape character is treated as identity escape
|
|
// too.
|
|
var r5 = /\a/;
|
|
assertTrue(r5.test("a"));
|
|
|
|
r5 = RegExp("\\a");
|
|
assertTrue(r5.test("a"));
|
|
|
|
var r6 = /\asecond/;
|
|
assertTrue(r6.test("asecond"));
|
|
|
|
r6 = RegExp("\\asecond");
|
|
assertTrue(r6.test("asecond"));
|
|
|
|
var r7 = /first\a/;
|
|
assertTrue(r7.test("firsta"));
|
|
assertFalse(r7.test("first\\a"));
|
|
|
|
r7 = RegExp("first\\a");
|
|
assertTrue(r7.test("firsta"));
|
|
assertFalse(r7.test("first\\a"));
|
|
|
|
var r8 = /first\asecond/;
|
|
assertTrue(r8.test("firstasecond"));
|
|
assertFalse(r8.test("first\\asecond"));
|
|
|
|
r8 = RegExp("first\\asecond");
|
|
assertTrue(r8.test("firstasecond"));
|
|
assertFalse(r8.test("first\\asecond"));
|
|
})();
|