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

Unified Diff: Source/core/fetch/ResourcePtr.h

Issue 720693002: ResourcePtr refactoring (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: Created 6 years, 1 month 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 | « Source/core/fetch/ResourceFetcherTest.cpp ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: Source/core/fetch/ResourcePtr.h
diff --git a/Source/core/fetch/ResourcePtr.h b/Source/core/fetch/ResourcePtr.h
index e3545ee251b320ff04eafe4838148a9d9bd1fb11..a03782ed3b5ea329bd512c24c04049f0f90b6263 100644
--- a/Source/core/fetch/ResourcePtr.h
+++ b/Source/core/fetch/ResourcePtr.h
@@ -32,27 +32,25 @@ namespace blink {
class ResourcePtrBase {
public:
- ~ResourcePtrBase();
-
Resource* get() const { return m_resource; }
bool operator!() const { return !m_resource; }
- void clear() { setResource(0); }
+ void clear() { setResource(nullptr); }
// This conversion operator allows implicit conversion to bool but not to other integer types.
typedef Resource* ResourcePtrBase::*UnspecifiedBoolType;
- operator UnspecifiedBoolType() const { return m_resource ? &ResourcePtrBase::m_resource : 0; }
+ operator UnspecifiedBoolType() const { return m_resource ? &ResourcePtrBase::m_resource : nullptr; }
protected:
- ResourcePtrBase() : m_resource(0) { }
- ResourcePtrBase(Resource*);
- ResourcePtrBase(const ResourcePtrBase&);
+ ResourcePtrBase() : m_resource(nullptr) { }
+ explicit ResourcePtrBase(Resource*);
+ explicit ResourcePtrBase(const ResourcePtrBase&);
+ ~ResourcePtrBase();
void setResource(Resource*);
private:
- ResourcePtrBase& operator=(const ResourcePtrBase&) { return *this; }
-
friend class Resource;
+ ResourcePtrBase& operator=(const ResourcePtrBase&) = delete;
Nate Chapin 2014/11/12 17:31:28 I'm not familiar with this syntax, I assume it's n
dcheng 2014/11/12 18:31:15 It's an error to call a deleted function, so this
Resource* m_resource;
};
@@ -77,19 +75,19 @@ inline ResourcePtrBase::ResourcePtrBase(const ResourcePtrBase& o)
m_resource->registerHandle(this);
}
-template <class R> class ResourcePtr : public ResourcePtrBase {
+template <class R> class ResourcePtr final : public ResourcePtrBase {
public:
ResourcePtr() { }
ResourcePtr(R* res) : ResourcePtrBase(res) { }
ResourcePtr(const ResourcePtr<R>& o) : ResourcePtrBase(o) { }
- template<typename U> ResourcePtr(const ResourcePtr<U>& o) : ResourcePtrBase(o.get()) { }
+ template<typename U> ResourcePtr(const ResourcePtr<U>& o) : ResourcePtr(o.get()) { }
- R* get() const { return reinterpret_cast<R*>(ResourcePtrBase::get()); }
+ R* get() const { return static_cast<R*>(ResourcePtrBase::get()); }
R* operator->() const { return get(); }
ResourcePtr& operator=(R* res) { setResource(res); return *this; }
ResourcePtr& operator=(const ResourcePtr& o) { setResource(o.get()); return *this; }
- template<typename U> ResourcePtr& operator=(const ResourcePtr<U>& o) { setResource(o.get()); return *this; }
+ template<typename U> ResourcePtr& operator=(const ResourcePtr<U>& o) { R* r = o.get(); setResource(r); return *this; }
bool operator==(const ResourcePtrBase& o) const { return get() == o.get(); }
bool operator!=(const ResourcePtrBase& o) const { return get() != o.get(); }
« no previous file with comments | « Source/core/fetch/ResourceFetcherTest.cpp ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698