Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2016 the V8 project authors. All rights reserved. | 1 // Copyright 2016 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_WASM_MANAGED_H_ | 5 #ifndef V8_WASM_MANAGED_H_ |
| 6 #define V8_WASM_MANAGED_H_ | 6 #define V8_WASM_MANAGED_H_ |
| 7 | 7 |
| 8 #include "src/factory.h" | 8 #include "src/factory.h" |
| 9 #include "src/global-handles.h" | 9 #include "src/global-handles.h" |
| 10 #include "src/handles.h" | 10 #include "src/handles.h" |
| 11 #include "src/isolate.h" | 11 #include "src/isolate.h" |
| 12 #include "src/objects-inl.h" | 12 #include "src/objects-inl.h" |
| 13 | 13 |
| 14 namespace v8 { | 14 namespace v8 { |
| 15 namespace internal { | 15 namespace internal { |
| 16 // An object that wraps a pointer to a C++ object and optionally deletes it | 16 // An object that wraps a pointer to a C++ object and optionally deletes it |
| 17 // when the managed wrapper object is garbage collected. | 17 // when the managed wrapper object is garbage collected. |
| 18 template <class CppType> | 18 template <class CppType> |
| 19 class Managed : public Foreign { | 19 class Managed : public Foreign { |
| 20 public: | 20 public: |
| 21 V8_INLINE CppType* get() { | 21 V8_INLINE CppType* get() { |
| 22 return reinterpret_cast<CppType*>(foreign_address()); | 22 return reinterpret_cast<CppType*>( |
| 23 reinterpret_cast<Isolate::ManagedLifeline*>(foreign_address()) | |
| 24 ->value()); | |
| 23 } | 25 } |
| 24 | 26 |
| 25 static Managed<CppType>* cast(Object* obj) { | 27 static Managed<CppType>* cast(Object* obj) { |
| 26 SLOW_DCHECK(obj->IsForeign()); | 28 SLOW_DCHECK(obj->IsForeign()); |
| 27 return reinterpret_cast<Managed<CppType>*>(obj); | 29 return reinterpret_cast<Managed<CppType>*>(obj); |
| 28 } | 30 } |
| 29 | 31 |
| 30 static Handle<Managed<CppType>> New(Isolate* isolate, CppType* ptr, | 32 static Handle<Managed<CppType>> New(Isolate* isolate, CppType* ptr) { |
| 31 bool delete_on_gc = true) { | 33 Isolate::ManagedLifeline* node = |
| 34 isolate->AddManagedObject(ptr, Managed<CppType>::NativeDelete); | |
| 32 Handle<Managed<CppType>> handle = Handle<Managed<CppType>>::cast( | 35 Handle<Managed<CppType>> handle = Handle<Managed<CppType>>::cast( |
| 33 isolate->factory()->NewForeign(reinterpret_cast<Address>(ptr))); | 36 isolate->factory()->NewForeign(reinterpret_cast<Address>(node))); |
| 34 if (delete_on_gc) { | 37 RegisterWeakCallbackForDelete(isolate, handle); |
| 35 RegisterWeakCallbackForDelete(isolate, handle); | |
| 36 } | |
| 37 return handle; | 38 return handle; |
| 38 } | 39 } |
| 39 | 40 |
| 41 static Handle<Managed<CppType>> NewForTesting(Isolate* isolate, | |
|
titzer
2017/02/08 23:32:48
Do we really need to have a separate constructor f
Mircea Trofin
2017/02/08 23:52:36
Not super convinced of the cleanliness of the case
| |
| 42 CppType* ptr) { | |
| 43 Isolate::ManagedLifeline* node = isolate->AddManagedObject(ptr, nullptr); | |
| 44 Handle<Managed<CppType>> handle = Handle<Managed<CppType>>::cast( | |
| 45 isolate->factory()->NewForeign(reinterpret_cast<Address>(node))); | |
| 46 return handle; | |
| 47 } | |
| 48 | |
| 40 private: | 49 private: |
| 41 static void RegisterWeakCallbackForDelete(Isolate* isolate, | 50 static void RegisterWeakCallbackForDelete(Isolate* isolate, |
| 42 Handle<Managed<CppType>> handle) { | 51 Handle<Managed<CppType>> handle) { |
| 43 Handle<Object> global_handle = isolate->global_handles()->Create(*handle); | 52 Handle<Object> global_handle = isolate->global_handles()->Create(*handle); |
| 44 GlobalHandles::MakeWeak(global_handle.location(), global_handle.location(), | 53 GlobalHandles::MakeWeak(global_handle.location(), global_handle.location(), |
| 45 &Managed<CppType>::Delete, | 54 &Managed<CppType>::GCDelete, |
| 46 v8::WeakCallbackType::kFinalizer); | 55 v8::WeakCallbackType::kFinalizer); |
| 47 } | 56 } |
| 48 static void Delete(const v8::WeakCallbackInfo<void>& data) { | 57 |
| 58 static void GCDelete(const v8::WeakCallbackInfo<void>& data) { | |
| 49 Managed<CppType>** p = | 59 Managed<CppType>** p = |
| 50 reinterpret_cast<Managed<CppType>**>(data.GetParameter()); | 60 reinterpret_cast<Managed<CppType>**>(data.GetParameter()); |
| 51 delete (*p)->get(); | 61 delete ( |
| 62 reinterpret_cast<Isolate::ManagedLifeline*>((*p)->foreign_address())); | |
| 52 (*p)->set_foreign_address(0); | 63 (*p)->set_foreign_address(0); |
| 53 GlobalHandles::Destroy(reinterpret_cast<Object**>(p)); | 64 GlobalHandles::Destroy(reinterpret_cast<Object**>(p)); |
| 54 } | 65 } |
| 66 | |
| 67 static void NativeDelete(void* value) { | |
| 68 CppType* typed_value = reinterpret_cast<CppType*>(value); | |
| 69 delete typed_value; | |
| 70 } | |
| 55 }; | 71 }; |
| 56 } // namespace internal | 72 } // namespace internal |
| 57 } // namespace v8 | 73 } // namespace v8 |
| 58 | 74 |
| 59 #endif // V8_WASM_MANAGED_H_ | 75 #endif // V8_WASM_MANAGED_H_ |
| OLD | NEW |