summaryrefslogtreecommitdiff
path: root/TAO/TAO_IDL/ast/ast_array.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'TAO/TAO_IDL/ast/ast_array.cpp')
-rw-r--r--TAO/TAO_IDL/ast/ast_array.cpp283
1 files changed, 283 insertions, 0 deletions
diff --git a/TAO/TAO_IDL/ast/ast_array.cpp b/TAO/TAO_IDL/ast/ast_array.cpp
new file mode 100644
index 00000000000..9f602b8633a
--- /dev/null
+++ b/TAO/TAO_IDL/ast/ast_array.cpp
@@ -0,0 +1,283 @@
+// $Id$
+
+/*
+
+COPYRIGHT
+
+Copyright 1992, 1993, 1994 Sun Microsystems, Inc. Printed in the United
+States of America. All Rights Reserved.
+
+This product is protected by copyright and distributed under the following
+license restricting its use.
+
+The Interface Definition Language Compiler Front End (CFE) is made
+available for your use provided that you include this license and copyright
+notice on all media and documentation and the software program in which
+this product is incorporated in whole or part. You may copy and extend
+functionality (but may not remove functionality) of the Interface
+Definition Language CFE without charge, but you are not authorized to
+license or distribute it to anyone else except as part of a product or
+program developed by you or with the express written consent of Sun
+Microsystems, Inc. ("Sun").
+
+The names of Sun Microsystems, Inc. and any of its subsidiaries or
+affiliates may not be used in advertising or publicity pertaining to
+distribution of Interface Definition Language CFE as permitted herein.
+
+This license is effective until terminated by Sun for failure to comply
+with this license. Upon termination, you shall destroy or return all code
+and documentation for the Interface Definition Language CFE.
+
+INTERFACE DEFINITION LANGUAGE CFE IS PROVIDED AS IS WITH NO WARRANTIES OF
+ANY KIND INCLUDING THE WARRANTIES OF DESIGN, MERCHANTIBILITY AND FITNESS
+FOR A PARTICULAR PURPOSE, NONINFRINGEMENT, OR ARISING FROM A COURSE OF
+DEALING, USAGE OR TRADE PRACTICE.
+
+INTERFACE DEFINITION LANGUAGE CFE IS PROVIDED WITH NO SUPPORT AND WITHOUT
+ANY OBLIGATION ON THE PART OF Sun OR ANY OF ITS SUBSIDIARIES OR AFFILIATES
+TO ASSIST IN ITS USE, CORRECTION, MODIFICATION OR ENHANCEMENT.
+
+SUN OR ANY OF ITS SUBSIDIARIES OR AFFILIATES SHALL HAVE NO LIABILITY WITH
+RESPECT TO THE INFRINGEMENT OF COPYRIGHTS, TRADE SECRETS OR ANY PATENTS BY
+INTERFACE DEFINITION LANGUAGE CFE OR ANY PART THEREOF.
+
+IN NO EVENT WILL SUN OR ANY OF ITS SUBSIDIARIES OR AFFILIATES BE LIABLE FOR
+ANY LOST REVENUE OR PROFITS OR OTHER SPECIAL, INDIRECT AND CONSEQUENTIAL
+DAMAGES, EVEN IF SUN HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
+
+Use, duplication, or disclosure by the government is subject to
+restrictions as set forth in subparagraph (c)(1)(ii) of the Rights in
+Technical Data and Computer Software clause at DFARS 252.227-7013 and FAR
+52.227-19.
+
+Sun, Sun Microsystems and the Sun logo are trademarks or registered
+trademarks of Sun Microsystems, Inc.
+
+SunSoft, Inc.
+2550 Garcia Avenue
+Mountain View, California 94043
+
+NOTE:
+
+SunOS, SunSoft, Sun, Solaris, Sun Microsystems or the Sun logo are
+trademarks or registered trademarks of Sun Microsystems, Inc.
+
+*/
+
+// AST_Array nodes denote array type and field modifiers.
+// AST_Array nodes have a list of dimensions (a UTL_ExprList)
+// a count of the number of dimensions and a base type (a
+// subtype of AST_ConcreteType. This means that we cannot have
+// arrays of AST_Interfaces???
+
+#include "ast_array.h"
+#include "ast_expression.h"
+#include "ast_visitor.h"
+#include "utl_exprlist.h"
+#include "utl_identifier.h"
+#include "ace/Log_Msg.h"
+#include "ace/OS_Memory.h"
+
+ACE_RCSID (ast,
+ ast_array,
+ "$Id$")
+
+// Constructor(s) and destructor.
+
+AST_Array::AST_Array (void)
+ : COMMON_Base (),
+ AST_Decl (),
+ AST_Type (),
+ AST_ConcreteType (),
+ pd_n_dims (0),
+ pd_dims (0),
+ pd_base_type (0),
+ owns_base_type_ (false)
+{
+}
+
+AST_Array::AST_Array (UTL_ScopedName *n,
+ unsigned long nd,
+ UTL_ExprList *ds,
+ bool local,
+ bool abstract)
+ : COMMON_Base (local,
+ abstract),
+ AST_Decl (AST_Decl::NT_array,
+ n,
+ true),
+ AST_Type (AST_Decl::NT_array,
+ n),
+ AST_ConcreteType (AST_Decl::NT_array,
+ n),
+ pd_n_dims (nd),
+ pd_base_type (0),
+ owns_base_type_ (false)
+{
+ this->pd_dims = this->compute_dims (ds,
+ nd);
+}
+
+AST_Array::~AST_Array (void)
+{
+}
+
+// Private operations.
+
+// Compute how many dimensions there are and collect their expressions
+// into an array.
+AST_Expression **
+AST_Array::compute_dims (UTL_ExprList *ds,
+ unsigned long nds)
+{
+ if (ds == 0)
+ {
+ return 0;
+ }
+
+ AST_Expression **result = 0;
+ ACE_NEW_RETURN (result,
+ AST_Expression *[nds],
+ 0);
+
+ UTL_ExprlistActiveIterator iter (ds);
+
+ for (unsigned long i = 0;
+ !iter.is_done () && i < nds;
+ iter.next (), i++)
+ {
+ AST_Expression *orig = iter.item ();
+ AST_Expression *copy = 0;
+ ACE_NEW_RETURN (copy,
+ AST_Expression (orig,
+ orig->ev ()->et),
+ 0);
+ result[i] = copy;
+ }
+
+ return result;
+}
+
+// Redefinition of inherited virtual operations.
+
+// Dump this AST_Array node to the ostream o.
+void
+AST_Array::dump (ACE_OSTREAM_TYPE &o)
+{
+ pd_base_type->dump (o);
+
+ this->dump_i (o, " ");
+
+ this->local_name ()->dump (o);
+
+ for (unsigned long i = 0; i < this->pd_n_dims; i++)
+ {
+ this->dump_i (o, "[");
+
+ pd_dims[i]->dump (o);
+
+ this->dump_i (o, "]");
+ }
+}
+
+int
+AST_Array::ast_accept (ast_visitor *visitor)
+{
+ return visitor->visit_array (this);
+}
+
+// Compute the size type of the node in question.
+int
+AST_Array::compute_size_type (void)
+{
+ AST_Type *type = this->base_type ();
+
+ if (!type)
+ {
+ ACE_ERROR_RETURN ((LM_ERROR,
+ "(%N:%l) be_array::compute_size_type - "
+ "bad base type\n"),
+ -1);
+ }
+
+ // Our size type is the same as our type.
+ this->size_type (type->size_type ());
+
+ this->has_constructor (type->has_constructor ());
+
+ return 0;
+}
+
+// Data accessors.
+unsigned long
+AST_Array::n_dims (void)
+{
+ return this->pd_n_dims;
+}
+
+AST_Expression **
+AST_Array::dims (void)
+{
+ return this->pd_dims;
+}
+
+AST_Type *
+AST_Array::base_type (void) const
+{
+ return this->pd_base_type;
+}
+
+void
+AST_Array::set_base_type (AST_Type *nbt)
+{
+ this->pd_base_type = nbt;
+
+ this->is_local_ = nbt->is_local ();
+
+ if (AST_Decl::NT_sequence == nbt->node_type ())
+ {
+ this->owns_base_type_ = true;
+ }
+}
+
+bool
+AST_Array::legal_for_primary_key (void) const
+{
+ return this->base_type ()->legal_for_primary_key ();
+}
+
+void
+AST_Array::destroy (void)
+{
+ if (this->owns_base_type_)
+ {
+ this->pd_base_type->destroy ();
+ delete this->pd_base_type;
+ this->pd_base_type = 0;
+ }
+
+ for (unsigned long i = 0; i < this->pd_n_dims; ++i)
+ {
+ this->pd_dims[i]->destroy ();
+ delete this->pd_dims[i];
+ this->pd_dims[i] = 0;
+ }
+
+ delete [] this->pd_dims;
+ this->pd_dims = 0;
+ this->pd_n_dims = 0;
+
+ this->AST_ConcreteType::destroy ();
+}
+
+void
+AST_Array::set_dims (AST_Expression **ds,
+ unsigned long nds)
+{
+ this->pd_dims = ds;
+ this->pd_n_dims = nds;
+}
+
+// Narrowing methods.
+IMPL_NARROW_METHODS1(AST_Array, AST_ConcreteType)
+IMPL_NARROW_FROM_DECL(AST_Array)