#include <Token_Manager.h>
Inheritance diagram for ACE_Token_Manager:


| Public Methods | |
| ACE_Token_Manager (void) | |
| virtual | ~ACE_Token_Manager (void) | 
| void | instance (ACE_Token_Manager *) | 
| Set the pointer to token manager singleton. More... | |
| void | get_token (ACE_Token_Proxy *, const ACE_TCHAR *token_name) | 
| The Token manager uses ACE_Token_Proxy::token_id_ to look for an existing token. More... | |
| int | check_deadlock (ACE_Token_Proxy *proxy) | 
| Check whether acquire will cause deadlock or not. More... | |
| int | check_deadlock (ACE_Tokens *token, ACE_Token_Proxy *proxy) | 
| void | release_token (ACE_Tokens *&token) | 
| Notify the token manager that a token has been released. If as a result, there is no owner of the token, the token is deleted. More... | |
| ACE_TOKEN_CONST::MUTEX & | mutex (void) | 
| This is to allow Tokens to perform atomic transactions. More... | |
| void | dump (void) const | 
| Dump the state of the class. More... | |
| void | debug (int d) | 
| Turn debug mode on/off. More... | |
| Static Public Methods | |
| ACE_Token_Manager * | instance (void) | 
| Get the pointer to token manager singleton. More... | |
| Private Types | |
| typedef ACE_Token_Name | TOKEN_NAME | 
| This may be changed to a template type. More... | |
| typedef ACE_Map_Manager< TOKEN_NAME, ACE_Tokens *, ACE_Null_Mutex > | COLLECTION | 
| COLLECTION maintains a mapping from token names to ACE_Tokens*. More... | |
| typedef ACE_Map_Iterator< TOKEN_NAME, ACE_Tokens *, ACE_Null_Mutex > | COLLECTION_ITERATOR | 
| Allows iterations through collection_. More... | |
| typedef ACE_Map_Entry< TOKEN_NAME, ACE_Tokens *> | COLLECTION_ENTRY | 
| Allows iterations through collection_. More... | |
| Private Methods | |
| ACE_Tokens * | token_waiting_for (const ACE_TCHAR *client_id) | 
| Return the token that the given client_id is waiting for, if any. More... | |
| Private Attributes | |
| int | debug_ | 
| Whether to print debug messages or not. More... | |
| ACE_TOKEN_CONST::MUTEX | lock_ | 
| ACE_Mutex_Token used to lock internal data structures. More... | |
| COLLECTION | collection_ | 
| COLLECTION maintains a mapping from token names to ACE_Tokens*. More... | |
| Static Private Attributes | |
| ACE_Token_Manager * | token_manager_ = 0 | 
| pointer to singleton token manager. More... | |
Factory: Proxies use the token manager to obtain token references. This allows multiple proxies to reference the same logical token. Deadlock detection: Tokens use the manager to check for deadlock situations during acquires.
| 
 | 
| COLLECTION maintains a mapping from token names to ACE_Tokens*. 
 | 
| 
 | 
| Allows iterations through collection_. 
 | 
| 
 | 
| Allows iterations through collection_. 
 | 
| 
 | 
| This may be changed to a template type. 
 | 
| 
 | 
| 
 | 
| 
 | 
| 
 | 
| 
 | ||||||||||||
| 
 | 
| 
 | 
| Check whether acquire will cause deadlock or not. returns 1 if the acquire will _not_ cause deadlock. returns 0 if the acquire _will_ cause deadlock. This method ignores recursive acquisition. That is, it will not report deadlock if the client holding the token requests the token again. Thus, it assumes recursive mutexes. | 
| 
 | 
| Turn debug mode on/off. 
 | 
| 
 | 
| Dump the state of the class. 
 | 
| 
 | ||||||||||||
| The Token manager uses ACE_Token_Proxy::token_id_ to look for an existing token. If none is found, the Token Manager calls ACE_Token_Proxy::create_token to create a new one. When finished, sets ACE_Token_Proxy::token_. <token_name> uniquely id's the token name. | 
| 
 | 
| Set the pointer to token manager singleton. 
 | 
| 
 | 
| Get the pointer to token manager singleton. 
 | 
| 
 | 
| This is to allow Tokens to perform atomic transactions. The typical usage is to acquire this mutex, check for a safe_acquire, perform some queueing (if need be) and then release the lock. This is necessary since safe_acquire is implemented in terms of the Token queues. | 
| 
 | 
| Notify the token manager that a token has been released. If as a result, there is no owner of the token, the token is deleted. 
 | 
| 
 | 
| Return the token that the given client_id is waiting for, if any. 
 | 
| 
 | 
| COLLECTION maintains a mapping from token names to ACE_Tokens*. 
 | 
| 
 | 
| Whether to print debug messages or not. 
 | 
| 
 | 
| ACE_Mutex_Token used to lock internal data structures. 
 | 
| 
 | 
| pointer to singleton token manager. 
 | 
 1.2.13.1 written by Dimitri van Heesch,
 © 1997-2001
1.2.13.1 written by Dimitri van Heesch,
 © 1997-2001