#include <ace/Token.h>
class ACE_Token {
public:ACE_Token (LPCTSTR name = 0, void * = 0);virtual ~ACE_Token (void);int acquire (void (*sleep_hook)( void *), void *arg = 0, ACE_Time_Value *timeout = 0 );int acquire (ACE_Time_Value *timeout = 0);virtual void sleep_hook (void);int renew (int requeue_position = 0, ACE_Time_Value *timeout = 0);int tryacquire (void);int remove (void);int release (void);int acquire_read (void);int acquire_read (void (*sleep_hook)( void *), void *arg = 0, ACE_Time_Value *timeout = 0 );int acquire_write (void);int acquire_write (void (*sleep_hook)( void *), void *arg = 0, ACE_Time_Value *timeout = 0 );int tryacquire_read (void);int tryacquire_write (void);int waiters (void);ACE_thread_t current_owner (void);int signal_all_threads ();void dump (void) const;ACE_ALLOC_HOOK_DECLARE;struct ACE_Token_Queue_Entry {
public:ACE_Token_Queue_Entry ( ACE_Thread_Mutex &m, ACE_thread_t t_id );int wait (ACE_Time_Value *timeout, ACE_Thread_Mutex &lock);int signal (void);ACE_Token_Queue_Entry *next_;ACE_thread_t thread_id_;ACE_Semaphore cv_;ACE_Condition_Thread_Mutex cv_;int runable_;};
    inline int acquire (ACE_Time_Value * = 0);
    inline int tryacquire (void);
    inline int remove (void);
    inline int release (void);
  private:
    enum ACE_Token_Op_Type{ READ_TOKEN = 1, WRITE_TOKEN };
    struct ACE_Token_Queue
    {
      public:
        ACE_Token_Queue (void);
        void remove_entry (ACE_Token_Queue_Entry *);
        ACE_Token_Queue_Entry *head_;
        ACE_Token_Queue_Entry *tail_;
    };
    int shared_acquire (void (*sleep_hook_func)(
        void *),
        void *arg,
        ACE_Time_Value *timeout,
        ACE_Token_Op_Type op_type
        );
    ACE_Token_Queue writers_;
    ACE_Token_Queue readers_;
    ACE_Thread_Mutex lock_;
    ACE_thread_t owner_;
    int in_use_;
    int waiters_;
    int nesting_level_;
    int signal_all_threads_;
};
ACE_Token (LPCTSTR name = 0, void * = 0);
virtual ~ACE_Token (void);
int acquire (void (*sleep_hook)(
    void *),
    void *arg = 0,
    ACE_Time_Value *timeout = 0
    );
timeout expires.  If some other thread currently holds the
token then sleep_hook is called before our thread goes to
sleep.  This sleep_hook can be used by the requesting thread to
unblock a token-holder that is sleeping, e.g., by means of
writing to a pipe (the ACE ACE_Reactor uses this functionality).
Return values:
0 if acquires without calling sleep_hook
1 if sleep_hook is called.
2 if the token is signaled.
-1 if failure or timeout occurs (if timeout occurs errno == ETIME)
If timeout == &ACE_Time_Value::zero then acquire has polling
semantics (and does *not* call sleep_hook).
int acquire (ACE_Time_Value *timeout = 0);
acquire method, except
that it invokes the virtual function called sleep_hook
that can be overridden by a subclass of ACE_Token.
virtual void sleep_hook (void);
acquire goes to sleep.
By default, this is a no-op...
int renew (int requeue_position = 0, ACE_Time_Value *timeout = 0);
requeue_position ==
-1 and there are other threads waiting to obtain the token we are
queued at the end of the list of waiters.  If requeue_position
> -1 then it indicates how many entries to skip over before
inserting our thread into the list of waiters (e.g.,
requeue_position == 0 means "insert at front of the queue").
Renew has the rather odd semantics such that if there are other
waiting threads it will give up the token even if the
nesting_level_  1.  I'm not sure if this is really the right
thing to do (since it makes it possible for shared data to be
changed unexpectedly) so use with caution...
This method maintians the original token priority.
int tryacquire (void);
acquire).
int remove (void);
int release (void);
int acquire_read (void);
int acquire_read (void (*sleep_hook)(
    void *),
    void *arg = 0,
    ACE_Time_Value *timeout = 0
    );
int acquire_write (void);
acquire.
int acquire_write (void (*sleep_hook)(
    void *),
    void *arg = 0,
    ACE_Time_Value *timeout = 0
    );
int tryacquire_read (void);
int tryacquire_write (void);
tryacquire.
int waiters (void);
ACE_thread_t current_owner (void);
int signal_all_threads ();
signal_all_thread_ to non-zero if
there're threads waiting, and returns the number of threads
waiting.  If there's no thread waiting for the token, the call
returns 0 and doesn't do anything.  The last thread releases the
token also reset the singal_all_thread_ flag to 0.  This means,
any threads that try to acquire the token after the call is
issued will also get "signaled" and the number of threads waiting
the token is only a snapshot.
void dump (void) const;
ACE_ALLOC_HOOK_DECLARE;