From 6bf0a5cb5034a7e684dcc3500e841785237ce2dd Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sun, 7 Apr 2024 19:32:43 +0200 Subject: Adding upstream version 1:115.7.0. Signed-off-by: Daniel Baumann --- .../String/replace-updates-global-lastIndex.js | 38 ++++++++++++++++++++++ 1 file changed, 38 insertions(+) create mode 100644 js/src/tests/non262/String/replace-updates-global-lastIndex.js (limited to 'js/src/tests/non262/String/replace-updates-global-lastIndex.js') diff --git a/js/src/tests/non262/String/replace-updates-global-lastIndex.js b/js/src/tests/non262/String/replace-updates-global-lastIndex.js new file mode 100644 index 0000000000..c859d7093b --- /dev/null +++ b/js/src/tests/non262/String/replace-updates-global-lastIndex.js @@ -0,0 +1,38 @@ +/* + * Any copyright is dedicated to the Public Domain. + * http://creativecommons.org/licenses/publicdomain/ + */ + +var BUGNUMBER = 501739; +var summary = + "String.prototype.relace should zero the .lastIndex when called with a " + + "global RegExp"; + +print(BUGNUMBER + ": " + summary); + +/************** + * BEGIN TEST * + **************/ + +var s = '0x2x4x6x8'; + +var p1 = /x/g; +p1.lastIndex = 3; +s.replace(p1, ''); +assertEq(p1.lastIndex, 0); + +var p2 = /x/g; +p2.lastIndex = 3; +var c = 0; +s.replace(p2, function(s) { + assertEq(p2.lastIndex++, c++); + return 'y'; +}); +assertEq(p2.lastIndex, 4); + +/******************************************************************************/ + +if (typeof reportCompare === "function") + reportCompare(true, true); + +print("Tests complete"); -- cgit v1.2.3