summaryrefslogtreecommitdiff
path: root/TAO
diff options
context:
space:
mode:
authorsma <sma@ae88bc3d-4319-0410-8dbf-d08b4c9d3795>2006-11-16 10:27:17 +0000
committersma <sma@ae88bc3d-4319-0410-8dbf-d08b4c9d3795>2006-11-16 10:27:17 +0000
commit70e95618843c7f963b649d13066af96d1a966f1e (patch)
treea49c37307a688caa3390dc951a530a5a2ff857eb /TAO
parent6c81af6aa85babeeb5ad5210a724dccb9dba30a0 (diff)
downloadATCD-70e95618843c7f963b649d13066af96d1a966f1e.tar.gz
Thu Nov 16 10:20:00 UTC 2006 Simon Massey <sma@prismtech.com>
Diffstat (limited to 'TAO')
-rw-r--r--TAO/ChangeLog14
-rw-r--r--TAO/tao/IIOP_Profile.cpp12
2 files changed, 24 insertions, 2 deletions
diff --git a/TAO/ChangeLog b/TAO/ChangeLog
index 97074998e84..935f1d103b2 100644
--- a/TAO/ChangeLog
+++ b/TAO/ChangeLog
@@ -1,3 +1,17 @@
+Thu Nov 16 10:20:00 UTC 2006 Simon Massey <sma@prismtech.com>
+
+ * tao/IIOP_Profile.cpp:
+
+ Committed for Phil Mesnier. Patch so that Bug_2604_Regression
+ test passes on windows. The problem was that an IIOP_Profile
+ that is decoded from a CDR buffer does not correctly set the
+ is_ipv6_decimal_ flag for the first endpoint only. After the
+ beta is out more changes have to be made to remove the friend
+ relationships and cleanup more code. Need to also update
+ tests/IPV6 so that we have a regression in the repo for this
+ problem. Thanks to Johnny Willemsen and Martin Corino for
+ quickly testing this fix.
+
Thu Nov 16 00:07:30 UTC 2006 J.T. Conklin <jtc@acorntoolworks.com>
* tao/Makefile.am:
diff --git a/TAO/tao/IIOP_Profile.cpp b/TAO/tao/IIOP_Profile.cpp
index 63cc46e53f8..ceb6d1f4fec 100644
--- a/TAO/tao/IIOP_Profile.cpp
+++ b/TAO/tao/IIOP_Profile.cpp
@@ -93,8 +93,13 @@ int
TAO_IIOP_Profile::decode_profile (TAO_InputCDR& cdr)
{
// Decode host and port into the <endpoint_>.
- if (cdr.read_string (this->endpoint_.host_.out ()) == 0
- || cdr.read_ushort (this->endpoint_.port_) == 0)
+ // it is necessary to do it indirectly so that IPv6 host addresses
+ // can be evaluated correctly.
+ CORBA::String_var host;
+ CORBA::UShort port;
+
+ if (cdr.read_string(host.out()) == 0 ||
+ cdr.read_ushort (port) == 0)
{
if (TAO_debug_level > 0)
ACE_DEBUG ((LM_DEBUG,
@@ -103,6 +108,9 @@ TAO_IIOP_Profile::decode_profile (TAO_InputCDR& cdr)
return -1;
}
+ this->endpoint_.host(host.in());
+ this->endpoint_.port(port);
+
if (cdr.good_bit ())
{
// Invalidate the object_addr_ until first access.