Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(228)

Unified Diff: third_party/WebKit/Source/platform/heap/Handle.h

Issue 1397073002: [Oilpan] Create UnsafePtr to store on-heap pointers in Vector (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Drop unnecessary parts Created 5 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « third_party/WebKit/Source/core/frame/LocalFrame.cpp ('k') | third_party/WebKit/Source/platform/heap/Heap.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: third_party/WebKit/Source/platform/heap/Handle.h
diff --git a/third_party/WebKit/Source/platform/heap/Handle.h b/third_party/WebKit/Source/platform/heap/Handle.h
index fd9415a02382af0ad0f35457dd7285cb41c122fa..b9072d14380fcc5e14e679499aa977e96dd2a547 100644
--- a/third_party/WebKit/Source/platform/heap/Handle.h
+++ b/third_party/WebKit/Source/platform/heap/Handle.h
@@ -869,15 +869,43 @@ private:
template<typename Derived> friend class VisitorHelper;
};
-// Comparison operators between (Weak)Members and Persistents
+// UntracedMember is actually a raw pointer.
+// It is allowed to store a pointer to an object on oilpan heap,
+// and it is also allowed to store UntracedMember in off heap collections.
+// UntracedMember does not keep the pointee object alive, so if you use
+// UntracedMember, you must guarantee that the pointee object is alive in
+// some reason.
haraken 2015/10/15 05:26:08 // UntracedMember is a pointer to an on-heap objec
peria 2015/10/15 06:03:43 Done. Thank you for this description.
+template<typename T>
+class UntracedMember : public Member<T> {
haraken 2015/10/15 05:26:08 Add final.
peria 2015/10/15 06:03:43 Done.
+public:
+ UntracedMember() : Member<T>() { }
+
+ UntracedMember(std::nullptr_t) : Member<T>(nullptr) { }
+
+ UntracedMember(T* raw) : Member<T>(raw) { }
+
+ template<typename U>
+ UntracedMember(const RawPtr<U>& other) : Member<T>(other) { }
+
+ template<typename U>
+ UntracedMember(const Persistent<U>& other) : Member<T>(other) { }
+
+ template<typename U>
+ UntracedMember(const Member<U>& other) : Member<T>(other) { }
+
+ UntracedMember(WTF::HashTableDeletedValueType x) : Member<T>(x) { }
haraken 2015/10/15 05:26:08 Also implement operator=, just like WeakMember's o
peria 2015/10/15 06:03:43 Done.
+};
+
+// Comparison operators between (Weak)Members, Persistents, and UntracedMembers.
template<typename T, typename U> inline bool operator==(const Member<T>& a, const Member<U>& b) { return a.get() == b.get(); }
template<typename T, typename U> inline bool operator!=(const Member<T>& a, const Member<U>& b) { return a.get() != b.get(); }
+template<typename T, typename U> inline bool operator==(const Persistent<T>& a, const Persistent<U>& b) { return a.get() == b.get(); }
+template<typename T, typename U> inline bool operator!=(const Persistent<T>& a, const Persistent<U>& b) { return a.get() != b.get(); }
+
template<typename T, typename U> inline bool operator==(const Member<T>& a, const Persistent<U>& b) { return a.get() == b.get(); }
template<typename T, typename U> inline bool operator!=(const Member<T>& a, const Persistent<U>& b) { return a.get() != b.get(); }
template<typename T, typename U> inline bool operator==(const Persistent<T>& a, const Member<U>& b) { return a.get() == b.get(); }
template<typename T, typename U> inline bool operator!=(const Persistent<T>& a, const Member<U>& b) { return a.get() != b.get(); }
-template<typename T, typename U> inline bool operator==(const Persistent<T>& a, const Persistent<U>& b) { return a.get() == b.get(); }
-template<typename T, typename U> inline bool operator!=(const Persistent<T>& a, const Persistent<U>& b) { return a.get() != b.get(); }
template<typename T>
class DummyBase {
@@ -925,6 +953,7 @@ public:
#define RawPtrWillBePersistent blink::Persistent
#define RawPtrWillBeWeakMember blink::WeakMember
#define RawPtrWillBeWeakPersistent blink::WeakPersistent
+#define RawPtrWillBeUntracedMember blink::UntracedMember
#define OwnPtrWillBeCrossThreadPersistent blink::CrossThreadPersistent
#define OwnPtrWillBeMember blink::Member
#define OwnPtrWillBePersistent blink::Persistent
@@ -1008,6 +1037,7 @@ template<typename T> T* adoptPtrWillBeNoop(T* ptr)
#define RawPtrWillBePersistent WTF::RawPtr
#define RawPtrWillBeWeakMember WTF::RawPtr
#define RawPtrWillBeWeakPersistent WTF::RawPtr
+#define RawPtrWillBeUntracedMember WTF::RawPtr
#define OwnPtrWillBeCrossThreadPersistent WTF::OwnPtr
#define OwnPtrWillBeMember WTF::OwnPtr
#define OwnPtrWillBePersistent WTF::OwnPtr
@@ -1198,6 +1228,13 @@ template <typename T> struct VectorTraits<blink::WeakMember<T>> : VectorTraitsBa
static const bool canMoveWithMemcpy = true;
};
+template <typename T> struct VectorTraits<blink::UntracedMember<T>> : VectorTraitsBase<blink::UntracedMember<T>> {
+ static const bool needsDestruction = false;
+ static const bool canInitializeWithMemset = true;
+ static const bool canClearUnusedSlotsWithMemset = true;
+ static const bool canMoveWithMemcpy = true;
+};
+
template <typename T> struct VectorTraits<blink::HeapVector<T, 0>> : VectorTraitsBase<blink::HeapVector<T, 0>> {
static const bool needsDestruction = false;
static const bool canInitializeWithMemset = true;
@@ -1289,6 +1326,32 @@ template<typename T> struct HashTraits<blink::WeakMember<T>> : SimpleClassHashTr
}
};
+template<typename T> struct HashTraits<blink::UntracedMember<T>> : SimpleClassHashTraits<blink::UntracedMember<T>> {
+ static const bool needsDestruction = false;
+ // FIXME: The distinction between PeekInType and PassInType is there for
+ // the sake of the reference counting handles. When they are gone the two
+ // types can be merged into PassInType.
+ // FIXME: Implement proper const'ness for iterator types.
+ using PeekInType = RawPtr<T>;
+ using PassInType = RawPtr<T>;
+ using IteratorGetType = blink::UntracedMember<T>*;
+ using IteratorConstGetType = const blink::UntracedMember<T>*;
+ using IteratorReferenceType = blink::UntracedMember<T>&;
+ using IteratorConstReferenceType = const blink::UntracedMember<T>&;
+ static IteratorReferenceType getToReferenceConversion(IteratorGetType x) { return *x; }
+ static IteratorConstReferenceType getToReferenceConstConversion(IteratorConstGetType x) { return *x; }
+ // FIXME: Similarly, there is no need for a distinction between PeekOutType
+ // and PassOutType without reference counting.
+ using PeekOutType = T*;
+ using PassOutType = T*;
+
+ template<typename U>
+ static void store(const U& value, blink::UntracedMember<T>& storage) { storage = value; }
+
+ static PeekOutType peek(const blink::UntracedMember<T>& value) { return value; }
+ static PassOutType passOut(const blink::UntracedMember<T>& value) { return value; }
+};
+
template<typename T> struct PtrHash<blink::Member<T>> : PtrHash<T*> {
template<typename U>
static unsigned hash(const U& key) { return PtrHash<T*>::hash(key); }
@@ -1301,6 +1364,9 @@ template<typename T> struct PtrHash<blink::Member<T>> : PtrHash<T*> {
template<typename T> struct PtrHash<blink::WeakMember<T>> : PtrHash<blink::Member<T>> {
};
+template<typename T> struct PtrHash<blink::UntracedMember<T>> : PtrHash<blink::Member<T>> {
+};
+
// PtrHash is the default hash for hash tables with members.
template<typename T> struct DefaultHash<blink::Member<T>> {
using Hash = PtrHash<blink::Member<T>>;
@@ -1310,6 +1376,10 @@ template<typename T> struct DefaultHash<blink::WeakMember<T>> {
using Hash = PtrHash<blink::WeakMember<T>>;
};
+template<typename T> struct DefaultHash<blink::UntracedMember<T>> {
+ using Hash = PtrHash<blink::UntracedMember<T>>;
+};
+
template<typename T>
struct NeedsTracing<blink::Member<T>> {
static const bool value = true;
« no previous file with comments | « third_party/WebKit/Source/core/frame/LocalFrame.cpp ('k') | third_party/WebKit/Source/platform/heap/Heap.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698