|
|
|
// 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.
|
|
|
|
|
|
|
|
#include "src/char-predicates.h"
|
|
|
|
#include "src/unicode.h"
|
|
|
|
#include "testing/gtest/include/gtest/gtest.h"
|
|
|
|
|
|
|
|
namespace v8 {
|
|
|
|
namespace internal {
|
|
|
|
|
|
|
|
TEST(CharPredicatesTest, WhiteSpace) {
|
|
|
|
EXPECT_TRUE(WhiteSpace::Is(0x0009));
|
|
|
|
EXPECT_TRUE(WhiteSpace::Is(0x000B));
|
|
|
|
EXPECT_TRUE(WhiteSpace::Is(0x000C));
|
|
|
|
EXPECT_TRUE(WhiteSpace::Is(' '));
|
|
|
|
EXPECT_TRUE(WhiteSpace::Is(0x00A0));
|
|
|
|
EXPECT_TRUE(WhiteSpace::Is(0x1680));
|
|
|
|
EXPECT_TRUE(WhiteSpace::Is(0x2000));
|
|
|
|
EXPECT_TRUE(WhiteSpace::Is(0x2007));
|
|
|
|
EXPECT_TRUE(WhiteSpace::Is(0x202F));
|
|
|
|
EXPECT_TRUE(WhiteSpace::Is(0x205F));
|
|
|
|
EXPECT_TRUE(WhiteSpace::Is(0x3000));
|
|
|
|
EXPECT_TRUE(WhiteSpace::Is(0xFEFF));
|
|
|
|
EXPECT_FALSE(WhiteSpace::Is(0x180E));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
TEST(CharPredicatesTest, WhiteSpaceOrLineTerminator) {
|
|
|
|
EXPECT_TRUE(WhiteSpaceOrLineTerminator::Is(0x0009));
|
|
|
|
EXPECT_TRUE(WhiteSpaceOrLineTerminator::Is(0x000B));
|
|
|
|
EXPECT_TRUE(WhiteSpaceOrLineTerminator::Is(0x000C));
|
|
|
|
EXPECT_TRUE(WhiteSpaceOrLineTerminator::Is(' '));
|
|
|
|
EXPECT_TRUE(WhiteSpaceOrLineTerminator::Is(0x00A0));
|
|
|
|
EXPECT_TRUE(WhiteSpaceOrLineTerminator::Is(0x1680));
|
|
|
|
EXPECT_TRUE(WhiteSpaceOrLineTerminator::Is(0x2000));
|
|
|
|
EXPECT_TRUE(WhiteSpaceOrLineTerminator::Is(0x2007));
|
|
|
|
EXPECT_TRUE(WhiteSpaceOrLineTerminator::Is(0x202F));
|
|
|
|
EXPECT_TRUE(WhiteSpaceOrLineTerminator::Is(0x205F));
|
|
|
|
EXPECT_TRUE(WhiteSpaceOrLineTerminator::Is(0xFEFF));
|
|
|
|
// Line terminators
|
|
|
|
EXPECT_TRUE(WhiteSpaceOrLineTerminator::Is(0x000A));
|
|
|
|
EXPECT_TRUE(WhiteSpaceOrLineTerminator::Is(0x000D));
|
|
|
|
EXPECT_TRUE(WhiteSpaceOrLineTerminator::Is(0x2028));
|
|
|
|
EXPECT_TRUE(WhiteSpaceOrLineTerminator::Is(0x2029));
|
|
|
|
EXPECT_FALSE(WhiteSpaceOrLineTerminator::Is(0x180E));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
TEST(CharPredicatesTest, IdentifierStart) {
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is('$'));
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is('_'));
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is('\\'));
|
|
|
|
|
|
|
|
// http://www.unicode.org/reports/tr31/
|
|
|
|
// curl http://www.unicode.org/Public/UCD/latest/ucd/PropList.txt |
|
|
|
|
// grep 'Other_ID_Start'
|
|
|
|
// Other_ID_Start
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is(0x1885));
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is(0x1886));
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is(0x2118));
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is(0x212E));
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is(0x309B));
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is(0x309C));
|
|
|
|
|
|
|
|
// Issue 2892:
|
|
|
|
// \u2E2F has the Pattern_Syntax property, excluding it from ID_Start.
|
|
|
|
EXPECT_FALSE(IdentifierStart::Is(0x2E2F));
|
|
|
|
|
|
|
|
#ifdef V8_INTL_SUPPORT
|
|
|
|
// New in Unicode 8.0 (6,847 code points)
|
|
|
|
// [:ID_Start:] & [[:Age=8.0:] - [:Age=7.0:]]
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is(0x08B3));
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is(0x0AF9));
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is(0x13F8));
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is(0x9FCD));
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is(0xAB60));
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is(0x10CC0));
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is(0x108E0));
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is(0x2B820));
|
|
|
|
|
|
|
|
// New in Unicode 9.0 (7,177 code points)
|
|
|
|
// [:ID_Start:] & [[:Age=9.0:] - [:Age=8.0:]]
|
|
|
|
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is(0x1C80));
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is(0x104DB));
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is(0x1E922));
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
TEST(CharPredicatesTest, IdentifierPart) {
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is('$'));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is('_'));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is('\\'));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x200C));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x200D));
|
|
|
|
|
|
|
|
#ifdef V8_INTL_SUPPORT
|
|
|
|
// New in Unicode 8.0 (6,847 code points)
|
|
|
|
// [:ID_Start:] & [[:Age=8.0:] - [:Age=7.0:]]
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x08B3));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x0AF9));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x13F8));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x9FCD));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0xAB60));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x10CC0));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x108E0));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x2B820));
|
|
|
|
|
|
|
|
// [[:ID_Continue:]-[:ID_Start:]] & [[:Age=8.0:]-[:Age=7.0:]]
|
|
|
|
// 162 code points
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x08E3));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0xA69E));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x11730));
|
|
|
|
|
|
|
|
// New in Unicode 9.0 (7,177 code points)
|
|
|
|
// [:ID_Start:] & [[:Age=9.0:] - [:Age=8.0:]]
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x1C80));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x104DB));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x1E922));
|
|
|
|
|
|
|
|
// [[:ID_Continue:]-[:ID_Start:]] & [[:Age=9.0:]-[:Age=8.0:]]
|
|
|
|
// 162 code points
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x08D4));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x1DFB));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0xA8C5));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x11450));
|
|
|
|
#endif
|
|
|
|
|
|
|
|
// http://www.unicode.org/reports/tr31/
|
|
|
|
// curl http://www.unicode.org/Public/UCD/latest/ucd/PropList.txt |
|
|
|
|
// grep 'Other_ID_(Continue|Start)'
|
|
|
|
|
|
|
|
// Other_ID_Start
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x1885));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x1886));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x2118));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x212E));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x309B));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x309C));
|
|
|
|
|
|
|
|
// Other_ID_Continue
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x00B7));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x0387));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x1369));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x1370));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x1371));
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x19DA));
|
|
|
|
|
|
|
|
// Issue 2892:
|
|
|
|
// \u2E2F has the Pattern_Syntax property, excluding it from ID_Start.
|
|
|
|
EXPECT_FALSE(IdentifierPart::Is(0x2E2F));
|
|
|
|
}
|
|
|
|
|
|
|
|
#ifdef V8_INTL_SUPPORT
|
|
|
|
TEST(CharPredicatesTest, SupplementaryPlaneIdentifiers) {
|
|
|
|
// Both ID_Start and ID_Continue.
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is(0x10403)); // Category Lu
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x10403));
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is(0x1043C)); // Category Ll
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x1043C));
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is(0x16F9C)); // Category Lm
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x16F9C));
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is(0x10048)); // Category Lo
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x10048));
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is(0x1014D)); // Category Nl
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x1014D));
|
|
|
|
|
|
|
|
// New in Unicode 8.0
|
|
|
|
// [ [:ID_Start=Yes:] & [:Age=8.0:]] - [:Age=7.0:]
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is(0x108E0));
|
|
|
|
EXPECT_TRUE(IdentifierStart::Is(0x10C80));
|
|
|
|
|
|
|
|
// Only ID_Continue.
|
|
|
|
EXPECT_FALSE(IdentifierStart::Is(0x101FD)); // Category Mn
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x101FD));
|
|
|
|
EXPECT_FALSE(IdentifierStart::Is(0x11002)); // Category Mc
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x11002));
|
|
|
|
EXPECT_FALSE(IdentifierStart::Is(0x104A9)); // Category Nd
|
|
|
|
EXPECT_TRUE(IdentifierPart::Is(0x104A9));
|
|
|
|
|
|
|
|
// Neither.
|
|
|
|
EXPECT_FALSE(IdentifierStart::Is(0x10111)); // Category No
|
|
|
|
EXPECT_FALSE(IdentifierPart::Is(0x10111));
|
|
|
|
EXPECT_FALSE(IdentifierStart::Is(0x1F4A9)); // Category So
|
|
|
|
EXPECT_FALSE(IdentifierPart::Is(0x1F4A9));
|
|
|
|
}
|
|
|
|
#endif // V8_INTL_SUPPORT
|
|
|
|
|
|
|
|
} // namespace internal
|
|
|
|
} // namespace v8
|