summaryrefslogtreecommitdiff
path: root/ace/Strategies_T.h
diff options
context:
space:
mode:
authorirfan <irfan@ae88bc3d-4319-0410-8dbf-d08b4c9d3795>1997-10-26 01:43:14 +0000
committerirfan <irfan@ae88bc3d-4319-0410-8dbf-d08b4c9d3795>1997-10-26 01:43:14 +0000
commit1ffe60f64b8c13e9bd7f5b3d9a3cbc88b84b85b5 (patch)
tree3c9c4134b97200d8a4a900715cdfac543ebd2159 /ace/Strategies_T.h
parent44067864df8e39840ea5df9252cb8317b1f47a9f (diff)
downloadATCD-1ffe60f64b8c13e9bd7f5b3d9a3cbc88b84b85b5.tar.gz
*** empty log message ***
Diffstat (limited to 'ace/Strategies_T.h')
-rw-r--r--ace/Strategies_T.h72
1 files changed, 41 insertions, 31 deletions
diff --git a/ace/Strategies_T.h b/ace/Strategies_T.h
index e3a492de8d8..8f265fa42b9 100644
--- a/ace/Strategies_T.h
+++ b/ace/Strategies_T.h
@@ -509,70 +509,60 @@ public:
// This is a no-op.
};
-template <class ADDR_T, class SVC_HANDLER>
+template <class ADDR_T>
class ACE_Hash_Addr
// = TITLE
// Internal class to compute hash values on addresses in
// <ACE_Cached_Connect_Strategy>.
//
// = DESCRIPTION
- // Intended to be used as a key to an <ACE_Hash_Map_Manager>. The
- // <SVC_HANDLER> class is expected to implement the following
- // methods:
- // = BEGIN<INDENT>
- // = BEGIN<CODE>
- // int in_use() const;
- // void in_use(int is_used);
- // = END<CODE>
- // = END<INDENT>
- // Likewise, the <ADDR_T> parameter/subclass is typically
- // <ACE_INET_Addr>. It is expected to implement operator==().
+ //
+ // Intended to be used as a key to an <ACE_Hash_Map_Manager>.
+ // <ADDR_T> parameter/subclass is typically <ACE_INET_Addr>. It
+ // is expected to implement operator==().
{
public:
// = Initialization methods.
ACE_Hash_Addr (void);
// Default constructor.
- ACE_Hash_Addr (const ADDR_T &a,
- SVC_HANDLER *sh = 0);
+ ACE_Hash_Addr (const ADDR_T &a);
// Pre-compute hash value.
-
+
+ ACE_Hash_Addr (const ADDR_T &a, int recyclable);
+ // Pre-compute hash value.
+
u_long hash (void) const;
// Computes and returns hash value. This "caches" the hash value to
// improve performance.
- int operator== (const ACE_Hash_Addr<ADDR_T, SVC_HANDLER> &rhs) const;
+ int operator== (const ACE_Hash_Addr<ADDR_T> &rhs) const;
// Compares two hash values.
- operator ADDR_T& (void);
- operator const ADDR_T& (void) const;
- // Conversion operators allowing <ACE_Hash_Addr> to be used in place
- // of an <{ADDR_T}>.
+ // = Set/Get the recyclable bit
+ int recyclable (void) const;
+ void recyclable (int new_value);
private:
size_t hash_i (const ADDR_T &) const;
// This is the method that actually performs the non-cached hash
// computation. It should typically be specialized.
- int compare_i (const ADDR_T &b1, const ADDR_T &bs) const;
- // Compares two hash values. This is the method that actually
- // performs the non-cached hash computation. It should typically be
- // specialized.
-
u_long hash_value_;
// Pre-computed hash-value.
- SVC_HANDLER *svc_handler_;
- // Pointer to associated <SVC_HANDLER> which is used to detect
- // "in-use" <SVC_HANDLER>s so we can ignore them. See <DESCRIPTION>
- // for details on methods required on <SVC_HANDLER>.
+ int recyclable_;
+ // We need to know if the <SVC_HANDLER> is "in-use". If it is, we
+ // can operator==() can skip the comparison.
ADDR_T addr_;
// The underlying address.
};
template <class SVC_HANDLER, ACE_PEER_CONNECTOR_1, class MUTEX>
-class ACE_Cached_Connect_Strategy : public ACE_Connect_Strategy<SVC_HANDLER, ACE_PEER_CONNECTOR_2>
+class ACE_Cached_Connect_Strategy
+ : public ACE_Connection_Recycling_Strategy,
+ public ACE_Connect_Strategy<SVC_HANDLER, ACE_PEER_CONNECTOR_2>
// = TITLE
// A connection strategy which caches connections to peers
// (represented by <SVC_HANDLER> instances), thereby allowing
@@ -603,6 +593,10 @@ class ACE_Cached_Connect_Strategy : public ACE_Connect_Strategy<SVC_HANDLER, ACE
// <ACE_Hash_Addr>.
{
public:
+
+ virtual ~ACE_Cached_Connect_Strategy (void);
+ // Destructor
+
virtual int connect_svc_handler (SVC_HANDLER *&sh,
const ACE_PEER_CONNECTOR_ADDR &remote_addr,
ACE_Time_Value *timeout,
@@ -623,8 +617,24 @@ public:
// to consider enhancing the interface at some point so that this also
// controls re-use of the cache.}>
+ virtual int purge (const void *recycling_act);
+ // Remove from cache.
+
+ virtual int cache (const void *recycling_act);
+ // Add to cache.
+
private:
- ACE_Hash_Map_Manager <ACE_Hash_Addr <ACE_PEER_CONNECTOR_ADDR,SVC_HANDLER>, SVC_HANDLER*, ACE_Null_Mutex> connection_cache_;
+
+ // = Super class
+ typedef ACE_Connect_Strategy<SVC_HANDLER, ACE_PEER_CONNECTOR_2> CONNECT_STRATEGY;
+
+ // = Typedefs for managing the map
+ typedef ACE_Hash_Addr<ACE_PEER_CONNECTOR_ADDR> ADDRESS;
+ typedef ACE_Hash_Map_Manager <ADDRESS, SVC_HANDLER *, ACE_Null_Mutex> CONNECTION_MAP;
+ typedef ACE_Hash_Map_Iterator <ADDRESS, SVC_HANDLER *, ACE_Null_Mutex> CONNECTION_MAP_ITERATOR;
+ typedef ACE_Hash_Map_Entry<ADDRESS, SVC_HANDLER *> CONNECTION_MAP_ENTRY;
+
+ CONNECTION_MAP connection_cache_;
// Table that maintains the cache of connected <SVC_HANDLER>s.
MUTEX lock_;