summaryrefslogtreecommitdiff
path: root/include/utils/RefBase.h
diff options
context:
space:
mode:
author Mathias Agopian <mathias@google.com> 2011-06-12 18:05:53 -0700
committer Mathias Agopian <mathias@google.com> 2011-06-13 18:39:45 -0700
commiteb99f0d9f05dd37f988a815e6bc01bbd7152c31a (patch)
treeeab0217d74f5887e680f0dbc57aca49acba2913a /include/utils/RefBase.h
parenta934219ca8d23a63e5a9f443fafd6d4ac9847c71 (diff)
fix RefBase so it retains binary-compatibility with gingerbread
Bug: 4595257 Change-Id: I0d5e10f497e3f39868bff58f6ded510c38b44b12
Diffstat (limited to 'include/utils/RefBase.h')
-rw-r--r--include/utils/RefBase.h20
1 files changed, 13 insertions, 7 deletions
diff --git a/include/utils/RefBase.h b/include/utils/RefBase.h
index 412622596c85..f8c3216b4618 100644
--- a/include/utils/RefBase.h
+++ b/include/utils/RefBase.h
@@ -116,16 +116,22 @@ public:
typedef RefBase basetype;
-protected:
- RefBase();
- virtual ~RefBase();
+ // used to override the RefBase destruction.
+ class Destroyer {
+ friend class RefBase;
+ public:
+ virtual ~Destroyer();
+ private:
+ virtual void destroy(RefBase const* base) = 0;
+ };
- // called when the last reference goes away. this is responsible for
- // calling the destructor. The default implementation just does
- // "delete this;".
// Make sure to never acquire a strong reference from this function. The
// same restrictions than for destructors apply.
- virtual void destroy() const;
+ void setDestroyer(Destroyer* destroyer);
+
+protected:
+ RefBase();
+ virtual ~RefBase();
//! Flags for extendObjectLifetime()
enum {