OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright (C) 2009, 2010 Apple Inc. All rights reserved. | 2 * Copyright (C) 2009, 2010 Apple Inc. All rights reserved. |
3 * Copyright (C) 2013 Intel Corporation. All rights reserved. | 3 * Copyright (C) 2013 Intel Corporation. All rights reserved. |
4 * | 4 * |
5 * Redistribution and use in source and binary forms, with or without | 5 * Redistribution and use in source and binary forms, with or without |
6 * modification, are permitted provided that the following conditions | 6 * modification, are permitted provided that the following conditions |
7 * are met: | 7 * are met: |
8 * 1. Redistributions of source code must retain the above copyright | 8 * 1. Redistributions of source code must retain the above copyright |
9 * notice, this list of conditions and the following disclaimer. | 9 * notice, this list of conditions and the following disclaimer. |
10 * 2. Redistributions in binary form must reproduce the above copyright | 10 * 2. Redistributions in binary form must reproduce the above copyright |
(...skipping 29 matching lines...) Expand all Loading... | |
40 | 40 |
41 template <typename T> class PassOwnPtr { | 41 template <typename T> class PassOwnPtr { |
42 DISALLOW_NEW(); | 42 DISALLOW_NEW(); |
43 public: | 43 public: |
44 typedef typename std::remove_extent<T>::type ValueType; | 44 typedef typename std::remove_extent<T>::type ValueType; |
45 typedef ValueType* PtrType; | 45 typedef ValueType* PtrType; |
46 | 46 |
47 PassOwnPtr() : m_ptr(nullptr) {} | 47 PassOwnPtr() : m_ptr(nullptr) {} |
48 PassOwnPtr(std::nullptr_t) : m_ptr(nullptr) {} | 48 PassOwnPtr(std::nullptr_t) : m_ptr(nullptr) {} |
49 | 49 |
50 // It somewhat breaks the type system to allow transfer of ownership out of | 50 // It somewhat breaks the type system to allow transfer of ownership out of |
Mikhail
2016/04/27 09:57:10
Now this comment looks outdated.
Yuta Kitamura
2016/04/27 10:10:35
You are right; removed.
| |
51 // a const PassOwnPtr. However, it makes it much easier to work with | 51 // a const PassOwnPtr. However, it makes it much easier to work with |
52 // PassOwnPtr temporaries, and we don't have a need to use real const | 52 // PassOwnPtr temporaries, and we don't have a need to use real const |
53 // PassOwnPtrs anyway. | 53 // PassOwnPtrs anyway. |
54 PassOwnPtr(const PassOwnPtr& o) : m_ptr(o.leakPtr()) {} | 54 PassOwnPtr(PassOwnPtr&& o) : m_ptr(o.leakPtr()) {} |
55 template <typename U> PassOwnPtr(const PassOwnPtr<U>&, EnsurePtrConvertibleA rgDecl(U, T)); | 55 template <typename U> PassOwnPtr(PassOwnPtr<U>&&, EnsurePtrConvertibleArgDec l(U, T)); |
56 | 56 |
57 ~PassOwnPtr() { OwnedPtrDeleter<T>::deletePtr(m_ptr); } | 57 ~PassOwnPtr() { OwnedPtrDeleter<T>::deletePtr(m_ptr); } |
58 | 58 |
59 PtrType get() const { return m_ptr; } | 59 PtrType get() const { return m_ptr; } |
60 | 60 |
61 PtrType leakPtr() const WARN_UNUSED_RETURN; | 61 PtrType leakPtr() const WARN_UNUSED_RETURN; |
62 | 62 |
63 ValueType& operator*() const { ASSERT(m_ptr); return *m_ptr; } | 63 ValueType& operator*() const { ASSERT(m_ptr); return *m_ptr; } |
64 PtrType operator->() const { ASSERT(m_ptr); return m_ptr; } | 64 PtrType operator->() const { ASSERT(m_ptr); return m_ptr; } |
65 | 65 |
66 bool operator!() const { return !m_ptr; } | 66 bool operator!() const { return !m_ptr; } |
67 explicit operator bool() const { return m_ptr; } | 67 explicit operator bool() const { return m_ptr; } |
68 | 68 |
69 template <typename U> friend PassOwnPtr<U> adoptPtr(U*); | 69 template <typename U> friend PassOwnPtr<U> adoptPtr(U*); |
70 template <typename U> friend PassOwnPtr<U[]> adoptArrayPtr(U*); | 70 template <typename U> friend PassOwnPtr<U[]> adoptArrayPtr(U*); |
71 template <typename U> friend class OwnPtr; | 71 template <typename U> friend class OwnPtr; |
72 | 72 |
73 private: | 73 private: |
74 explicit PassOwnPtr(PtrType ptr) : m_ptr(ptr) {} | 74 explicit PassOwnPtr(PtrType ptr) : m_ptr(ptr) {} |
75 | 75 |
76 PassOwnPtr(const PassOwnPtr&) = delete; | |
76 PassOwnPtr& operator=(const PassOwnPtr&) = delete; | 77 PassOwnPtr& operator=(const PassOwnPtr&) = delete; |
77 | 78 |
78 // We should never have two OwnPtrs for the same underlying object | 79 // We should never have two OwnPtrs for the same underlying object |
79 // (otherwise we'll get double-destruction), so these equality operators | 80 // (otherwise we'll get double-destruction), so these equality operators |
80 // should never be needed. | 81 // should never be needed. |
81 template <typename U> bool operator==(const PassOwnPtr<U>&) const = delete; | 82 template <typename U> bool operator==(const PassOwnPtr<U>&) const = delete; |
82 template <typename U> bool operator!=(const PassOwnPtr<U>&) const = delete; | 83 template <typename U> bool operator!=(const PassOwnPtr<U>&) const = delete; |
83 template <typename U> bool operator==(const OwnPtr<U>&) const = delete; | 84 template <typename U> bool operator==(const OwnPtr<U>&) const = delete; |
84 template <typename U> bool operator!=(const OwnPtr<U>&) const = delete; | 85 template <typename U> bool operator!=(const OwnPtr<U>&) const = delete; |
85 | 86 |
86 mutable PtrType m_ptr; | 87 mutable PtrType m_ptr; |
tzik
2016/04/27 09:40:14
Can we remove this "mutable" now?
Yuta Kitamura
2016/04/27 10:10:35
Yep, but removing this "mutable" has caused an err
| |
87 }; | 88 }; |
88 | 89 |
89 template <typename T> | 90 template <typename T> |
90 template <typename U> inline PassOwnPtr<T>::PassOwnPtr(const PassOwnPtr<U>& o, E nsurePtrConvertibleArgDefn(U, T)) | 91 template <typename U> inline PassOwnPtr<T>::PassOwnPtr(PassOwnPtr<U>&& o, Ensure PtrConvertibleArgDefn(U, T)) |
91 : m_ptr(o.leakPtr()) | 92 : m_ptr(o.leakPtr()) |
92 { | 93 { |
93 static_assert(!std::is_array<T>::value, "pointers to array must never be con verted"); | 94 static_assert(!std::is_array<T>::value, "pointers to array must never be con verted"); |
94 } | 95 } |
95 | 96 |
96 template <typename T> inline typename PassOwnPtr<T>::PtrType PassOwnPtr<T>::leak Ptr() const | 97 template <typename T> inline typename PassOwnPtr<T>::PtrType PassOwnPtr<T>::leak Ptr() const |
97 { | 98 { |
98 PtrType ptr = m_ptr; | 99 PtrType ptr = m_ptr; |
99 m_ptr = nullptr; | 100 m_ptr = nullptr; |
100 return ptr; | 101 return ptr; |
(...skipping 22 matching lines...) Expand all Loading... | |
123 template <typename T> inline PassOwnPtr<T> adoptPtr(T* ptr) | 124 template <typename T> inline PassOwnPtr<T> adoptPtr(T* ptr) |
124 { | 125 { |
125 return PassOwnPtr<T>(ptr); | 126 return PassOwnPtr<T>(ptr); |
126 } | 127 } |
127 | 128 |
128 template <typename T> inline PassOwnPtr<T[]> adoptArrayPtr(T* ptr) | 129 template <typename T> inline PassOwnPtr<T[]> adoptArrayPtr(T* ptr) |
129 { | 130 { |
130 return PassOwnPtr<T[]>(ptr); | 131 return PassOwnPtr<T[]>(ptr); |
131 } | 132 } |
132 | 133 |
133 template <typename T, typename U> inline PassOwnPtr<T> static_pointer_cast(const PassOwnPtr<U>& p) | 134 template <typename T, typename U> inline PassOwnPtr<T> static_pointer_cast(PassO wnPtr<U>&& p) |
134 { | 135 { |
135 static_assert(!std::is_array<T>::value, "pointers to array must never be con verted"); | 136 static_assert(!std::is_array<T>::value, "pointers to array must never be con verted"); |
136 return adoptPtr(static_cast<T*>(p.leakPtr())); | 137 return adoptPtr(static_cast<T*>(p.leakPtr())); |
137 } | 138 } |
138 | 139 |
139 template <typename T> inline T* getPtr(const PassOwnPtr<T>& p) | 140 template <typename T> inline T* getPtr(const PassOwnPtr<T>& p) |
140 { | 141 { |
141 return p.get(); | 142 return p.get(); |
142 } | 143 } |
143 | 144 |
144 } // namespace WTF | 145 } // namespace WTF |
145 | 146 |
146 using WTF::PassOwnPtr; | 147 using WTF::PassOwnPtr; |
147 using WTF::adoptPtr; | 148 using WTF::adoptPtr; |
148 using WTF::adoptArrayPtr; | 149 using WTF::adoptArrayPtr; |
149 using WTF::static_pointer_cast; | 150 using WTF::static_pointer_cast; |
150 | 151 |
151 #endif // WTF_PassOwnPtr_h | 152 #endif // WTF_PassOwnPtr_h |
OLD | NEW |