1
// Replication_Service.cpp,v 1.7 2003/12/01 18:26:59 huangming Exp
3
#include "Replication_Service.h"
4
#include "AMI_Replication_Strategy.h"
5
#include "Basic_Replication_Strategy.h"
6
#include "FTEC_ORBInitializer.h"
8
#include "tao/ORBInitializer_Registry.h"
10
#include "ace/OS_NS_strings.h"
12
ACE_RCSID (EventChannel,
14
"Replication_Service.cpp,v 1.7 2003/12/01 18:26:59 huangming Exp")
19
auto_ptr<Replication_Strategy> replication_strategy;
20
Replication_Service* service;
23
Replication_Service* Replication_Service::instance()
28
Replication_Service::Replication_Service()
33
Replication_Service::~Replication_Service()
37
int Replication_Service::init (int argc, ACE_TCHAR* argv[])
39
static int initialized = 0;
41
// Only allow initialization once.
47
Replication_Strategy* strategy;
49
// Parse any service configurator parameters.
50
if (argc > 0 && ACE_OS::strcasecmp (argv[0], ACE_LIB_TEXT("AMI")) == 0)
51
ACE_NEW_RETURN (strategy, AMI_Replication_Strategy, -1);
53
ACE_NEW_RETURN (strategy, Basic_Replication_Strategy, -1);
55
ACE_AUTO_PTR_RESET (replication_strategy, strategy, Replication_Strategy);
59
PortableInterceptor::ORBInitializer_ptr temp_orb_initializer =
60
PortableInterceptor::ORBInitializer::_nil ();
61
PortableInterceptor::ORBInitializer_var orb_initializer;
63
/// Register the RTCORBA ORBInitializer.
64
ACE_NEW_THROW_EX (temp_orb_initializer,
68
orb_initializer = temp_orb_initializer;
70
PortableInterceptor::register_orb_initializer (orb_initializer.in ()
71
ACE_ENV_ARG_PARAMETER);
76
ACE_PRINT_EXCEPTION (ACE_ANY_EXCEPTION,
77
"Unexpected exception caught while "
78
"initializing the TransactionDepth");
86
void Replication_Service::become_primary()
88
Replication_Strategy* strategy =
89
replication_strategy->make_primary_strategy();
93
if (replication_strategy.get() != strategy) {
94
ACE_AUTO_PTR_RESET(replication_strategy, strategy, Replication_Strategy);
98
void Replication_Service::check_validity(ACE_ENV_SINGLE_ARG_DECL)
100
replication_strategy->check_validity(ACE_ENV_SINGLE_ARG_PARAMETER);
104
void Replication_Service::replicate_request(const FtRtecEventChannelAdmin::Operation& update,
105
RollbackOperation rollback
111
ACE_Message_Block mb;
112
ACE_CDR::consolidate(&mb, cdr.begin());
113
FTRT::State state(mb.length(), &mb);
116
replication_strategy->replicate_request(
120
ACE_ENV_ARG_PARAMETER);
123
int Replication_Service::acquire_read (void)
125
int r = replication_strategy->acquire_read();
126
ACE_DEBUG((LM_DEBUG, "Read Lock acquired %d\n", r));
130
int Replication_Service::acquire_write (void)
132
int r= replication_strategy->acquire_write();
133
ACE_DEBUG((LM_DEBUG, "Write Lock acqured %d\n", r));
137
int Replication_Service::release (void)
139
int r= replication_strategy->release();
140
ACE_DEBUG((LM_DEBUG, "Lock Released %d\n", r));
144
ACE_FACTORY_DEFINE (TAO_FTRTEC, Replication_Service)
146
ACE_STATIC_SVC_DEFINE (Replication_Service,
147
ACE_TEXT ("FTRTEC_Replication"),
149
&ACE_SVC_NAME (Replication_Service),
150
ACE_Service_Type::DELETE_THIS
151
| ACE_Service_Type::DELETE_OBJ,