Index: test/webkit/fast/js/regexp-unicode-handling.js |
diff --git a/test/webkit/fast/js/regexp-unicode-handling.js b/test/webkit/fast/js/regexp-unicode-handling.js |
new file mode 100644 |
index 0000000000000000000000000000000000000000..43d4fa453de06919c4e62a42f62b883759c5cfa7 |
--- /dev/null |
+++ b/test/webkit/fast/js/regexp-unicode-handling.js |
@@ -0,0 +1,128 @@ |
+// Copyright 2013 the V8 project authors. All rights reserved. |
+// Copyright (C) 2005, 2006, 2007, 2008, 2009 Apple Inc. All rights reserved. |
+// |
+// Redistribution and use in source and binary forms, with or without |
+// modification, are permitted provided that the following conditions |
+// are met: |
+// 1. Redistributions of source code must retain the above copyright |
+// notice, this list of conditions and the following disclaimer. |
+// 2. Redistributions in binary form must reproduce the above copyright |
+// notice, this list of conditions and the following disclaimer in the |
+// documentation and/or other materials provided with the distribution. |
+// |
+// THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS'' AND ANY |
+// EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED |
+// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE |
+// DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS BE LIABLE FOR ANY |
+// DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES |
+// (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; |
+// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON |
+// ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
+// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS |
+// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
+ |
+description( |
+ |
+'Test for proper handling of Unicode RegExps and <a href="http://bugzilla.webkit.org/show_bug.cgi?id=7445">bug 7445</a>: Gmail puts wrong subject in replies.' |
+ |
+); |
+ |
+// Regex to match Re in various languanges straight from Gmail source |
+var I3=/^\s*(fwd|re|aw|antw|antwort|wg|sv|ang|odp|betreff|betr|transf|reenv\.|reenv|in|res|resp|resp\.|enc|\u8f6c\u53d1|\u56DE\u590D|\u041F\u0435\u0440\u0435\u0441\u043B|\u041E\u0442\u0432\u0435\u0442):\s*(.*)$/i; |
+ |
+// Other RegExs from Gmail source |
+var Ci=/\s+/g; |
+var BC=/^ /; |
+var BG=/ $/; |
+ |
+// Strips leading Re or similar (from Gmail source) |
+function cy(a) { |
+ //var b = I3.exec(a); |
+ var b = I3.exec(a); |
+ |
+ if (b) { |
+ a = b[2]; |
+ } |
+ |
+ return Gn(a); |
+} |
+ |
+// This function replaces consecutive whitespace with a single space |
+// then removes a leading and trailing space if they exist. (From Gmail) |
+function Gn(a) { |
+ return a.replace(Ci, " ").replace(BC, "").replace(BG, ""); |
+} |
+ |
+shouldBe("cy('Re: Moose')", "'Moose'") |
+shouldBe("cy('\\u8f6c\\u53d1: Moose')", "'Moose'") |
+ |
+// Test handling of \u2820 (skull and crossbones) |
+var sample="sample bm\u2820p cm\\u2820p"; |
+ |
+var inlineRe=/.m\u2820p/ |
+var evalInlineRe=eval("/.m\\u2820p/") |
+var explicitRe=new RegExp(".m\\u2820p") |
+var newFromInlineRe=new RegExp(inlineRe.source) |
+var evalFromInlineRe=eval(inlineRe.toString()) |
+var newFromEvalInlineRe=new RegExp(evalInlineRe.source) |
+var evalFromEvalInlineRe=eval(evalInlineRe.toString()) |
+var newFromExplicitRe=new RegExp(explicitRe.source) |
+var evalFromExplicitRe=eval(explicitRe.toString()) |
+ |
+shouldBe("inlineRe.source", "newFromInlineRe.source") |
+shouldBe("inlineRe.source", "evalFromInlineRe.source") |
+shouldBe("inlineRe.source", "evalInlineRe.source") |
+shouldBe("inlineRe.source", "newFromEvalInlineRe.source") |
+shouldBe("inlineRe.source", "evalFromEvalInlineRe.source") |
+shouldBe("inlineRe.source", "explicitRe.source") |
+shouldBe("inlineRe.source", "newFromExplicitRe.source") |
+shouldBe("inlineRe.source", "evalFromExplicitRe.source") |
+ |
+shouldBe("inlineRe.toString()", "newFromInlineRe.toString()") |
+shouldBe("inlineRe.toString()", "evalFromInlineRe.toString()") |
+shouldBe("inlineRe.toString()", "evalInlineRe.toString()") |
+shouldBe("inlineRe.toString()", "newFromEvalInlineRe.toString()") |
+shouldBe("inlineRe.toString()", "evalFromEvalInlineRe.toString()") |
+shouldBe("inlineRe.toString()", "explicitRe.toString()") |
+shouldBe("inlineRe.toString()", "newFromExplicitRe.toString()") |
+shouldBe("inlineRe.toString()", "evalFromExplicitRe.toString()") |
+ |
+shouldBe("inlineRe.exec(sample)[0]", "'bm\u2820p'") |
+shouldBe("evalInlineRe.exec(sample)[0]", "'bm\u2820p'") |
+shouldBe("explicitRe.exec(sample)[0]", "'bm\u2820p'") |
+ |
+ |
+// Test handling of \u007c "|" |
+var bsample="sample bm\u007cp cm\\u007cp"; |
+ |
+var binlineRe=/.m\u007cp/ |
+var bevalInlineRe=eval("/.m\\u007cp/") |
+var bexplicitRe=new RegExp(".m\\u007cp") |
+var bnewFromInlineRe=new RegExp(binlineRe.source) |
+var bevalFromInlineRe=eval(binlineRe.toString()) |
+var bnewFromEvalInlineRe=new RegExp(bevalInlineRe.source) |
+var bevalFromEvalInlineRe=eval(bevalInlineRe.toString()) |
+var bnewFromExplicitRe=new RegExp(bexplicitRe.source) |
+var bevalFromExplicitRe=eval(bexplicitRe.toString()) |
+ |
+shouldBe("binlineRe.source", "bnewFromInlineRe.source") |
+shouldBe("binlineRe.source", "bevalFromInlineRe.source") |
+shouldBe("binlineRe.source", "bevalInlineRe.source") |
+shouldBe("binlineRe.source", "bnewFromEvalInlineRe.source") |
+shouldBe("binlineRe.source", "bevalFromEvalInlineRe.source") |
+shouldBe("binlineRe.source", "bexplicitRe.source") |
+shouldBe("binlineRe.source", "bnewFromExplicitRe.source") |
+shouldBe("binlineRe.source", "bevalFromExplicitRe.source") |
+ |
+shouldBe("binlineRe.toString()", "bnewFromInlineRe.toString()") |
+shouldBe("binlineRe.toString()", "bevalFromInlineRe.toString()") |
+shouldBe("binlineRe.toString()", "bevalInlineRe.toString()") |
+shouldBe("binlineRe.toString()", "bnewFromEvalInlineRe.toString()") |
+shouldBe("binlineRe.toString()", "bevalFromEvalInlineRe.toString()") |
+shouldBe("binlineRe.toString()", "bexplicitRe.toString()") |
+shouldBe("binlineRe.toString()", "bnewFromExplicitRe.toString()") |
+shouldBe("binlineRe.toString()", "bevalFromExplicitRe.toString()") |
+ |
+shouldBe("binlineRe.exec(bsample)[0]", "'bm|p'") |
+shouldBe("bevalInlineRe.exec(bsample)[0]", "'bm|p'") |
+shouldBe("bexplicitRe.exec(bsample)[0]", "'bm|p'") |