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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
|
#include "orbsvcs/Log/EventLog_i.h"
#include "orbsvcs/Log/LogMgr_i.h"
#include "orbsvcs/Log/LogNotification.h"
ACE_RCSID (Log,
EventLog_i,
"$Id$")
TAO_BEGIN_VERSIONED_NAMESPACE_DECL
TAO_EventLog_i::TAO_EventLog_i (CORBA::ORB_ptr orb,
PortableServer::POA_ptr poa,
PortableServer::POA_ptr log_poa,
TAO_LogMgr_i &logmgr_i,
DsLogAdmin::LogMgr_ptr factory,
TAO_LogNotification *log_notifier,
DsLogAdmin::LogId id)
: TAO_Log_i (orb, logmgr_i, factory, id, log_notifier),
poa_(PortableServer::POA::_duplicate(poa)),
log_poa_(PortableServer::POA::_duplicate(log_poa))
{
// Create an instance of the event channel.
TAO_CEC_EventChannel_Attributes attr (this->poa_.in(),
this->poa_.in());
ACE_NEW_THROW_EX (this->event_channel_,
TAO_CEC_EventChannel(attr),
CORBA::NO_MEMORY ());
}
TAO_EventLog_i::~TAO_EventLog_i ()
{
this->event_channel_->destroy ();
delete this->event_channel_;
}
DsLogAdmin::Log_ptr
TAO_EventLog_i::copy (DsLogAdmin::LogId &id)
ACE_THROW_SPEC ((CORBA::SystemException))
{
// Duplicate the log.
DsEventLogAdmin::EventLogFactory_var eventLogFactory =
DsEventLogAdmin::EventLogFactory::_narrow (factory_.in ());
DsEventLogAdmin::EventLog_var log =
eventLogFactory->create (DsLogAdmin::halt, 0, thresholds_, id);
this->copy_attributes (log.in ());
return log._retn ();
}
DsLogAdmin::Log_ptr
TAO_EventLog_i::copy_with_id (DsLogAdmin::LogId id)
ACE_THROW_SPEC ((CORBA::SystemException))
{
// Duplicate the log supplying the log id.
DsEventLogAdmin::EventLogFactory_var eventLogFactory =
DsEventLogAdmin::EventLogFactory::_narrow (factory_.in ());
DsEventLogAdmin::EventLog_var log =
eventLogFactory->create_with_id (id, DsLogAdmin::halt, 0, thresholds_);
this->copy_attributes (log.in ());
return log._retn ();
}
void
TAO_EventLog_i::destroy (void)
ACE_THROW_SPEC ((CORBA::SystemException))
{
// Send event to indicate the log has been deleted.
notifier_->object_deletion (logid_);
// Remove ourselves from the list of logs.
this->logmgr_i_.remove (this->logid_);
// Deregister with POA.
PortableServer::ObjectId_var id =
this->log_poa_->servant_to_id (this);
this->log_poa_->deactivate_object (id.in ());
}
void
TAO_EventLog_i::activate (void)
{
CosEventChannelAdmin::ConsumerAdmin_var consumer_admin =
this->event_channel_->for_consumers ();
// Create the PushConsumer that will log the events.
this->my_log_consumer_ = new TAO_Event_LogConsumer (this);
this->my_log_consumer_->connect (consumer_admin.in ());
}
CosEventChannelAdmin::ConsumerAdmin_ptr
TAO_EventLog_i::for_consumers (void)
ACE_THROW_SPEC ((CORBA::SystemException))
{
return this->event_channel_->for_consumers ();
}
CosEventChannelAdmin::SupplierAdmin_ptr
TAO_EventLog_i::for_suppliers (void)
ACE_THROW_SPEC ((CORBA::SystemException))
{
return this->event_channel_->for_suppliers ();
}
TAO_END_VERSIONED_NAMESPACE_DECL
|