Lunchbox  1.4.0
Public Member Functions
lunchbox::PerThreadRef< T > Class Template Reference

Thread-specific storage for a RefPtr. More...

#include <perThreadRef.h>

+ Inheritance diagram for lunchbox::PerThreadRef< T >:
+ Collaboration diagram for lunchbox::PerThreadRef< T >:

List of all members.

Public Member Functions

 PerThreadRef ()
 Construct a new per-thread RefPtr.
 ~PerThreadRef ()
 Destruct a per-thread RefPtr.
PerThreadRef< T > & operator= (RefPtr< T > data)
 Assign a RefPtr to the thread-local storage.
PerThreadRef< T > & operator= (const PerThreadRef< T > &rhs)
 Assign a RefPtr to the thread-local storage.
RefPtr< const T > get () const
RefPtr< T > get ()
T * getPointer ()
T * operator-> ()
const T * operator-> () const
bool operator== (const PerThreadRef &rhs) const
bool operator== (const RefPtr< T > &rhs) const
bool operator!= (const RefPtr< T > &rhs) const
bool operator! () const
bool isValid () const

Detailed Description

template<typename T>
class lunchbox::PerThreadRef< T >

Thread-specific storage for a RefPtr.

To instantiate the template code for this class, applications have to include pthread.h before this file. pthread.h is not automatically included to avoid hard to resolve type conflicts with other header files on Windows.

Definition at line 36 of file perThreadRef.h.


Constructor & Destructor Documentation

template<typename T>
lunchbox::PerThreadRef< T >::PerThreadRef ( )

Construct a new per-thread RefPtr.

Version:
1.0
template<typename T>
lunchbox::PerThreadRef< T >::~PerThreadRef ( )

Destruct a per-thread RefPtr.

Version:
1.0

Member Function Documentation

template<typename T>
RefPtr< const T > lunchbox::PerThreadRef< T >::get ( ) const
Returns:
the RefPtr from the thread-local storage.
Version:
1.0

Referenced by lunchbox::PerThreadRef< T >::operator==().

+ Here is the caller graph for this function:

template<typename T>
RefPtr< T > lunchbox::PerThreadRef< T >::get ( )
Returns:
the RefPtr from the thread-local storage.
Version:
1.0
template<typename T>
T* lunchbox::PerThreadRef< T >::getPointer ( )
Returns:
the C pointer of the RefPtr from the thread-local storage.
Version:
1.0
template<typename T>
bool lunchbox::PerThreadRef< T >::isValid ( ) const
Returns:
true if the thread-local storage holds a non-0 pointer.
Version:
1.0
template<typename T>
bool lunchbox::PerThreadRef< T >::operator! ( ) const
Returns:
true if the thread-local storage holds a 0 pointer.
Version:
1.0
template<typename T>
bool lunchbox::PerThreadRef< T >::operator!= ( const RefPtr< T > &  rhs) const [inline]
Returns:
true if the two objects hold the same C pointer.
Version:
1.0

Definition at line 91 of file perThreadRef.h.

template<typename T>
T* lunchbox::PerThreadRef< T >::operator-> ( )
Returns:
the object held by the RefPtr in the thread-local storage.
Version:
1.0
template<typename T>
const T* lunchbox::PerThreadRef< T >::operator-> ( ) const
Returns:
the object held by the RefPtr in the thread-local storage.
Version:
1.0
template<typename T>
PerThreadRef<T>& lunchbox::PerThreadRef< T >::operator= ( RefPtr< T >  data)

Assign a RefPtr to the thread-local storage.

Version:
1.0
template<typename T>
PerThreadRef<T>& lunchbox::PerThreadRef< T >::operator= ( const PerThreadRef< T > &  rhs)

Assign a RefPtr to the thread-local storage.

Version:
1.0
template<typename T>
bool lunchbox::PerThreadRef< T >::operator== ( const PerThreadRef< T > &  rhs) const [inline]
Returns:
true if the two objects hold the same C pointer.
Version:
1.0

Definition at line 77 of file perThreadRef.h.

References lunchbox::PerThreadRef< T >::get().

+ Here is the call graph for this function:

template<typename T>
bool lunchbox::PerThreadRef< T >::operator== ( const RefPtr< T > &  rhs) const [inline]
Returns:
true if the two objects hold the same C pointer.
Version:
1.0

Definition at line 84 of file perThreadRef.h.


The documentation for this class was generated from the following file: