OLD | NEW |
1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "src/v8.h" | 5 #include "src/v8.h" |
6 | 6 |
7 #include "src/arguments.h" | 7 #include "src/arguments.h" |
8 #include "src/runtime/runtime-utils.h" | 8 #include "src/runtime/runtime-utils.h" |
9 | 9 |
10 | 10 |
(...skipping 27 matching lines...) Expand all Loading... |
38 | 38 |
39 RUNTIME_FUNCTION(Runtime_GenericHash) { | 39 RUNTIME_FUNCTION(Runtime_GenericHash) { |
40 HandleScope scope(isolate); | 40 HandleScope scope(isolate); |
41 DCHECK(args.length() == 1); | 41 DCHECK(args.length() == 1); |
42 CONVERT_ARG_HANDLE_CHECKED(Object, object, 0); | 42 CONVERT_ARG_HANDLE_CHECKED(Object, object, 0); |
43 Handle<Smi> hash = Object::GetOrCreateHash(isolate, object); | 43 Handle<Smi> hash = Object::GetOrCreateHash(isolate, object); |
44 return *hash; | 44 return *hash; |
45 } | 45 } |
46 | 46 |
47 | 47 |
| 48 void Runtime::JSSetInitialize(Isolate* isolate, Handle<JSSet> set) { |
| 49 Handle<OrderedHashSet> table = isolate->factory()->NewOrderedHashSet(); |
| 50 set->set_table(*table); |
| 51 } |
| 52 |
| 53 |
48 RUNTIME_FUNCTION(Runtime_SetInitialize) { | 54 RUNTIME_FUNCTION(Runtime_SetInitialize) { |
49 HandleScope scope(isolate); | 55 HandleScope scope(isolate); |
50 DCHECK(args.length() == 1); | 56 DCHECK(args.length() == 1); |
51 CONVERT_ARG_HANDLE_CHECKED(JSSet, holder, 0); | 57 CONVERT_ARG_HANDLE_CHECKED(JSSet, holder, 0); |
52 Handle<OrderedHashSet> table = isolate->factory()->NewOrderedHashSet(); | 58 Runtime::JSSetInitialize(isolate, holder); |
53 holder->set_table(*table); | |
54 return *holder; | 59 return *holder; |
55 } | 60 } |
56 | 61 |
57 | 62 |
58 RUNTIME_FUNCTION(Runtime_SetGrow) { | 63 RUNTIME_FUNCTION(Runtime_SetGrow) { |
59 HandleScope scope(isolate); | 64 HandleScope scope(isolate); |
60 DCHECK(args.length() == 1); | 65 DCHECK(args.length() == 1); |
61 CONVERT_ARG_HANDLE_CHECKED(JSSet, holder, 0); | 66 CONVERT_ARG_HANDLE_CHECKED(JSSet, holder, 0); |
62 Handle<OrderedHashSet> table(OrderedHashSet::cast(holder->table())); | 67 Handle<OrderedHashSet> table(OrderedHashSet::cast(holder->table())); |
63 table = OrderedHashSet::EnsureGrowable(table); | 68 table = OrderedHashSet::EnsureGrowable(table); |
(...skipping 72 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
136 DCHECK(args.length() == 1); | 141 DCHECK(args.length() == 1); |
137 CONVERT_ARG_HANDLE_CHECKED(JSSetIterator, holder, 0); | 142 CONVERT_ARG_HANDLE_CHECKED(JSSetIterator, holder, 0); |
138 Handle<FixedArray> details = isolate->factory()->NewFixedArray(4); | 143 Handle<FixedArray> details = isolate->factory()->NewFixedArray(4); |
139 details->set(0, isolate->heap()->ToBoolean(holder->HasMore())); | 144 details->set(0, isolate->heap()->ToBoolean(holder->HasMore())); |
140 details->set(1, holder->index()); | 145 details->set(1, holder->index()); |
141 details->set(2, holder->kind()); | 146 details->set(2, holder->kind()); |
142 return *isolate->factory()->NewJSArrayWithElements(details); | 147 return *isolate->factory()->NewJSArrayWithElements(details); |
143 } | 148 } |
144 | 149 |
145 | 150 |
| 151 void Runtime::JSMapInitialize(Isolate* isolate, Handle<JSMap> map) { |
| 152 Handle<OrderedHashMap> table = isolate->factory()->NewOrderedHashMap(); |
| 153 map->set_table(*table); |
| 154 } |
| 155 |
| 156 |
146 RUNTIME_FUNCTION(Runtime_MapInitialize) { | 157 RUNTIME_FUNCTION(Runtime_MapInitialize) { |
147 HandleScope scope(isolate); | 158 HandleScope scope(isolate); |
148 DCHECK(args.length() == 1); | 159 DCHECK(args.length() == 1); |
149 CONVERT_ARG_HANDLE_CHECKED(JSMap, holder, 0); | 160 CONVERT_ARG_HANDLE_CHECKED(JSMap, holder, 0); |
150 Handle<OrderedHashMap> table = isolate->factory()->NewOrderedHashMap(); | 161 Runtime::JSMapInitialize(isolate, holder); |
151 holder->set_table(*table); | |
152 return *holder; | 162 return *holder; |
153 } | 163 } |
154 | 164 |
155 | 165 |
156 RUNTIME_FUNCTION(Runtime_MapShrink) { | 166 RUNTIME_FUNCTION(Runtime_MapShrink) { |
157 HandleScope scope(isolate); | 167 HandleScope scope(isolate); |
158 DCHECK(args.length() == 1); | 168 DCHECK(args.length() == 1); |
159 CONVERT_ARG_HANDLE_CHECKED(JSMap, holder, 0); | 169 CONVERT_ARG_HANDLE_CHECKED(JSMap, holder, 0); |
160 Handle<OrderedHashMap> table(OrderedHashMap::cast(holder->table())); | 170 Handle<OrderedHashMap> table(OrderedHashMap::cast(holder->table())); |
161 table = OrderedHashMap::Shrink(table); | 171 table = OrderedHashMap::Shrink(table); |
(...skipping 253 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
415 | 425 |
416 RUNTIME_FUNCTION(Runtime_ObservationWeakMapCreate) { | 426 RUNTIME_FUNCTION(Runtime_ObservationWeakMapCreate) { |
417 HandleScope scope(isolate); | 427 HandleScope scope(isolate); |
418 DCHECK(args.length() == 0); | 428 DCHECK(args.length() == 0); |
419 Handle<JSWeakMap> weakmap = isolate->factory()->NewJSWeakMap(); | 429 Handle<JSWeakMap> weakmap = isolate->factory()->NewJSWeakMap(); |
420 Runtime::WeakCollectionInitialize(isolate, weakmap); | 430 Runtime::WeakCollectionInitialize(isolate, weakmap); |
421 return *weakmap; | 431 return *weakmap; |
422 } | 432 } |
423 } // namespace internal | 433 } // namespace internal |
424 } // namespace v8 | 434 } // namespace v8 |
OLD | NEW |