server/dep/acelite/ace/MEM_Connector.cpp
2023-01-01 00:55:45 +00:00

146 lines
5 KiB
C++

// $Id: MEM_Connector.cpp 97326 2013-09-11 07:52:09Z johnnyw $
#include "ace/MEM_Connector.h"
#if (ACE_HAS_POSITION_INDEPENDENT_POINTERS == 1)
#if !defined (__ACE_INLINE__)
#include "ace/MEM_Connector.inl"
#endif /* __ACE_INLINE__ */
ACE_BEGIN_VERSIONED_NAMESPACE_DECL
ACE_ALLOC_HOOK_DEFINE(ACE_MEM_Connector)
void
ACE_MEM_Connector::dump (void) const
{
#if defined (ACE_HAS_DUMP)
ACE_TRACE ("ACE_MEM_Connector::dump");
ACELIB_DEBUG ((LM_DEBUG, ACE_BEGIN_DUMP, this));
ACELIB_DEBUG ((LM_DEBUG, ACE_TEXT ("\n")));
ACELIB_DEBUG ((LM_DEBUG, ACE_END_DUMP));
#endif /* ACE_HAS_DUMP */
}
ACE_MEM_Connector::ACE_MEM_Connector (void)
: malloc_options_ (ACE_DEFAULT_BASE_ADDR, 0),
preferred_strategy_ (ACE_MEM_IO::Reactive)
{
ACE_TRACE ("ACE_MEM_Connector::ACE_MEM_Connector");
}
// Establish a connection.
ACE_MEM_Connector::ACE_MEM_Connector (ACE_MEM_Stream &new_stream,
const ACE_INET_Addr &remote_sap,
ACE_Time_Value *timeout,
const ACE_Addr &local_sap,
int reuse_addr,
int flags,
int perms)
: malloc_options_ (ACE_DEFAULT_BASE_ADDR, 0),
preferred_strategy_ (ACE_MEM_IO::Reactive)
{
ACE_TRACE ("ACE_MEM_Connector::ACE_MEM_Connector");
// This is necessary due to the weird inheritance relationships of
// ACE_MEM_Stream.
this->connect (new_stream,
remote_sap,
timeout,
local_sap,
reuse_addr,
flags,
perms);
}
int
ACE_MEM_Connector::connect (ACE_MEM_Stream &new_stream,
const ACE_INET_Addr &remote_sap,
ACE_Time_Value *timeout,
const ACE_Addr &local_sap,
int reuse_addr,
int flags,
int perms)
{
ACE_TRACE ("ACE_MEM_Connector::connect");
if (!this->address_.same_host (remote_sap))
ACELIB_ERROR_RETURN ((LM_ERROR,
ACE_TEXT ("(%P|%t) MEM_Connector can't connect ")
ACE_TEXT ("to %C:%d which is not a local endpoint ")
ACE_TEXT ("(local address is %C:%d)\n"),
remote_sap.get_host_name (),
remote_sap.get_port_number (),
this->address_.get_host_name (),
this->address_.get_port_number ()),
-1);
else
this->address_.set_port_number (remote_sap.get_port_number ());
ACE_SOCK_Stream temp_stream;
if (ACE_SOCK_Connector::connect (temp_stream,
this->address_.get_local_addr (),
timeout, local_sap,
reuse_addr, flags, perms) == -1)
ACELIB_ERROR_RETURN ((LM_DEBUG,
ACE_TEXT ("%p\n"),
ACE_TEXT ("ACE_MEM_Connector::connect")),
-1);
ACE_HANDLE new_handle = temp_stream.get_handle ();
new_stream.set_handle (new_handle);
new_stream.disable (ACE_NONBLOCK);
// Do not close the handle.
// now we should setup the mmap malloc.
ACE_TCHAR buf[MAXPATHLEN];
// @@ Need to handle timeout here.
ACE_INT16 server_strategy = ACE_MEM_IO::Reactive;
// Receive the signaling strategy theserver support.
if (ACE::recv (new_handle, &server_strategy,
sizeof (ACE_INT16)) == -1)
ACELIB_ERROR_RETURN ((LM_DEBUG,
ACE_TEXT ("ACE_MEM_Connector::connect error receiving strategy\n")),
-1);
// If either side don't support MT, we will not use it.
#if defined (ACE_WIN32) || !defined (_ACE_USE_SV_SEM)
if (! (this->preferred_strategy_ == ACE_MEM_IO::MT &&
server_strategy == ACE_MEM_IO::MT))
#endif /* ACE_WIN32 || !_ACE_USE_SV_SEM */
server_strategy = ACE_MEM_IO::Reactive;
if (ACE::send (new_handle, &server_strategy,
sizeof (ACE_INT16)) == -1)
ACELIB_ERROR_RETURN ((LM_DEBUG,
ACE_TEXT ("ACE_MEM_Connector::connect error sending strategy\n")),
-1);
ACE_INT16 buf_len;
// Byte-order is not a problem for this read.
if (ACE::recv (new_handle, &buf_len, sizeof (buf_len)) == -1)
ACELIB_ERROR_RETURN ((LM_DEBUG,
ACE_TEXT ("ACE_MEM_Connector::connect error receiving shm filename length\n")),
-1);
if (ACE::recv (new_handle, buf, buf_len) == -1)
ACELIB_ERROR_RETURN ((LM_DEBUG,
ACE_TEXT ("ACE_MEM_Connector::connect error receiving shm filename.\n")),
-1);
if (new_stream.init (buf,
static_cast<ACE_MEM_IO::Signal_Strategy> (server_strategy),
&this->malloc_options_) == -1)
return -1;
return 0;
}
ACE_END_VERSIONED_NAMESPACE_DECL
#endif /* ACE_HAS_POSITION_INDEPENDENT_POINTERS == 1 */