| OLD | NEW |
| 1 // Copyright 2011 the V8 project authors. All rights reserved. | 1 // Copyright 2011 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 465 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 476 if (result->IsJSFunction()) return result; | 476 if (result->IsJSFunction()) return result; |
| 477 | 477 |
| 478 // Try to find a suitable function delegate for the object at hand. | 478 // Try to find a suitable function delegate for the object at hand. |
| 479 result = TryCallAsFunction(result); | 479 result = TryCallAsFunction(result); |
| 480 if (result->IsJSFunction()) return result; | 480 if (result->IsJSFunction()) return result; |
| 481 | 481 |
| 482 // Otherwise, it will fail in the lookup step. | 482 // Otherwise, it will fail in the lookup step. |
| 483 } | 483 } |
| 484 | 484 |
| 485 // Lookup the property in the object. | 485 // Lookup the property in the object. |
| 486 LookupResult lookup; | 486 LookupResult lookup(isolate()); |
| 487 LookupForRead(*object, *name, &lookup); | 487 LookupForRead(*object, *name, &lookup); |
| 488 | 488 |
| 489 if (!lookup.IsProperty()) { | 489 if (!lookup.IsProperty()) { |
| 490 // If the object does not have the requested property, check which | 490 // If the object does not have the requested property, check which |
| 491 // exception we need to throw. | 491 // exception we need to throw. |
| 492 if (IsContextual(object)) { | 492 if (IsContextual(object)) { |
| 493 return ReferenceError("not_defined", name); | 493 return ReferenceError("not_defined", name); |
| 494 } | 494 } |
| 495 return TypeError("undefined_method", object, name); | 495 return TypeError("undefined_method", object, name); |
| 496 } | 496 } |
| (...skipping 431 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 928 return Accessors::FunctionGetPrototype(*object, 0); | 928 return Accessors::FunctionGetPrototype(*object, 0); |
| 929 } | 929 } |
| 930 } | 930 } |
| 931 | 931 |
| 932 // Check if the name is trivially convertible to an index and get | 932 // Check if the name is trivially convertible to an index and get |
| 933 // the element if so. | 933 // the element if so. |
| 934 uint32_t index; | 934 uint32_t index; |
| 935 if (name->AsArrayIndex(&index)) return object->GetElement(index); | 935 if (name->AsArrayIndex(&index)) return object->GetElement(index); |
| 936 | 936 |
| 937 // Named lookup in the object. | 937 // Named lookup in the object. |
| 938 LookupResult lookup; | 938 LookupResult lookup(isolate()); |
| 939 LookupForRead(*object, *name, &lookup); | 939 LookupForRead(*object, *name, &lookup); |
| 940 | 940 |
| 941 // If we did not find a property, check if we need to throw an exception. | 941 // If we did not find a property, check if we need to throw an exception. |
| 942 if (!lookup.IsProperty()) { | 942 if (!lookup.IsProperty()) { |
| 943 if (IsContextual(object)) { | 943 if (IsContextual(object)) { |
| 944 return ReferenceError("not_defined", name); | 944 return ReferenceError("not_defined", name); |
| 945 } | 945 } |
| 946 LOG(isolate(), SuspectReadEvent(*name, *object)); | 946 LOG(isolate(), SuspectReadEvent(*name, *object)); |
| 947 } | 947 } |
| 948 | 948 |
| (...skipping 247 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1196 // the element or char if so. | 1196 // the element or char if so. |
| 1197 uint32_t index = 0; | 1197 uint32_t index = 0; |
| 1198 if (name->AsArrayIndex(&index)) { | 1198 if (name->AsArrayIndex(&index)) { |
| 1199 HandleScope scope(isolate()); | 1199 HandleScope scope(isolate()); |
| 1200 // Rewrite to the generic keyed load stub. | 1200 // Rewrite to the generic keyed load stub. |
| 1201 if (FLAG_use_ic) set_target(generic_stub()); | 1201 if (FLAG_use_ic) set_target(generic_stub()); |
| 1202 return Runtime::GetElementOrCharAt(isolate(), object, index); | 1202 return Runtime::GetElementOrCharAt(isolate(), object, index); |
| 1203 } | 1203 } |
| 1204 | 1204 |
| 1205 // Named lookup. | 1205 // Named lookup. |
| 1206 LookupResult lookup; | 1206 LookupResult lookup(isolate()); |
| 1207 LookupForRead(*object, *name, &lookup); | 1207 LookupForRead(*object, *name, &lookup); |
| 1208 | 1208 |
| 1209 // If we did not find a property, check if we need to throw an exception. | 1209 // If we did not find a property, check if we need to throw an exception. |
| 1210 if (!lookup.IsProperty() && IsContextual(object)) { | 1210 if (!lookup.IsProperty() && IsContextual(object)) { |
| 1211 return ReferenceError("not_defined", name); | 1211 return ReferenceError("not_defined", name); |
| 1212 } | 1212 } |
| 1213 | 1213 |
| 1214 if (FLAG_use_ic) { | 1214 if (FLAG_use_ic) { |
| 1215 UpdateCaches(&lookup, state, object, name); | 1215 UpdateCaches(&lookup, state, object, name); |
| 1216 } | 1216 } |
| (...skipping 211 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1428 #endif | 1428 #endif |
| 1429 Builtins::Name target = (strict_mode == kStrictMode) | 1429 Builtins::Name target = (strict_mode == kStrictMode) |
| 1430 ? Builtins::kStoreIC_ArrayLength_Strict | 1430 ? Builtins::kStoreIC_ArrayLength_Strict |
| 1431 : Builtins::kStoreIC_ArrayLength; | 1431 : Builtins::kStoreIC_ArrayLength; |
| 1432 set_target(isolate()->builtins()->builtin(target)); | 1432 set_target(isolate()->builtins()->builtin(target)); |
| 1433 return receiver->SetProperty(*name, *value, NONE, strict_mode); | 1433 return receiver->SetProperty(*name, *value, NONE, strict_mode); |
| 1434 } | 1434 } |
| 1435 | 1435 |
| 1436 // Lookup the property locally in the receiver. | 1436 // Lookup the property locally in the receiver. |
| 1437 if (FLAG_use_ic && !receiver->IsJSGlobalProxy()) { | 1437 if (FLAG_use_ic && !receiver->IsJSGlobalProxy()) { |
| 1438 LookupResult lookup; | 1438 LookupResult lookup(isolate()); |
| 1439 | 1439 |
| 1440 if (LookupForWrite(*receiver, *name, &lookup)) { | 1440 if (LookupForWrite(*receiver, *name, &lookup)) { |
| 1441 // Generate a stub for this store. | 1441 // Generate a stub for this store. |
| 1442 UpdateCaches(&lookup, state, strict_mode, receiver, name, value); | 1442 UpdateCaches(&lookup, state, strict_mode, receiver, name, value); |
| 1443 } else { | 1443 } else { |
| 1444 // Strict mode doesn't allow setting non-existent global property | 1444 // Strict mode doesn't allow setting non-existent global property |
| 1445 // or an assignment to a read only property. | 1445 // or an assignment to a read only property. |
| 1446 if (strict_mode == kStrictMode) { | 1446 if (strict_mode == kStrictMode) { |
| 1447 if (lookup.IsFound() && lookup.IsReadOnly()) { | 1447 if (lookup.IsFound() && lookup.IsReadOnly()) { |
| 1448 return TypeError("strict_read_only_property", object, name); | 1448 return TypeError("strict_read_only_property", object, name); |
| (...skipping 393 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1842 // Check if the given name is an array index. | 1842 // Check if the given name is an array index. |
| 1843 uint32_t index; | 1843 uint32_t index; |
| 1844 if (name->AsArrayIndex(&index)) { | 1844 if (name->AsArrayIndex(&index)) { |
| 1845 HandleScope scope(isolate()); | 1845 HandleScope scope(isolate()); |
| 1846 Handle<Object> result = SetElement(receiver, index, value, strict_mode); | 1846 Handle<Object> result = SetElement(receiver, index, value, strict_mode); |
| 1847 if (result.is_null()) return Failure::Exception(); | 1847 if (result.is_null()) return Failure::Exception(); |
| 1848 return *value; | 1848 return *value; |
| 1849 } | 1849 } |
| 1850 | 1850 |
| 1851 // Lookup the property locally in the receiver. | 1851 // Lookup the property locally in the receiver. |
| 1852 LookupResult lookup; | 1852 LookupResult lookup(isolate()); |
| 1853 receiver->LocalLookup(*name, &lookup); | 1853 receiver->LocalLookup(*name, &lookup); |
| 1854 | 1854 |
| 1855 // Update inline cache and stub cache. | 1855 // Update inline cache and stub cache. |
| 1856 if (FLAG_use_ic) { | 1856 if (FLAG_use_ic) { |
| 1857 UpdateCaches(&lookup, state, strict_mode, receiver, name, value); | 1857 UpdateCaches(&lookup, state, strict_mode, receiver, name, value); |
| 1858 } | 1858 } |
| 1859 | 1859 |
| 1860 // Set the property. | 1860 // Set the property. |
| 1861 return receiver->SetProperty(*name, *value, NONE, strict_mode); | 1861 return receiver->SetProperty(*name, *value, NONE, strict_mode); |
| 1862 } | 1862 } |
| (...skipping 749 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2612 #undef ADDR | 2612 #undef ADDR |
| 2613 }; | 2613 }; |
| 2614 | 2614 |
| 2615 | 2615 |
| 2616 Address IC::AddressFromUtilityId(IC::UtilityId id) { | 2616 Address IC::AddressFromUtilityId(IC::UtilityId id) { |
| 2617 return IC_utilities[id]; | 2617 return IC_utilities[id]; |
| 2618 } | 2618 } |
| 2619 | 2619 |
| 2620 | 2620 |
| 2621 } } // namespace v8::internal | 2621 } } // namespace v8::internal |
| OLD | NEW |