OLD | NEW |
1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 the V8 project authors. All rights reserved. |
2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
4 // met: | 4 // met: |
5 // | 5 // |
6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
(...skipping 122 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
133 | 133 |
134 | 134 |
135 bool AstValue::BooleanValue() const { | 135 bool AstValue::BooleanValue() const { |
136 switch (type_) { | 136 switch (type_) { |
137 case STRING: | 137 case STRING: |
138 DCHECK(string_ != NULL); | 138 DCHECK(string_ != NULL); |
139 return !string_->IsEmpty(); | 139 return !string_->IsEmpty(); |
140 case SYMBOL: | 140 case SYMBOL: |
141 UNREACHABLE(); | 141 UNREACHABLE(); |
142 break; | 142 break; |
| 143 case NUMBER_WITH_DOT: |
143 case NUMBER: | 144 case NUMBER: |
144 return DoubleToBoolean(number_); | 145 return DoubleToBoolean(number_); |
145 case SMI: | 146 case SMI: |
146 return smi_ != 0; | 147 return smi_ != 0; |
147 case BOOLEAN: | 148 case BOOLEAN: |
148 return bool_; | 149 return bool_; |
149 case NULL_TYPE: | 150 case NULL_TYPE: |
150 return false; | 151 return false; |
151 case THE_HOLE: | 152 case THE_HOLE: |
152 UNREACHABLE(); | 153 UNREACHABLE(); |
(...skipping 15 matching lines...) Expand all Loading... |
168 break; | 169 break; |
169 case SYMBOL: | 170 case SYMBOL: |
170 if (symbol_name_[0] == 'i') { | 171 if (symbol_name_[0] == 'i') { |
171 DCHECK_EQ(0, strcmp(symbol_name_, "iterator_symbol")); | 172 DCHECK_EQ(0, strcmp(symbol_name_, "iterator_symbol")); |
172 value_ = isolate->factory()->iterator_symbol(); | 173 value_ = isolate->factory()->iterator_symbol(); |
173 } else { | 174 } else { |
174 DCHECK_EQ(0, strcmp(symbol_name_, "home_object_symbol")); | 175 DCHECK_EQ(0, strcmp(symbol_name_, "home_object_symbol")); |
175 value_ = isolate->factory()->home_object_symbol(); | 176 value_ = isolate->factory()->home_object_symbol(); |
176 } | 177 } |
177 break; | 178 break; |
| 179 case NUMBER_WITH_DOT: |
178 case NUMBER: | 180 case NUMBER: |
179 value_ = isolate->factory()->NewNumber(number_, TENURED); | 181 value_ = isolate->factory()->NewNumber(number_, TENURED); |
180 break; | 182 break; |
181 case SMI: | 183 case SMI: |
182 value_ = handle(Smi::FromInt(smi_), isolate); | 184 value_ = handle(Smi::FromInt(smi_), isolate); |
183 break; | 185 break; |
184 case BOOLEAN: | 186 case BOOLEAN: |
185 if (bool_) { | 187 if (bool_) { |
186 value_ = isolate->factory()->true_value(); | 188 value_ = isolate->factory()->true_value(); |
187 } else { | 189 } else { |
(...skipping 95 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
283 const AstValue* AstValueFactory::NewSymbol(const char* name) { | 285 const AstValue* AstValueFactory::NewSymbol(const char* name) { |
284 AstValue* value = new (zone_) AstValue(name); | 286 AstValue* value = new (zone_) AstValue(name); |
285 if (isolate_) { | 287 if (isolate_) { |
286 value->Internalize(isolate_); | 288 value->Internalize(isolate_); |
287 } | 289 } |
288 values_.Add(value); | 290 values_.Add(value); |
289 return value; | 291 return value; |
290 } | 292 } |
291 | 293 |
292 | 294 |
293 const AstValue* AstValueFactory::NewNumber(double number) { | 295 const AstValue* AstValueFactory::NewNumber(double number, bool with_dot) { |
294 AstValue* value = new (zone_) AstValue(number); | 296 AstValue* value = new (zone_) AstValue(number, with_dot); |
295 if (isolate_) { | 297 if (isolate_) { |
296 value->Internalize(isolate_); | 298 value->Internalize(isolate_); |
297 } | 299 } |
298 values_.Add(value); | 300 values_.Add(value); |
299 return value; | 301 return value; |
300 } | 302 } |
301 | 303 |
302 | 304 |
303 const AstValue* AstValueFactory::NewSmi(int number) { | 305 const AstValue* AstValueFactory::NewSmi(int number) { |
304 AstValue* value = | 306 AstValue* value = |
(...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
378 const AstRawString* lhs = static_cast<AstRawString*>(a); | 380 const AstRawString* lhs = static_cast<AstRawString*>(a); |
379 const AstRawString* rhs = static_cast<AstRawString*>(b); | 381 const AstRawString* rhs = static_cast<AstRawString*>(b); |
380 if (lhs->is_one_byte() != rhs->is_one_byte()) return false; | 382 if (lhs->is_one_byte() != rhs->is_one_byte()) return false; |
381 if (lhs->hash() != rhs->hash()) return false; | 383 if (lhs->hash() != rhs->hash()) return false; |
382 int len = lhs->byte_length(); | 384 int len = lhs->byte_length(); |
383 if (rhs->byte_length() != len) return false; | 385 if (rhs->byte_length() != len) return false; |
384 return memcmp(lhs->raw_data(), rhs->raw_data(), len) == 0; | 386 return memcmp(lhs->raw_data(), rhs->raw_data(), len) == 0; |
385 } | 387 } |
386 } // namespace internal | 388 } // namespace internal |
387 } // namespace v8 | 389 } // namespace v8 |
OLD | NEW |