#include <Local_Tokens.h>
Inheritance diagram for ACE_Tokens:
Public Types | |
typedef ACE_Unbounded_Stack< ACE_TPQ_Entry * > | OWNER_STACK |
Stack of owners. | |
enum | TOKEN_TYPES { MUTEX, RWLOCK } |
Public Methods | |
ACE_Tokens (void) | |
Null constructor. | |
virtual | ~ACE_Tokens (void) |
Destructor. | |
virtual int | acquire (ACE_TPQ_Entry *caller, int ignore_deadlock, int notify)=0 |
No implementation. | |
virtual int | tryacquire (ACE_TPQ_Entry *caller)=0 |
No implementation. | |
virtual int | renew (ACE_TPQ_Entry *caller, int requeue_position)=0 |
No implementation. | |
virtual int | release (ACE_TPQ_Entry *caller)=0 |
No implementation. | |
void | make_owner (ACE_TPQ_Entry *caller) |
void | remove (ACE_TPQ_Entry *caller) |
Remove the caller from the waiter list. | |
virtual int | owners (OWNER_STACK &o, const ACE_TCHAR *id)=0 |
virtual int | is_waiting_for (const ACE_TCHAR *id)=0 |
Returns 1 if <id> is waiting for this token. 0 otherwise. | |
virtual int | is_owner (const ACE_TCHAR *id)=0 |
Returns 1 if <id> is an owner of this token. 0 otherwise. | |
virtual ACE_Token_Proxy_Queue * | waiters (void) |
Return the queue of waiters. | |
virtual int | no_of_waiters (void) |
const ACE_TCHAR * | owner_id (void) |
The current owner. | |
const ACE_TCHAR * | name (void) |
Token name. | |
void | inc_reference (void) |
int | dec_reference (void) |
void | dump (void) const |
Dump the state of the class. | |
virtual int | type (void) const=0 |
void | visit (int v) |
Mark or unmark the token as visited. | |
int | visited (void) |
Check if the token has been visited. | |
ACE_TPQ_Entry * | owner (void) |
All the data of the current owner. | |
Protected Attributes | |
int | visited_ |
For the deadlock detection algorithm. | |
int | reference_count_ |
Reference count. | |
ACE_Token_Proxy_Queue | waiters_ |
List of client's owning and waiting the token. | |
ACE_TCHAR | token_name_ [ACE_MAXTOKENNAMELEN] |
Name of token. |
Not a public interface. Currently, I don't see a reason for providing an abstract interface at this level of the library. As of yet, no one uses <ACE_Tokens> derivatives through this abstract interface except for <ACE_Token_Manager>. It only uses the statistical methods which are shared by all Tokens. For that reason, it still makes since to have a common base class. However, acquire, renew, and release do not need to have matching interfaces throughout all Tokens. To add a new type of token (e.g. semaphore), this class must be subtyped to define the new semantics. See <ACE_Token_Manager> for details.
|
Stack of owners.
|
|
These are the Token types supported by the library at ship time. There is no restriction on the number of Token types added by "3rd parties." These are only necessary for the Token Server. |
|
Null constructor.
|
|
Destructor.
|
|
No implementation.
Implemented in ACE_Mutex_Token, and ACE_RW_Token. |
|
|
|
Dump the state of the class.
Reimplemented in ACE_Mutex_Token, and ACE_RW_Token. |
|
|
|
Returns 1 if <id> is an owner of this token. 0 otherwise.
Implemented in ACE_Mutex_Token, and ACE_RW_Token. |
|
Returns 1 if <id> is waiting for this token. 0 otherwise.
Implemented in ACE_Mutex_Token, and ACE_RW_Token. |
|
Move the caller to the front of the waiter list. This is for use with remote mutexes and shadow mutexes. |
|
Token name.
|
|
Return the number of proxies that are currently waiting to get the token. |
|
All the data of the current owner.
|
|
The current owner.
|
|
Returns a stack of the current owners. Returns -1 on error, 0 on success. If <id> is non-zero, returns 1 if id is an owner. Implemented in ACE_Mutex_Token, and ACE_RW_Token. |
|
No implementation.
Implemented in ACE_Mutex_Token, and ACE_RW_Token. |
|
Remove the caller from the waiter list.
|
|
No implementation.
Implemented in ACE_Mutex_Token, and ACE_RW_Token. |
|
No implementation.
Implemented in ACE_Mutex_Token, and ACE_RW_Token. |
|
Provides a manual RTTI mechanism. This method is used only by ACE_Token_Request so that the type of a token can be sent to a remote Token Server. Implemented in ACE_Mutex_Token, and ACE_RW_Token. |
|
Mark or unmark the token as visited.
|
|
Check if the token has been visited.
|
|
Return the queue of waiters.
|
|
Reference count.
|
|
Name of token.
|
|
For the deadlock detection algorithm.
|
|
List of client's owning and waiting the token.
|