diff options
author | darin@chromium.org <darin@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-09-01 20:50:17 +0000 |
---|---|---|
committer | darin@chromium.org <darin@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-09-01 20:50:17 +0000 |
commit | 3125d6467fc6d03e81776fca4228e92dd107e93a (patch) | |
tree | 7a5b154e921fe88291701bc3d67ec577ed0f2c4f /base/base.gyp | |
parent | 40e62b147d083b8e9bb5b42fdb065dd5f654f523 (diff) | |
download | chromium_src-3125d6467fc6d03e81776fca4228e92dd107e93a.zip chromium_src-3125d6467fc6d03e81776fca4228e92dd107e93a.tar.gz chromium_src-3125d6467fc6d03e81776fca4228e92dd107e93a.tar.bz2 |
Add a WeakPtr<T> class.
This allows a class to hand out weak pointers to itself that will be nulled out
automatically when the class instance is destroyed.
I have provided two ways for a class to implement weak pointers. It can either
subclass SupportsWeakPtr (like subclassing RefCounted) or it can be composed of
WeakPtrFactory (like having a ScopedRunnableMethodFactory member).
Eventually, I'd like to make it possible to pass a WeakPtr<T> as the first
parameter to NewRunnableMethod. This will make ScopedRunnableMethodFactory
obsolete and should help cleanup some code.
One feature that makes the implementation here a bit more complicated is that
it is possible to pass a WeakPtr<U> to a method that takes a WeakPtr<T>
provided U "is a" T. This proved useful in RenderView, which can then give
out weak references to both itself as well as to an interface it implements.
This informed the design of WeakPtr, causing it to have a T* ptr_ member
instead of stashing that pointer within the ref counted WeakReference object.
R=brettw
BUG=none
TEST=weak_ptr_unittest.cc
Review URL: http://codereview.chromium.org/183026
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@25087 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'base/base.gyp')
-rw-r--r-- | base/base.gyp | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/base/base.gyp b/base/base.gyp index 3e0503e..6636b53 100644 --- a/base/base.gyp +++ b/base/base.gyp @@ -339,6 +339,7 @@ 'waitable_event_win.cc', 'watchdog.cc', 'watchdog.h', + 'weak_ptr.h', 'win_util.cc', 'win_util.h', 'windows_message_list.h', @@ -643,6 +644,7 @@ 'waitable_event_unittest.cc', 'waitable_event_watcher_unittest.cc', 'watchdog_unittest.cc', + 'weak_ptr_unittest.cc', 'win_util_unittest.cc', 'wmi_util_unittest.cc', 'word_iterator_unittest.cc', |