diff options
author | coryan <coryan@ae88bc3d-4319-0410-8dbf-d08b4c9d3795> | 1999-08-19 18:01:54 +0000 |
---|---|---|
committer | coryan <coryan@ae88bc3d-4319-0410-8dbf-d08b4c9d3795> | 1999-08-19 18:01:54 +0000 |
commit | 3f64aeffc6646a66d81b615f892e3906f158f012 (patch) | |
tree | 8da62bcb1bb53aa545132006cec9f6f069d218dc /TAO | |
parent | e84c19db4894528c9ec67261e0c2af6898f75ae9 (diff) | |
download | ATCD-3f64aeffc6646a66d81b615f892e3906f158f012.tar.gz |
ChangeLogTag:Thu Aug 19 12:57:12 1999 Carlos O'Ryan <coryan@cs.wustl.edu>
Diffstat (limited to 'TAO')
-rw-r--r-- | TAO/ChangeLog-99c | 8 | ||||
-rw-r--r-- | TAO/tao/Sequence_T.cpp | 28 | ||||
-rw-r--r-- | TAO/tao/Sequence_T.i | 16 |
3 files changed, 30 insertions, 22 deletions
diff --git a/TAO/ChangeLog-99c b/TAO/ChangeLog-99c index e9b1d9c61c9..41fc4a4b5e8 100644 --- a/TAO/ChangeLog-99c +++ b/TAO/ChangeLog-99c @@ -1,3 +1,11 @@ +Thu Aug 19 12:57:12 1999 Carlos O'Ryan <coryan@cs.wustl.edu> + + * tao/Sequence_T.i: + * tao/Sequence_T.cpp: + Moved some methods of TAO_Object_Manager<> to the .cpp file, + they were causing problems with forward declared + interfaces. Thanks to David for pointing this out. + Thu Aug 19 11:24:35 1999 David L. Levine <levine@cs.wustl.edu> * rules.tao.GNU,tao/Makefile: don't include the Interface diff --git a/TAO/tao/Sequence_T.cpp b/TAO/tao/Sequence_T.cpp index 772663b0bae..6fdb4b624bb 100644 --- a/TAO/tao/Sequence_T.cpp +++ b/TAO/tao/Sequence_T.cpp @@ -263,6 +263,22 @@ TAO_Object_Manager<T,T_var>::operator=(T_var &p) return *this; } +template <class T, class T_var> T *& +TAO_Object_Manager<T,T_var>::out (void) +{ + CORBA::release (*this->ptr_); + *this->ptr_ = T::_nil (); + return *this->ptr_; +} + +template <class T, class T_var> T * +TAO_Object_Manager<T,T_var>::_retn (void) +{ + T *temp = *this->ptr_; + *this->ptr_ = T::_nil (); + return temp; +} + // ************************************************************* // class TAO_Pseudo_Object_Manager // ************************************************************* @@ -1073,7 +1089,7 @@ TAO_Bounded_WString_Sequence (const TAO_Bounded_WString_Sequence<MAX> &rhs) { CORBA::WChar **tmp1 = TAO_Bounded_WString_Sequence<MAX>::allocbuf (this->maximum_); - CORBA::WChar ** const tmp2 = + CORBA::WChar ** const tmp2 = ACE_reinterpret_cast (CORBA::WChar ** ACE_CAST_CONST, rhs.buffer_); @@ -1092,7 +1108,7 @@ TAO_Bounded_WString_Sequence<MAX>::operator= if (this->release_) { - CORBA::WChar **tmp = ACE_reinterpret_cast (CORBA::WChar **, + CORBA::WChar **tmp = ACE_reinterpret_cast (CORBA::WChar **, this->buffer_); for (CORBA::ULong i = 0; i < this->length_; ++i) @@ -1109,9 +1125,9 @@ TAO_Bounded_WString_Sequence<MAX>::operator= TAO_Bounded_Base_Sequence::operator= (rhs); - CORBA::WChar **tmp1 = ACE_reinterpret_cast (CORBA::WChar **, + CORBA::WChar **tmp1 = ACE_reinterpret_cast (CORBA::WChar **, this->buffer_); - CORBA::WChar ** const tmp2 = + CORBA::WChar ** const tmp2 = ACE_reinterpret_cast (CORBA::WChar ** ACE_CAST_CONST, rhs.buffer_); @@ -1124,7 +1140,7 @@ template<size_t MAX> TAO_SeqElem_WString_Manager TAO_Bounded_WString_Sequence<MAX>::operator[] (CORBA::ULong slot) const { ACE_ASSERT (slot < this->maximum_); - CORBA::WChar **const tmp = + CORBA::WChar **const tmp = ACE_reinterpret_cast (CORBA::WChar **ACE_CAST_CONST, this->buffer_); return TAO_SeqElem_WString_Manager (tmp + slot, @@ -1177,7 +1193,7 @@ TAO_Bounded_WString_Sequence<MAX>::_deallocate_buffer (void) { if (this->release_ == 0) return; - CORBA::WChar **tmp = ACE_reinterpret_cast (CORBA::WChar **, + CORBA::WChar **tmp = ACE_reinterpret_cast (CORBA::WChar **, this->buffer_); TAO_Bounded_WString_Sequence<MAX>::freebuf (tmp); this->buffer_ = 0; diff --git a/TAO/tao/Sequence_T.i b/TAO/tao/Sequence_T.i index adbfa791916..db4b1d6cf19 100644 --- a/TAO/tao/Sequence_T.i +++ b/TAO/tao/Sequence_T.i @@ -257,22 +257,6 @@ TAO_Object_Manager<T,T_var>::inout (void) return *this->ptr_; } -template <class T, class T_var> ACE_INLINE T *& -TAO_Object_Manager<T,T_var>::out (void) -{ - CORBA::release (*this->ptr_); - *this->ptr_ = T::_nil (); - return *this->ptr_; -} - -template <class T, class T_var> ACE_INLINE T * -TAO_Object_Manager<T,T_var>::_retn (void) -{ - T *temp = *this->ptr_; - *this->ptr_ = T::_nil (); - return temp; -} - // ************************************************************* // Inline operations for class TAO_Pseudo_Object_Manager<T> // ************************************************************* |