diff options
Diffstat (limited to 'TAO/TAO_IDL/be/be_visitor_sequence/gen_bounded_sequence_ci.cpp')
-rw-r--r-- | TAO/TAO_IDL/be/be_visitor_sequence/gen_bounded_sequence_ci.cpp | 419 |
1 files changed, 0 insertions, 419 deletions
diff --git a/TAO/TAO_IDL/be/be_visitor_sequence/gen_bounded_sequence_ci.cpp b/TAO/TAO_IDL/be/be_visitor_sequence/gen_bounded_sequence_ci.cpp index 24b2a666569..ea7ac940810 100644 --- a/TAO/TAO_IDL/be/be_visitor_sequence/gen_bounded_sequence_ci.cpp +++ b/TAO/TAO_IDL/be/be_visitor_sequence/gen_bounded_sequence_ci.cpp @@ -22,422 +22,3 @@ ACE_RCSID (be_visitor_sequence, gen_bounded_sequence_ci, "$Id$") -int -be_visitor_sequence_ci::gen_bounded_sequence (be_sequence *node) -{ - TAO_OutStream *os = this->ctx_->stream (); - be_type *bt; - - // Retrieve the base type since we may need to do some code - // generation for the base type. - bt = be_type::narrow_from_decl (node->base_type ()); - - if (!bt) - { - ACE_ERROR_RETURN ((LM_ERROR, - "(%N:%l) be_visitor_sequence_ci::" - "visit_sequence - " - "Bad element type\n"), - -1); - } - - // If we contain an anonymous sequence, - // generate code for that sequence here. - if (bt->node_type () == AST_Decl::NT_sequence) - { - if (this->gen_anonymous_base_type (bt, - TAO_CodeGen::TAO_ROOT_CI) - == -1) - { - ACE_ERROR_RETURN ((LM_ERROR, - "(%N:%l) be_visitor_sequence_ci::" - "gen_bounded_sequence - " - "gen_anonymous_base_type failed\n"), - -1); - } - } - - // Generate the class name. - be_type *pt = 0; - - if (bt->node_type () == AST_Decl::NT_typedef) - { - // Get the primitive base type of this typedef node. - be_typedef *t = be_typedef::narrow_from_decl (bt); - pt = t->primitive_base_type (); - } - else - { - pt = bt; - } - - const char * class_name = node->instance_name (); - - static char full_class_name [NAMEBUFSIZE]; - ACE_OS::memset (full_class_name, - '\0', - NAMEBUFSIZE); - - if (node->is_nested ()) - { - be_scope *s = - be_scope::narrow_from_scope (node->defined_in ()); - - ACE_OS::sprintf (full_class_name, - "%s::%s", - s->decl ()->full_name (), - class_name); - } - else - { - ACE_OS::sprintf (full_class_name, - "%s", - class_name); - } - - - be_visitor_context ctx (*this->ctx_); - be_visitor_sequence_base visitor (&ctx); - - *os << be_nl << be_nl << "// TAO_IDL - Generated from " << be_nl - << "// " << __FILE__ << ":" << __LINE__; - - // !! Branching in either compile time template instantiation - // or manual template instatiation - os->gen_ifdef_AHETI(); - os->gen_ifdef_macro (class_name); - - // First generate the static methods since they are used by others. Since - // they are inlined, their definition needs to come before their use else - // some compilers give lots of warnings. - - // Static Operations. - // allocbuf. - *os << be_nl << be_nl - << "ACE_INLINE" << be_nl; - - // The accept is used the first time here, and if an - // error occurs, it will occur here. Later, no check - // for errors will be done. - if (bt->accept (&visitor) == -1) - { - ACE_ERROR_RETURN ((LM_ERROR, - "(%N:%l) be_visitor_sequence::" - "gen_bounded_sequence - " - "base type visit failed\n"), - -1); - } - - *os << " *" << be_nl - << full_class_name << "::allocbuf (CORBA::ULong) " << be_nl - << "{" << be_idt_nl; - - bt->accept (&visitor); - - *os << " *retval = 0;" << be_nl - << "ACE_NEW_RETURN (retval, "; - - bt->accept (&visitor); - - *os << "[" << node->max_size () << "], 0);" << be_nl - << "return retval;" << be_uidt_nl - << "}" << be_nl - << be_nl; - - // free_buf. - *os << "ACE_INLINE void " << be_nl - << full_class_name << "::freebuf ("; - - bt->accept (&visitor); - - *os << " *buffer)" << be_nl - << "{" << be_idt_nl - << "delete [] buffer;" << be_uidt_nl - << "}" << be_nl - << be_nl; - - // Default constructor. - *os << "ACE_INLINE" << be_nl - << full_class_name << "::" << class_name << " (void)" << be_nl - << " : TAO_Bounded_Base_Sequence (" << node->max_size () - << ", 0)" << be_nl - << "{" << be_nl - << "}" << be_nl - << be_nl; - - // Constructor. - *os << "ACE_INLINE" << be_nl; - *os << full_class_name << "::" << class_name << " (" << be_idt << be_idt_nl - << "CORBA::ULong length," << be_nl; - - bt->accept (&visitor); - - *os <<" *data," << be_nl - << "CORBA::Boolean release" << be_uidt_nl - << ")" << be_uidt_nl - << " : TAO_Bounded_Base_Sequence (" << node->max_size () - << ", length, data, release)" << be_nl - << "{" << be_nl - << "}" << be_nl - << be_nl; - - // Constructor. - *os << "ACE_INLINE" << be_nl - << full_class_name << "::" << class_name - << " (const " << class_name << " &rhs)" << be_idt_nl - << ": TAO_Bounded_Base_Sequence (rhs)" << be_uidt_nl - << "{" << be_idt_nl - << "if (rhs.buffer_ != 0)" << be_idt_nl - << "{" << be_idt_nl; - - bt->accept (&visitor); - - *os <<" *tmp1 =" << be_idt_nl - << class_name << "::allocbuf (" << node->max_size () - << ");" << be_uidt_nl << be_nl; - - bt->accept (&visitor); - - *os <<" * const tmp2 =" << be_idt_nl - << "ACE_reinterpret_cast ("; - - bt->accept (&visitor); - - *os << " * ACE_CAST_CONST, rhs.buffer_);" << be_uidt_nl << be_nl - << "for (CORBA::ULong i = 0; i < this->length_; ++i)" << be_idt_nl - << "{" << be_idt_nl; - - if (pt->node_type () == AST_Decl::NT_array) - { - bt->accept (&visitor); - *os << "_var::copy (tmp1[i], tmp2[i]);"; - } - else - { - *os << "tmp1[i] = tmp2[i];"; - } - - *os << be_uidt_nl - << "}" << be_uidt_nl; - - *os << be_nl - << "this->buffer_ = tmp1;" << be_uidt_nl - << "}" << be_uidt_nl - << "else" << be_idt_nl - << "{" << be_idt_nl - << "this->buffer_ = 0;" << be_uidt_nl - << "}" << be_uidt << be_uidt_nl - << "}" << be_nl - << be_nl; - - // operator=. - *os << "ACE_INLINE" << be_nl - << full_class_name << " &" << be_nl - << full_class_name << "::operator= (" << be_idt << be_idt_nl - << "const " - << class_name << " &rhs" << be_uidt_nl - << ")" << be_uidt_nl - << "{" << be_idt_nl - << "if (this == &rhs)" << be_idt_nl - << "{" << be_idt_nl - << "return *this;" << be_uidt_nl - << "}" << be_uidt_nl << be_nl - << "if (! this->release_ || this->buffer_ == 0)" << be_idt_nl - << "{" << be_idt_nl - << "this->buffer_ =" << be_idt_nl - << class_name - << "::allocbuf (rhs.maximum_);" << be_uidt << be_uidt_nl - << "}" << be_uidt_nl << be_nl - <<"TAO_Bounded_Base_Sequence::operator= (rhs);" << be_nl << be_nl; - - bt->accept (&visitor); - - *os <<"* tmp1 =" << be_idt_nl - << "ACE_reinterpret_cast ("; - - bt->accept (&visitor); - - *os << " *, this->buffer_);" << be_uidt_nl << be_nl; - - bt->accept (&visitor); - - *os <<"* const tmp2 =" << be_idt_nl - << "ACE_reinterpret_cast ("; - - bt->accept (&visitor); - - *os << " * ACE_CAST_CONST, rhs.buffer_);" << be_uidt_nl << be_nl - << "for (CORBA::ULong i = 0; i < this->length_; ++i)" << be_idt_nl - << "{" << be_idt_nl; - - if (pt->node_type () == AST_Decl::NT_array) - { - bt->accept (&visitor); - *os << "_var::copy (tmp1[i], tmp2[i]);"; - } - else - { - *os << "tmp1[i] = tmp2[i];"; - } - - *os << be_uidt_nl - << "}" << be_uidt_nl; - - *os << be_nl - << "return *this;" << be_uidt_nl - << "}" << be_nl - << be_nl; - - // Accessors. - *os << "ACE_INLINE" << be_nl; - - bt->accept (&visitor); - - *os << " &" << be_nl; - *os << full_class_name << "::operator[] (CORBA::ULong i)" << be_nl - << "{" << be_idt_nl - << "ACE_ASSERT (i < this->maximum_);" << be_nl; - - bt->accept (&visitor); - - *os <<" *tmp =" << be_idt_nl - << "ACE_reinterpret_cast ("; - - bt->accept (&visitor); - - *os << "*, this->buffer_);" << be_uidt_nl - << "return tmp[i];" << be_uidt_nl - << "}" << be_nl << be_nl; - - *os << "ACE_INLINE" << be_nl - << "const "; - - bt->accept (&visitor); - - *os << " &" << be_nl - << full_class_name << "::operator[] (CORBA::ULong i) const" - << be_nl - << "{" << be_idt_nl - << "ACE_ASSERT (i < this->maximum_);" << be_nl - << "const "; - - bt->accept (&visitor); - - *os << "* tmp =" << be_idt_nl - << "ACE_reinterpret_cast (const "; - - bt->accept (&visitor); - - *os << "* ACE_CAST_CONST, this->buffer_);" << be_uidt_nl - << "return tmp[i];" << be_uidt_nl - << "}" << be_nl - << be_nl; - - // get_buffer. - *os << "ACE_INLINE" << be_nl; - - bt->accept (&visitor); - - *os << " *" << be_nl - << full_class_name << "::get_buffer (CORBA::Boolean orphan)" << be_nl - << "{" << be_idt_nl; - - bt->accept (&visitor); - - *os << " *result = 0;" << be_nl << be_nl - << "if (orphan == 0)" << be_idt_nl - << "{" << be_idt_nl - << "// We retain ownership." << be_nl - << "if (this->buffer_ == 0)" << be_idt_nl - << "{" << be_idt_nl - << "result =" << be_idt_nl - << class_name << "::allocbuf (this->maximum_);" << be_uidt_nl - << "this->buffer_ = result;" << be_nl - << "this->release_ = 1;" << be_uidt_nl - << "}" << be_uidt_nl - << "else" << be_idt_nl - << "{" << be_idt_nl - << "result =" << be_idt_nl - << "ACE_reinterpret_cast ("; - - bt->accept (&visitor); - - *os << "*, this->buffer_);" << be_uidt << be_uidt_nl - << "}" << be_uidt << be_uidt_nl - << "}" << be_uidt_nl - << "else // if (orphan == 1)" << be_idt_nl - << "{" << be_idt_nl - << "if (this->release_ != 0)" << be_idt_nl - << "{" << be_idt_nl - << "// We set the state back to default and relinquish ownership." - << be_nl - << "result =" << be_idt_nl - << "ACE_reinterpret_cast("; - - bt->accept (&visitor); - - *os << "*, this->buffer_);" << be_uidt_nl - << "this->maximum_ = 0;" << be_nl - << "this->length_ = 0;" << be_nl - << "this->buffer_ = 0;" << be_nl - << "this->release_ = 0;" << be_uidt_nl - << "}" << be_uidt << be_uidt_nl - << "}" << be_uidt_nl << be_nl - << "return result;" << be_uidt_nl - << "}" << be_nl << be_nl; - - // get_buffer. - *os << "ACE_INLINE" << be_nl - << "const "; - - bt->accept (&visitor); - - *os << " *" << be_nl - << full_class_name << "::get_buffer (void) const" << be_nl - << "{" << be_idt_nl - << "return ACE_reinterpret_cast (const "; - - bt->accept (&visitor); - - *os << " * ACE_CAST_CONST, this->buffer_);" << be_uidt_nl - << "}" << be_nl << be_nl; - - // replace. - *os << "ACE_INLINE" << be_nl - << "void " << be_nl - << full_class_name << "::replace (" << be_idt << be_idt_nl - << "CORBA::ULong max," << be_nl - << "CORBA::ULong length," << be_nl; - - bt->accept (&visitor); - - *os <<" *data," << be_nl - << "CORBA::Boolean release" << be_uidt_nl - << ")" << be_uidt_nl - << "{" << be_idt_nl - << "this->maximum_ = max;" << be_nl - << "this->length_ = length;" << be_nl << be_nl - << "if (this->buffer_ && this->release_ == 1)" << be_idt_nl - << "{" << be_idt_nl; - - bt->accept (&visitor); - - *os <<"* tmp =" << be_idt_nl - << "ACE_reinterpret_cast ("; - - bt->accept (&visitor); - - *os << "* ACE_CAST_CONST, this->buffer_);" << be_uidt_nl - << class_name << "::freebuf (tmp);" << be_uidt_nl - << "}" << be_uidt_nl << be_nl - << "this->buffer_ = data;" << be_nl - << "this->release_ = release;" << be_uidt_nl - << "}"; - - os->gen_endif (); - - // Generate #endif for AHETI. - os->gen_endif_AHETI(); - - return 0; -} |