Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(40)

Unified Diff: src/char-predicates.cc

Issue 2331303002: Use ICU for ID_START and ID_CONTINUE for Unicode 9 data (Closed)
Patch Set: drop an unnecessary todo Created 3 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « src/char-predicates.h ('k') | src/unicode.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: src/char-predicates.cc
diff --git a/src/char-predicates.cc b/src/char-predicates.cc
index dc9865b5584ff91f77269e4919842f07adf8e3b7..747f4194f4192732006f0a2b309ff95829074586 100644
--- a/src/char-predicates.cc
+++ b/src/char-predicates.cc
@@ -2,41 +2,43 @@
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
+#ifndef V8_INTL_SUPPORT
+#error Internationalization is expected to be enabled.
+#endif // V8_INTL_SUPPORT
+
#include "src/char-predicates.h"
-#ifdef V8_INTL_SUPPORT
#include "unicode/uchar.h"
#include "unicode/urename.h"
-#endif // V8_INTL_SUPPORT
namespace v8 {
namespace internal {
-bool SupplementaryPlanes::IsIDStart(uc32 c) {
- DCHECK(c > 0xFFFF);
-#ifdef V8_INTL_SUPPORT
- // This only works for code points in the SMPs, since ICU does not exclude
- // code points with properties 'Pattern_Syntax' or 'Pattern_White_Space'.
- // Code points in the SMP do not have those properties.
- return u_isIDStart(c);
-#else
- // This is incorrect, but if we don't have ICU, use this as fallback.
- return false;
-#endif // V8_INTL_SUPPORT
+// ES#sec-names-and-keywords Names and Keywords
+// UnicodeIDStart, '$', '_' and '\'
+bool IdentifierStart::Is(uc32 c) {
+ // cannot use u_isIDStart because it does not work for
+ // Other_ID_Start characters.
+ return u_hasBinaryProperty(c, UCHAR_ID_START) ||
+ (c < 0x60 && (c == '$' || c == '\\' || c == '_'));
}
+// ES#sec-names-and-keywords Names and Keywords
+// UnicodeIDContinue, '$', '_', '\', ZWJ, and ZWNJ
+bool IdentifierPart::Is(uc32 c) {
+ // Can't use u_isIDPart because it does not work for
+ // Other_ID_Continue characters.
+ return u_hasBinaryProperty(c, UCHAR_ID_CONTINUE) ||
+ (c < 0x60 && (c == '$' || c == '\\' || c == '_')) || c == 0x200C ||
+ c == 0x200D;
+}
-bool SupplementaryPlanes::IsIDPart(uc32 c) {
- DCHECK(c > 0xFFFF);
-#ifdef V8_INTL_SUPPORT
- // This only works for code points in the SMPs, since ICU does not exclude
- // code points with properties 'Pattern_Syntax' or 'Pattern_White_Space'.
- // Code points in the SMP do not have those properties.
- return u_isIDPart(c);
-#else
- // This is incorrect, but if we don't have ICU, use this as fallback.
- return false;
-#endif // V8_INTL_SUPPORT
+// ES#sec-white-space White Space
+// gC=Zs, U+0009, U+000B, U+000C, U+FEFF
+bool WhiteSpace::Is(uc32 c) {
+ return (u_charType(c) == U_SPACE_SEPARATOR) ||
+ (c < 0x0D && (c == 0x09 || c == 0x0B || c == 0x0C)) || c == 0xFEFF;
}
+
} // namespace internal
} // namespace v8
« no previous file with comments | « src/char-predicates.h ('k') | src/unicode.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698