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
|
// cvs-id : $Id$
#ifndef AGENT_H
#define AGENT_H
#include "LWFTS.h"
#include "ace/Hash_Map_Manager_T.h"
#include "ace/Unbounded_Queue.h"
#include <list>
struct AGENT_RANKED_IOR_LIST
{
bool now;
std::list<CORBA::Object_var> ior_list;
};
class Agent_i : public virtual POA_Agent
{
public:
Agent_i (bool proactive = true);
~Agent_i (void);
virtual CORBA::Object_ptr next_member (const char * m
ACE_ENV_ARG_DECL_WITH_DEFAULTS)
ACE_THROW_SPEC ((::CORBA::SystemException));
virtual void update_rank_list (const RankList & rank_list
ACE_ENV_ARG_DECL_WITH_DEFAULTS)
ACE_THROW_SPEC ((::CORBA::SystemException));
void initialize (CORBA::Object_ptr);
void proactive(bool v);
/*
virtual void update_reference (const char * m
ACE_ENV_ARG_DECL_WITH_DEFAULTS)
ACE_THROW_SPEC ((::CORBA::SystemException));
virtual void update_failover (const char * object_id,
CORBA::Object_ptr next_object
ACE_ENV_ARG_DECL_WITH_DEFAULTS)
ACE_THROW_SPEC ((::CORBA::SystemException));
virtual void update_secondary (const char * object_id,
CORBA::Object_ptr next_member
ACE_ENV_ARG_DECL_WITH_DEFAULTS)
ACE_THROW_SPEC ((::CORBA::SystemException));
virtual void initialize_agent (const ReplicaList & replica_list,
const ReplicasList & replicas_list
ACE_ENV_ARG_DECL_WITH_DEFAULTS)
ACE_THROW_SPEC ((::CORBA::SystemException));
virtual void update_failover_list (const FailoverList &failover_list
ACE_ENV_ARG_DECL_WITH_DEFAULTS)
ACE_THROW_SPEC ((::CORBA::SystemException));
typedef ACE_Hash_Map_Manager_Ex<
ACE_CString,
CORBA::Object_var,
ACE_Hash<ACE_CString>,
ACE_Equal_To<ACE_CString>,
ACE_Null_Mutex> REPLICA_MAP;
typedef ACE_Hash_Map_Manager_Ex<
ACE_CString,
CORBA::ULong,
ACE_Hash<ACE_CString>,
ACE_Equal_To<ACE_CString>,
ACE_Null_Mutex> FAILURE_MAP;
*/
typedef ACE_Hash_Map_Manager_Ex<
ACE_CString,
AGENT_RANKED_IOR_LIST,
ACE_Hash<ACE_CString>,
ACE_Equal_To<ACE_CString>,
ACE_Null_Mutex> OBJECTID_RANKED_IOR_MAP;
private:
//CORBA::String_var forward_str_;
//REPLICA_MAP failover_map_;
//REPLICA_MAP secondary_map_;
//FAILURE_MAP failure_map_;
ReplicationManager_var RM_var_;
OBJECTID_RANKED_IOR_MAP objectid_rankedior_map_;
ACE_Thread_Mutex ior_map_mutex_;
bool proactive_;
size_t update_count_;
};
#endif /* AGENT_H */
|