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 // 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 #ifndef V8_OBJECTS_VISITING_INL_H_ | 5 #ifndef V8_OBJECTS_VISITING_INL_H_ |
| 6 #define V8_OBJECTS_VISITING_INL_H_ | 6 #define V8_OBJECTS_VISITING_INL_H_ |
| 7 | 7 |
| 8 | 8 |
| 9 namespace v8 { | 9 namespace v8 { |
| 10 namespace internal { | 10 namespace internal { |
| (...skipping 340 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 351 } | 351 } |
| 352 | 352 |
| 353 | 353 |
| 354 template <typename StaticVisitor> | 354 template <typename StaticVisitor> |
| 355 void StaticMarkingVisitor<StaticVisitor>::VisitWeakCell(Map* map, | 355 void StaticMarkingVisitor<StaticVisitor>::VisitWeakCell(Map* map, |
| 356 HeapObject* object) { | 356 HeapObject* object) { |
| 357 Heap* heap = map->GetHeap(); | 357 Heap* heap = map->GetHeap(); |
| 358 WeakCell* weak_cell = reinterpret_cast<WeakCell*>(object); | 358 WeakCell* weak_cell = reinterpret_cast<WeakCell*>(object); |
| 359 Object* undefined = heap->undefined_value(); | 359 Object* undefined = heap->undefined_value(); |
| 360 // Enqueue weak cell in linked list of encountered weak collections. | 360 // Enqueue weak cell in linked list of encountered weak collections. |
| 361 // We can ignore weak cells with cleared values because they will always point | 361 // We can ignore weak cells with cleared values because they will always |
| 362 // to the undefined_value. | 362 // contain smi zero. |
| 363 if (weak_cell->next() == undefined && weak_cell->value() != undefined) { | 363 if (weak_cell->next() == undefined && !weak_cell->cleared()) { |
|
Erik Corry Chromium.org
2014/10/20 08:00:18
Perhaps this should just check for Sminess instead
ulan
2014/10/20 12:30:18
Since the initialization function of the weak cell
| |
| 364 weak_cell->set_next(heap->encountered_weak_cells()); | 364 weak_cell->set_next(heap->encountered_weak_cells()); |
| 365 heap->set_encountered_weak_cells(weak_cell); | 365 heap->set_encountered_weak_cells(weak_cell); |
| 366 } | 366 } |
| 367 } | 367 } |
| 368 | 368 |
| 369 | 369 |
| 370 template <typename StaticVisitor> | 370 template <typename StaticVisitor> |
| 371 void StaticMarkingVisitor<StaticVisitor>::VisitAllocationSite( | 371 void StaticMarkingVisitor<StaticVisitor>::VisitAllocationSite( |
| 372 Map* map, HeapObject* object) { | 372 Map* map, HeapObject* object) { |
| 373 Heap* heap = map->GetHeap(); | 373 Heap* heap = map->GetHeap(); |
| (...skipping 569 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 943 | 943 |
| 944 RelocIterator it(this, mode_mask); | 944 RelocIterator it(this, mode_mask); |
| 945 for (; !it.done(); it.next()) { | 945 for (; !it.done(); it.next()) { |
| 946 it.rinfo()->template Visit<StaticVisitor>(heap); | 946 it.rinfo()->template Visit<StaticVisitor>(heap); |
| 947 } | 947 } |
| 948 } | 948 } |
| 949 } | 949 } |
| 950 } // namespace v8::internal | 950 } // namespace v8::internal |
| 951 | 951 |
| 952 #endif // V8_OBJECTS_VISITING_INL_H_ | 952 #endif // V8_OBJECTS_VISITING_INL_H_ |
| OLD | NEW |