diff options
Diffstat (limited to 'libodb/odb/details/shared-ptr/base.ixx')
-rw-r--r-- | libodb/odb/details/shared-ptr/base.ixx | 119 |
1 files changed, 119 insertions, 0 deletions
diff --git a/libodb/odb/details/shared-ptr/base.ixx b/libodb/odb/details/shared-ptr/base.ixx new file mode 100644 index 0000000..1e2fd4b --- /dev/null +++ b/libodb/odb/details/shared-ptr/base.ixx @@ -0,0 +1,119 @@ +// file : odb/details/shared-ptr/base.ixx +// license : GNU GPL v2; see accompanying LICENSE file + +namespace odb +{ + namespace details + { + // share + // + + inline share:: + share (char id) + : id_ (id) + { + } + + inline bool share:: + operator== (share x) const + { + return id_ == x.id_; + } + + // shared_base + // + + inline shared_base:: + shared_base () + : counter_ (1), callback_ (0) + { + } + + inline shared_base:: + shared_base (const shared_base&) + : counter_ (1), callback_ (0) + { + } + + inline shared_base& shared_base:: + operator= (const shared_base&) + { + return *this; + } + + inline void shared_base:: + _inc_ref () + { +#ifdef ODB_CXX11 + counter_.fetch_add (1, std::memory_order_relaxed); +#else + ++counter_; +#endif + } + + inline bool shared_base:: + _dec_ref () + { + // While there are ways to avoid acquire (which is unnecessary except + // when the counter drops to zero), for our use-cases we'd rather keep + // it simple. + // + return +#ifdef ODB_CXX11 + counter_.fetch_sub (1, std::memory_order_acq_rel) == 1 +#else + --counter_ == 0 +#endif + ? callback_ == 0 || callback_->zero_counter (callback_->arg) + : false; + } + + inline std::size_t shared_base:: + _ref_count () const + { +#ifdef ODB_CXX11 + return counter_.load (std::memory_order_relaxed); +#else + return counter_; +#endif + } + +#ifdef ODB_CXX11 + inline void* shared_base:: + operator new (std::size_t n) + { + return ::operator new (n); + } + + inline void* shared_base:: + operator new (std::size_t n, share) + { + return ::operator new (n); + } +#else + inline void* shared_base:: + operator new (std::size_t n) throw (std::bad_alloc) + { + return ::operator new (n); + } + + inline void* shared_base:: + operator new (std::size_t n, share) throw (std::bad_alloc) + { + return ::operator new (n); + } +#endif + + inline void shared_base:: + operator delete (void* p, share) ODB_NOTHROW_NOEXCEPT + { + ::operator delete (p); + } + + inline void shared_base:: + operator delete (void* p) ODB_NOTHROW_NOEXCEPT + { + ::operator delete (p); + } + } +} |