blob: a88f9aa851652c502af20ed970cb4693f6cb77e3 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
|
// $Id$
#include "ace/Log_Category.h"
#include "ace/Reactor_Token_T.h"
ACE_BEGIN_VERSIONED_NAMESPACE_DECL
template <class ACE_TOKEN_TYPE> void
ACE_Reactor_Token_T<ACE_TOKEN_TYPE>::dump (void) const
{
#if defined (ACE_HAS_DUMP)
ACE_TRACE ("ACE_Reactor_Token_T::dump");
ACELIB_DEBUG ((LM_DEBUG, ACE_BEGIN_DUMP, this));
ACELIB_DEBUG ((LM_DEBUG, ACE_TEXT ("\n")));
ACELIB_DEBUG ((LM_DEBUG, ACE_END_DUMP));
#endif /* ACE_HAS_DUMP */
}
template <class ACE_TOKEN_TYPE>
ACE_Reactor_Token_T<ACE_TOKEN_TYPE>::ACE_Reactor_Token_T
(ACE_Reactor_Impl &r,
int s_queue)
: reactor_ (&r)
{
ACE_TRACE ("ACE_Reactor_Token_T::ACE_Reactor_Token");
this->queueing_strategy (s_queue);
}
template <class ACE_TOKEN_TYPE>
ACE_Reactor_Token_T<ACE_TOKEN_TYPE>::ACE_Reactor_Token_T (int s_queue)
: reactor_ (0)
{
ACE_TRACE ("ACE_Reactor_Token_T::ACE_Reactor_Token");
this->queueing_strategy (s_queue);
}
template <class ACE_TOKEN_TYPE>
ACE_Reactor_Token_T<ACE_TOKEN_TYPE>::~ACE_Reactor_Token_T (void)
{
ACE_TRACE ("ACE_Reactor_Token_T::~ACE_Reactor_Token_T");
}
template <class ACE_TOKEN_TYPE> ACE_Reactor_Impl &
ACE_Reactor_Token_T<ACE_TOKEN_TYPE>::reactor (void)
{
return *this->reactor_;
}
template <class ACE_TOKEN_TYPE> void
ACE_Reactor_Token_T<ACE_TOKEN_TYPE>::reactor (ACE_Reactor_Impl &reactor)
{
this->reactor_ = &reactor;
}
// Used to wakeup the reactor.
template <class ACE_TOKEN_TYPE> void
ACE_Reactor_Token_T<ACE_TOKEN_TYPE>::sleep_hook (void)
{
ACE_TRACE ("ACE_Reactor_Token_T::sleep_hook");
ACE_Time_Value ping (ACE_Time_Value::zero);
if (this->reactor_->notify (0, ACE_Event_Handler::EXCEPT_MASK, &ping) == -1)
{
if (errno == ETIME)
{
errno = 0;
}
else
{
ACELIB_ERROR ((LM_ERROR,
ACE_TEXT ("%p\n"),
ACE_TEXT ("sleep_hook failed")));
}
}
}
ACE_END_VERSIONED_NAMESPACE_DECL
|