blob: 0bd6ff8862e01ab23377c1db55b51936b72948c9 (
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
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
|
// -*- C++ -*-
//=============================================================================
/**
* @file FT_Storable_Naming_Context.h
*
*
* @author Kevin Stanley <stanleyk@ociweb.com>
*/
//=============================================================================
#ifndef TAO_FT_STORABLE_NAMING_CONTEXT_H
#define TAO_FT_STORABLE_NAMING_CONTEXT_H
#include /**/ "ace/pre.h"
#include "orbsvcs/Naming/Storable_Naming_Context.h"
#include "orbsvcs/Naming/FaultTolerant/ftnaming_export.h"
#include "orbsvcs/PortableGroupC.h"
#include "orbsvcs/Naming/FaultTolerant/FT_Naming_Manager.h"
#include "orbsvcs/FT_NamingReplicationC.h"
TAO_BEGIN_VERSIONED_NAMESPACE_DECL
class TAO_FT_Naming_Replication_Manager;
/**
* @class FT_TAO_Storable_Naming_Context
*
* @brief This class specializes the TAO_Storable_Naming_Context
* 'ConcreteImplementor' in the Bridge pattern architecture of the
* CosNaming::NamingContext implementation.
*
*/
class TAO_FtNaming_Export TAO_FT_Storable_Naming_Context :
public TAO_Storable_Naming_Context
{
public:
/**
* Constructor that takes in preallocated data structure and takes
* ownership of it. Derived class from TAO_Persistent_Naming_Context
* provides specialization of the resolve operation to support
* load balancing.
*/
TAO_FT_Storable_Naming_Context (CORBA::ORB_ptr orb,
PortableServer::POA_ptr poa,
const char *poa_id,
TAO_Storable_Naming_Context_Factory *cxt_factory,
TAO::Storable_Factory *factory);
/// Destructor.
virtual ~TAO_FT_Storable_Naming_Context (void);
/**
* Override the resolve operation to support load balancing using
* the object group manager and associated strategy.
*/
virtual CORBA::Object_ptr resolve (const CosNaming::Name &n);
// Set the Naming Manager as a static so that it is available for all
// naming context implementations.
static void set_naming_manager (TAO_FT_Naming_Manager *mgr_impl);
bool is_object_group (const CORBA::Object_ptr obj) const;
/**
* Queues a request to update the peer replica instance of this
* context.
*/
void propagate_update_notification (FT_Naming::ChangeType change_type);
/**
* Find the indicated context below this context. Returns 0
* if it cannot be found.
*/
TAO_FT_Storable_Naming_Context* find_relative_context (
const CosNaming::Name &n);
/**
* Mark the implementation as stale for replicated persistence support.
*/
virtual void stale (bool is_stale);
virtual bool stale (void);
/**
* An internal utility used to signal that this context was updated.
* Check the last_changed_ attribute for the time of the write.
*/
void context_written (void);
/**
* An internal callback invoked by the File_Open_Lock_and_Check
* object to determine if this context is obsolete with respect to the
* file object .
*/
virtual bool is_obsolete (time_t stored_time);
protected:
static TAO_FT_Naming_Manager *naming_manager_;
bool stale_;
TAO_FT_Naming_Replication_Manager *replicator_;
};
TAO_END_VERSIONED_NAMESPACE_DECL
#include /**/ "ace/post.h"
#endif /* TAO_FT_STORABLE_NAMING_CONTEXT_H */
|