| Index: src/ast-value-factory.cc
|
| diff --git a/src/ast-value-factory.cc b/src/ast-value-factory.cc
|
| index 68cf015200365c988adfcfd55bc73cbcaff49c7e..fbcde8b45703fca41a0d97b44ec43c2a38bbddf7 100644
|
| --- a/src/ast-value-factory.cc
|
| +++ b/src/ast-value-factory.cc
|
| @@ -29,6 +29,7 @@
|
|
|
| #include "src/api.h"
|
| #include "src/objects.h"
|
| +#include "src/utils.h"
|
|
|
| namespace v8 {
|
| namespace internal {
|
| @@ -379,11 +380,32 @@ AstRawString* AstValueFactory::GetString(uint32_t hash, bool is_one_byte,
|
| bool AstValueFactory::AstRawStringCompare(void* a, void* b) {
|
| const AstRawString* lhs = static_cast<AstRawString*>(a);
|
| const AstRawString* rhs = static_cast<AstRawString*>(b);
|
| - if (lhs->is_one_byte() != rhs->is_one_byte()) return false;
|
| + if (lhs->length() != rhs->length()) return false;
|
| if (lhs->hash() != rhs->hash()) return false;
|
| - int len = lhs->byte_length();
|
| - if (rhs->byte_length() != len) return false;
|
| - return memcmp(lhs->raw_data(), rhs->raw_data(), len) == 0;
|
| + const unsigned char* l = lhs->raw_data();
|
| + const unsigned char* r = rhs->raw_data();
|
| + size_t length = rhs->length();
|
| + if (lhs->is_one_byte()) {
|
| + if (rhs->is_one_byte()) {
|
| + return CompareCharsUnsigned(reinterpret_cast<const uint8_t*>(l),
|
| + reinterpret_cast<const uint8_t*>(r),
|
| + length) == 0;
|
| + } else {
|
| + return CompareCharsUnsigned(reinterpret_cast<const uint8_t*>(l),
|
| + reinterpret_cast<const uint16_t*>(r),
|
| + length) == 0;
|
| + }
|
| + } else {
|
| + if (rhs->is_one_byte()) {
|
| + return CompareCharsUnsigned(reinterpret_cast<const uint16_t*>(l),
|
| + reinterpret_cast<const uint8_t*>(r),
|
| + length) == 0;
|
| + } else {
|
| + return CompareCharsUnsigned(reinterpret_cast<const uint16_t*>(l),
|
| + reinterpret_cast<const uint16_t*>(r),
|
| + length) == 0;
|
| + }
|
| + }
|
| }
|
| } // namespace internal
|
| } // namespace v8
|
|
|