Panda3D
Loading...
Searching...
No Matches
cachedTypedWritableReferenceCount.h
Go to the documentation of this file.
1/**
2 * PANDA 3D SOFTWARE
3 * Copyright (c) Carnegie Mellon University. All rights reserved.
4 *
5 * All use of this software is subject to the terms of the revised BSD
6 * license. You should have received a copy of this license along
7 * with this source code in a file named "LICENSE."
8 *
9 * @file cachedTypedWritableReferenceCount.h
10 * @author drose
11 * @date 2005-01-25
12 */
13
14#ifndef CACHEDTYPEDWRITABLEREFERENCECOUNT_H
15#define CACHEDTYPEDWRITABLEREFERENCECOUNT_H
16
17#include "pandabase.h"
18
20
21/**
22 * This is a special extension to ReferenceCount that includes dual reference
23 * counts: the standard reference count number, which includes all references
24 * to the object, and a separate number (the cache reference count) that
25 * counts the number of references to the object just within its cache alone.
26 * When get_ref_count() == get_cache_ref_count(), the object is not referenced
27 * outside the cache.
28 *
29 * The cache refs must be explicitly maintained; there is no PointerTo<> class
30 * to maintain the cache reference counts automatically. The cache reference
31 * count is automatically included in the overall reference count: calling
32 * cache_ref() and cache_unref() automatically calls ref() and unref().
33 */
34class EXPCL_PANDA_PUTIL CachedTypedWritableReferenceCount : public TypedWritableReferenceCount {
35protected:
36 INLINE CachedTypedWritableReferenceCount();
37 INLINE CachedTypedWritableReferenceCount(const CachedTypedWritableReferenceCount &copy);
38 INLINE void operator = (const CachedTypedWritableReferenceCount &copy);
39 INLINE ~CachedTypedWritableReferenceCount();
40
41PUBLISHED:
42 INLINE int get_cache_ref_count() const;
43 INLINE void cache_ref() const;
44 INLINE bool cache_unref() const;
45 INLINE bool test_ref_count_integrity() const;
46
47 MAKE_PROPERTY(cache_ref_count, get_cache_ref_count);
48
49public:
50 INLINE void cache_ref_only() const;
51
52protected:
53 INLINE void cache_unref_only() const;
54 bool do_test_ref_count_integrity() const;
55
56private:
57 mutable AtomicAdjust::Integer _cache_ref_count;
58
59public:
60 static TypeHandle get_class_type() {
61 return _type_handle;
62 }
63
64 static void init_type() {
65 TypedWritableReferenceCount::init_type();
66 register_type(_type_handle, "CachedTypedWritableReferenceCount",
67 TypedWritableReferenceCount::get_class_type());
68 }
69
70private:
71 static TypeHandle _type_handle;
72};
73
74template<class RefCountType>
75INLINE void cache_unref_delete(RefCountType *ptr);
76
78
79#endif
PANDA 3D SOFTWARE Copyright (c) Carnegie Mellon University.
void cache_unref_delete(RefCountType *ptr)
This global helper function will unref the given ReferenceCount object, and if the reference count re...
void cache_ref() const
Explicitly increments the cache reference count and the normal reference count simultaneously.
bool cache_unref() const
Explicitly decrements the cache reference count and the normal reference count simultaneously.
get_cache_ref_count
Returns the current reference count.
void cache_ref_only() const
Decrements the cache reference count without affecting the normal reference count.
bool test_ref_count_integrity() const
Does some easy checks to make sure that the reference count isn't completely bogus.
TypeHandle is the identifier used to differentiate C++ class types.
Definition typeHandle.h:81
PANDA 3D SOFTWARE Copyright (c) Carnegie Mellon University.
void register_type(TypeHandle &type_handle, const std::string &name)
This inline function is just a convenient way to call TypeRegistry::register_type(),...
PANDA 3D SOFTWARE Copyright (c) Carnegie Mellon University.