Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 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 15071 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 15082 INLINE_FUNCTION_LIST(I) | 15082 INLINE_FUNCTION_LIST(I) |
| 15083 INLINE_OPTIMIZED_FUNCTION_LIST(IO) | 15083 INLINE_OPTIMIZED_FUNCTION_LIST(IO) |
| 15084 }; | 15084 }; |
| 15085 | 15085 |
| 15086 #undef IO | 15086 #undef IO |
| 15087 #undef I | 15087 #undef I |
| 15088 #undef FH | 15088 #undef FH |
| 15089 #undef F | 15089 #undef F |
| 15090 | 15090 |
| 15091 | 15091 |
| 15092 MaybeObject* Runtime::InitializeIntrinsicFunctionNames(Heap* heap, | 15092 Handle<NameDictionary> Runtime::InitializeIntrinsicFunctionNames( |
| 15093 Object* dictionary) { | 15093 Isolate* isolate, Handle<NameDictionary> dict) { |
| 15094 ASSERT(dictionary != NULL); | 15094 ASSERT(dict->NumberOfElements() == 0); |
| 15095 ASSERT(NameDictionary::cast(dictionary)->NumberOfElements() == 0); | 15095 ASSERT(dict->Capacity() == kNumFunctions); |
| 15096 for (int i = 0; i < kNumFunctions; ++i) { | 15096 for (int i = 0; i < kNumFunctions; ++i) { |
| 15097 HandleScope scope(isolate); | |
|
Michael Starzinger
2014/04/14 11:10:50
Do we need this handle scope at all? If yes, then
| |
| 15097 const char* name = kIntrinsicFunctions[i].name; | 15098 const char* name = kIntrinsicFunctions[i].name; |
| 15098 if (name == NULL) continue; | 15099 if (name == NULL) continue; |
| 15099 Object* name_string; | 15100 Handle<NameDictionary> new_dict = NameDictionary::Add( |
| 15100 { MaybeObject* maybe_name_string = | 15101 dict, |
| 15101 heap->InternalizeUtf8String(name); | 15102 isolate->factory()->InternalizeUtf8String(name), |
| 15102 if (!maybe_name_string->ToObject(&name_string)) return maybe_name_string; | 15103 Handle<Smi>(Smi::FromInt(i), isolate), |
| 15103 } | 15104 PropertyDetails(NONE, NORMAL, Representation::None())); |
| 15104 NameDictionary* name_dictionary = NameDictionary::cast(dictionary); | 15105 // The dictionary does not need to grow. |
| 15105 { MaybeObject* maybe_dictionary = name_dictionary->Add( | 15106 ASSERT(new_dict.is_identical_to(dict)); |
| 15106 String::cast(name_string), | 15107 USE(new_dict); |
| 15107 Smi::FromInt(i), | |
| 15108 PropertyDetails(NONE, NORMAL, Representation::None())); | |
| 15109 if (!maybe_dictionary->ToObject(&dictionary)) { | |
| 15110 // Non-recoverable failure. Calling code must restart heap | |
| 15111 // initialization. | |
| 15112 return maybe_dictionary; | |
| 15113 } | |
| 15114 } | |
| 15115 } | 15108 } |
| 15116 return dictionary; | 15109 return dict; |
| 15117 } | 15110 } |
| 15118 | 15111 |
| 15119 | 15112 |
| 15120 const Runtime::Function* Runtime::FunctionForName(Handle<String> name) { | 15113 const Runtime::Function* Runtime::FunctionForName(Handle<String> name) { |
| 15121 Heap* heap = name->GetHeap(); | 15114 Heap* heap = name->GetHeap(); |
| 15122 int entry = heap->intrinsic_function_names()->FindEntry(*name); | 15115 int entry = heap->intrinsic_function_names()->FindEntry(*name); |
| 15123 if (entry != kNotFound) { | 15116 if (entry != kNotFound) { |
| 15124 Object* smi_index = heap->intrinsic_function_names()->ValueAt(entry); | 15117 Object* smi_index = heap->intrinsic_function_names()->ValueAt(entry); |
| 15125 int function_index = Smi::cast(smi_index)->value(); | 15118 int function_index = Smi::cast(smi_index)->value(); |
| 15126 return &(kIntrinsicFunctions[function_index]); | 15119 return &(kIntrinsicFunctions[function_index]); |
| (...skipping 27 matching lines...) Expand all Loading... | |
| 15154 } | 15147 } |
| 15155 } | 15148 } |
| 15156 | 15149 |
| 15157 | 15150 |
| 15158 void Runtime::OutOfMemory() { | 15151 void Runtime::OutOfMemory() { |
| 15159 Heap::FatalProcessOutOfMemory("CALL_AND_RETRY_LAST", true); | 15152 Heap::FatalProcessOutOfMemory("CALL_AND_RETRY_LAST", true); |
| 15160 UNREACHABLE(); | 15153 UNREACHABLE(); |
| 15161 } | 15154 } |
| 15162 | 15155 |
| 15163 } } // namespace v8::internal | 15156 } } // namespace v8::internal |
| OLD | NEW |