diop_acceptor.cpp
来自「这是广泛使用的通信开源项目,对于大容量,高并发的通讯要求完全能够胜任,他广泛可用」· C++ 代码 · 共 754 行 · 第 1/2 页
CPP
754 行
// This may look like C, but it's really -*- C++ -*-
// DIOP_Acceptor.cpp,v 1.15 2003/11/03 03:05:24 dhinton Exp
#include "DIOP_Acceptor.h"
#if defined (TAO_HAS_DIOP) && (TAO_HAS_DIOP != 0)
#include "DIOP_Profile.h"
#include "tao/MProfile.h"
#include "tao/ORB_Core.h"
#include "tao/debug.h"
#include "tao/Protocols_Hooks.h"
#include "tao/Codeset_Manager.h"
#include "ace/Auto_Ptr.h"
#if !defined(__ACE_INLINE__)
#include "DIOP_Acceptor.i"
#endif /* __ACE_INLINE__ */
#include "ace/os_include/os_netdb.h"
ACE_RCSID (tao,
DIOP_Acceptor,
"DIOP_Acceptor.cpp,v 1.15 2003/11/03 03:05:24 dhinton Exp")
TAO_DIOP_Acceptor::TAO_DIOP_Acceptor (CORBA::Boolean flag)
: TAO_Acceptor (TAO_TAG_UDP_PROFILE),
addrs_ (0),
hosts_ (0),
endpoint_count_ (0),
version_ (TAO_DEF_GIOP_MAJOR, TAO_DEF_GIOP_MINOR),
orb_core_ (0),
lite_flag_ (flag),
connection_handler_ (0)
{
}
TAO_DIOP_Acceptor::~TAO_DIOP_Acceptor (void)
{
// Make sure we are closed before we start destroying the
// strategies.
this->close ();
delete [] this->addrs_;
for (size_t i = 0; i < this->endpoint_count_; ++i)
CORBA::string_free (this->hosts_[i]);
delete [] this->hosts_;
}
// TODO =
// 2) For V1.[1,2] there are tagged components
int
TAO_DIOP_Acceptor::create_profile (const TAO::ObjectKey & object_key,
TAO_MProfile &mprofile,
CORBA::Short priority)
{
// Sanity check.
if (this->endpoint_count_ == 0)
return -1;
// Check if multiple endpoints should be put in one profile or if
// they should be spread across multiple profiles.
if (priority == TAO_INVALID_PRIORITY)
return this->create_new_profile (object_key,
mprofile,
priority);
else
return this->create_shared_profile (object_key,
mprofile,
priority);
}
int
TAO_DIOP_Acceptor::create_new_profile (const TAO::ObjectKey &object_key,
TAO_MProfile &mprofile,
CORBA::Short priority)
{
// Adding this->endpoint_count_ to the TAO_MProfile.
int count = mprofile.profile_count ();
if ((mprofile.size () - count) < this->endpoint_count_
&& mprofile.grow (count + this->endpoint_count_) == -1)
return -1;
// Create a profile for each acceptor endpoint.
for (size_t i = 0; i < this->endpoint_count_; ++i)
{
TAO_DIOP_Profile *pfile = 0;
ACE_NEW_RETURN (pfile,
TAO_DIOP_Profile (this->hosts_[i],
this->addrs_[i].get_port_number (),
object_key,
this->addrs_[i],
this->version_,
this->orb_core_),
-1);
pfile->endpoint ()->priority (priority);
if (mprofile.give_profile (pfile) == -1)
{
pfile->_decr_refcnt ();
pfile = 0;
return -1;
}
// Do not add any tagged components to the profile if configured
// by the user not to do so, or if an IIOP 1.0 endpoint is being
// created (IIOP 1.0 did not support tagged components).
if (this->orb_core_->orb_params ()->std_profile_components () == 0
|| (this->version_.major == 1 && this->version_.minor == 0))
continue;
pfile->tagged_components ().set_orb_type (TAO_ORB_TYPE);
this->orb_core_->codeset_manager()->
set_codeset(pfile->tagged_components());
}
return 0;
}
int
TAO_DIOP_Acceptor::create_shared_profile (const TAO::ObjectKey &object_key,
TAO_MProfile &mprofile,
CORBA::Short priority)
{
size_t index = 0;
TAO_Profile *pfile = 0;
TAO_DIOP_Profile *iiop_profile = 0;
// First see if <mprofile> already contains a DIOP profile.
for (TAO_PHandle i = 0; i != mprofile.profile_count (); ++i)
{
pfile = mprofile.get_profile (i);
if (pfile->tag () == TAO_TAG_UDP_PROFILE)
{
iiop_profile = ACE_dynamic_cast (TAO_DIOP_Profile *,
pfile);
break;
}
}
// If <mprofile> doesn't contain a DIOP_Profile, we need to create
// one.
if (iiop_profile == 0)
{
ACE_NEW_RETURN (iiop_profile,
TAO_DIOP_Profile (this->hosts_[0],
this->addrs_[0].get_port_number (),
object_key,
this->addrs_[0],
this->version_,
this->orb_core_),
-1);
iiop_profile->endpoint ()->priority (priority);
if (mprofile.give_profile (iiop_profile) == -1)
{
iiop_profile->_decr_refcnt ();
iiop_profile = 0;
return -1;
}
if (this->orb_core_->orb_params ()->std_profile_components () != 0
&& (this->version_.major >= 1 && this->version_.minor >= 1))
{
iiop_profile->tagged_components ().set_orb_type (TAO_ORB_TYPE);
this->orb_core_->codeset_manager()->
set_codeset(iiop_profile->tagged_components());
}
index = 1;
}
// Add any remaining acceptor endpoints to the DIOP_Profile.
for (;
index < this->endpoint_count_;
++index)
{
TAO_DIOP_Endpoint *endpoint = 0;
ACE_NEW_RETURN (endpoint,
TAO_DIOP_Endpoint (this->hosts_[index],
this->addrs_[index].get_port_number (),
this->addrs_[index]),
-1);
endpoint->priority (priority);
iiop_profile->add_endpoint (endpoint);
}
return 0;
}
int
TAO_DIOP_Acceptor::is_collocated (const TAO_Endpoint *endpoint)
{
const TAO_DIOP_Endpoint *endp =
ACE_dynamic_cast (const TAO_DIOP_Endpoint *, endpoint);
// Make sure the dynamically cast pointer is valid.
if (endp == 0)
return 0;
for (size_t i = 0; i < this->endpoint_count_; ++i)
{
// compare the port and host name. Please do *NOT* optimize
// this code by comparing the IP address instead. That would
// trigger the following bug:
//
// http://deuce.doc.wustl.edu/bugzilla/show_bug.cgi?id=1220
//
if (endp->port() == this->addrs_[i].get_port_number()
&& ACE_OS::strcmp(endp->host(), this->hosts_[i]) == 0)
return 1; // Collocated
}
return 0; // Not collocated
}
int
TAO_DIOP_Acceptor::close (void)
{
return 0;
}
int
TAO_DIOP_Acceptor::open (TAO_ORB_Core *orb_core,
ACE_Reactor *reactor,
int major,
int minor,
const char *address,
const char *options)
{
this->orb_core_ = orb_core;
if (this->init_tcp_properties () != 0)
return -1;
if (this->hosts_ != 0)
{
// The hostname cache has already been set!
// This is bad mojo, i.e. an internal TAO error.
ACE_ERROR_RETURN ((LM_ERROR,
ACE_TEXT ("TAO (%P|%t) ")
ACE_TEXT ("DIOP_Acceptor::open - "),
ACE_TEXT ("hostname already set\n\n")),
-1);
}
if (address == 0)
return -1;
if (major >=0 && minor >= 0)
this->version_.set_version (ACE_static_cast (CORBA::Octet,
major),
ACE_static_cast (CORBA::Octet,
minor));
// Parse options
if (this->parse_options (options) == -1)
return -1;
ACE_INET_Addr addr;
const char *port_separator_loc = ACE_OS::strchr (address, ':');
const char *specified_hostname = 0;
char tmp_host[MAXHOSTNAMELEN + 1];
if (port_separator_loc == address)
{
// The address is a port number or port name. No hostname was
// specified. The hostname for each network interface and the
// fully qualified domain name must be obtained.
// Check for multiple network interfaces.
if (this->probe_interfaces (orb_core) == -1)
return -1;
// First convert the port into a usable form.
if (addr.set (address + sizeof (':')) != 0)
return -1;
// Now reset the port and set the host.
if (addr.set (addr.get_port_number (),
ACE_static_cast (ACE_UINT32, INADDR_ANY),
1) != 0)
return -1;
else
return this->open_i (addr,
reactor);
}
else if (port_separator_loc == 0)
{
// The address is a hostname. No port was specified, so assume
// port zero (port will be chosen for us).
if (addr.set ((unsigned short) 0, address) != 0)
return -1;
specified_hostname = address;
}
else
{
// Host and port were specified.
if (addr.set (address) != 0)
return -1;
// Extract out just the host part of the address.
size_t len = port_separator_loc - address;
ACE_OS::memcpy (tmp_host, address, len);
tmp_host[len] = '\0';
specified_hostname = tmp_host;
}
this->endpoint_count_ = 1; // Only one hostname to store
ACE_NEW_RETURN (this->addrs_,
ACE_INET_Addr[this->endpoint_count_],
-1);
ACE_NEW_RETURN (this->hosts_,
char *[this->endpoint_count_],
-1);
this->hosts_[0] = 0;
if (this->hostname (orb_core,
addr,
this->hosts_[0],
specified_hostname) != 0)
return -1;
// Copy the addr. The port is (re)set in
// TAO_DIOP_Acceptor::open_i().
if (this->addrs_[0].set (addr) != 0)
return -1;
return this->open_i (addr,
reactor);
}
int
TAO_DIOP_Acceptor::open_default (TAO_ORB_Core *orb_core,
ACE_Reactor *reactor,
int major,
int minor,
const char *options)
{
this->orb_core_ = orb_core;
if (this->init_tcp_properties () != 0)
return -1;
if (this->hosts_ != 0)
{
// The hostname cache has already been set!
// This is bad mojo, i.e. an internal TAO error.
ACE_ERROR_RETURN ((LM_ERROR,
ACE_TEXT ("TAO (%P|%t) ")
ACE_TEXT ("DIOP_Acceptor::open_default - "),
ACE_TEXT ("hostname already set\n\n")),
-1);
}
if (major >=0 && minor >= 0)
this->version_.set_version (ACE_static_cast (CORBA::Octet,
major),
ACE_static_cast (CORBA::Octet,
minor));
// Parse options
if (this->parse_options (options) == -1)
return -1;
// Check for multiple network interfaces.
if (this->probe_interfaces (orb_core) == -1)
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?