5 Copyright 1992, 1993, 1994 Sun Microsystems, Inc. Printed in the United
6 States of America. All Rights Reserved.
8 This product is protected by copyright and distributed under the following
9 license restricting its use.
11 The Interface Definition Language Compiler Front End (CFE) is made
12 available for your use provided that you include this license and copyright
13 notice on all media and documentation and the software program in which
14 this product is incorporated in whole or part. You may copy and extend
15 functionality (but may not remove functionality) of the Interface
16 Definition Language CFE without charge, but you are not authorized to
17 license or distribute it to anyone else except as part of a product or
18 program developed by you or with the express written consent of Sun
19 Microsystems, Inc. ("Sun").
21 The names of Sun Microsystems, Inc. and any of its subsidiaries or
22 affiliates may not be used in advertising or publicity pertaining to
23 distribution of Interface Definition Language CFE as permitted herein.
25 This license is effective until terminated by Sun for failure to comply
26 with this license. Upon termination, you shall destroy or return all code
27 and documentation for the Interface Definition Language CFE.
29 INTERFACE DEFINITION LANGUAGE CFE IS PROVIDED AS IS WITH NO WARRANTIES OF
30 ANY KIND INCLUDING THE WARRANTIES OF DESIGN, MERCHANTIBILITY AND FITNESS
31 FOR A PARTICULAR PURPOSE, NONINFRINGEMENT, OR ARISING FROM A COURSE OF
32 DEALING, USAGE OR TRADE PRACTICE.
34 INTERFACE DEFINITION LANGUAGE CFE IS PROVIDED WITH NO SUPPORT AND WITHOUT
35 ANY OBLIGATION ON THE PART OF Sun OR ANY OF ITS SUBSIDIARIES OR AFFILIATES
36 TO ASSIST IN ITS USE, CORRECTION, MODIFICATION OR ENHANCEMENT.
38 SUN OR ANY OF ITS SUBSIDIARIES OR AFFILIATES SHALL HAVE NO LIABILITY WITH
39 RESPECT TO THE INFRINGEMENT OF COPYRIGHTS, TRADE SECRETS OR ANY PATENTS BY
40 INTERFACE DEFINITION LANGUAGE CFE OR ANY PART THEREOF.
42 IN NO EVENT WILL SUN OR ANY OF ITS SUBSIDIARIES OR AFFILIATES BE LIABLE FOR
43 ANY LOST REVENUE OR PROFITS OR OTHER SPECIAL, INDIRECT AND CONSEQUENTIAL
44 DAMAGES, EVEN IF SUN HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES.
46 Use, duplication, or disclosure by the government is subject to
47 restrictions as set forth in subparagraph (c)(1)(ii) of the Rights in
48 Technical Data and Computer Software clause at DFARS 252.227-7013 and FAR
51 Sun, Sun Microsystems and the Sun logo are trademarks or registered
52 trademarks of Sun Microsystems, Inc.
56 Mountain View, California 94043
60 SunOS, SunSoft, Sun, Solaris, Sun Microsystems or the Sun logo are
61 trademarks or registered trademarks of Sun Microsystems, Inc.
65 #include "utl_scope.h"
66 #include "utl_identifier.h"
68 #include "utl_indenter.h"
69 #include "utl_string.h"
70 #include "utl_strlist.h"
71 #include "ast_valuebox.h"
72 #include "ast_valuetype.h"
73 #include "ast_valuetype_fwd.h"
74 #include "ast_eventtype.h"
75 #include "ast_eventtype_fwd.h"
76 #include "ast_component.h"
77 #include "ast_component_fwd.h"
79 #include "ast_porttype.h"
80 #include "ast_template_module.h"
81 #include "ast_template_module_ref.h"
82 #include "ast_template_module_inst.h"
83 #include "ast_typedef.h"
86 #include "ast_array.h"
88 #include "ast_concrete_type.h"
89 #include "ast_sequence.h"
90 #include "ast_string.h"
91 #include "ast_structure_fwd.h"
92 #include "ast_exception.h"
93 #include "ast_constant.h"
94 #include "ast_attribute.h"
95 #include "ast_operation.h"
96 #include "ast_argument.h"
97 #include "ast_param_holder.h"
98 #include "ast_union.h"
99 #include "ast_union_fwd.h"
100 #include "ast_union_branch.h"
101 #include "ast_field.h"
102 #include "ast_enum_val.h"
103 #include "ast_native.h"
104 #include "ast_factory.h"
105 #include "ast_visitor.h"
106 #include "ast_generator.h"
107 #include "ast_extern.h"
109 #include "fe_extern.h"
110 #include "nr_extern.h"
111 #include "global_extern.h"
113 #include "ace/OS_NS_strings.h"
115 // FUZZ: disable check_for_streams_include
116 #include "ace/streams.h"
123 UTL_Scope::UTL_Scope ()
124 : pd_scope_node_type (AST_Decl::NT_module
),
126 pd_decls_allocated (0),
128 pd_local_types (nullptr),
129 pd_locals_allocated (0),
131 pd_referenced (nullptr),
132 pd_referenced_allocated (0),
133 pd_referenced_used (0),
134 pd_name_referenced (nullptr),
135 pd_name_referenced_allocated (0),
136 pd_name_referenced_used (0),
138 which_pseudo_ (PSEUDO_ABSTRACTBASE
)
142 UTL_Scope::UTL_Scope (AST_Decl::NodeType nt
)
143 : pd_scope_node_type (nt
),
145 pd_decls_allocated (0),
147 pd_local_types (nullptr),
148 pd_locals_allocated (0),
150 pd_referenced (nullptr),
151 pd_referenced_allocated (0),
152 pd_referenced_used (0),
153 pd_name_referenced (nullptr),
154 pd_name_referenced_allocated (0),
155 pd_name_referenced_used (0),
157 which_pseudo_ (PSEUDO_ABSTRACTBASE
)
162 UTL_Scope::~UTL_Scope ()
164 for (UTL_ScopeActiveIterator
iter (this, IK_both
);
168 AST_Decl
*d
= iter
.item ();
173 delete [] this->pd_decls
;
174 delete [] this->pd_local_types
;
175 delete [] this->pd_referenced
;
177 for (long i
= this->pd_name_referenced_used
; i
--;) // NOTE test with i--
179 Identifier
*id
= this->pd_name_referenced
[i
];
184 delete [] this->pd_name_referenced
;
188 UTL_Scope::destroy ()
190 for (UTL_ScopeActiveIterator
iter (this, IK_both
);
194 AST_Decl
*d
= iter
.item ();
199 delete [] this->pd_decls
;
200 this->pd_decls
= nullptr;
201 this->pd_decls_allocated
= 0;
202 this->pd_decls_used
= 0;
204 delete [] this->pd_local_types
;
205 this->pd_local_types
= nullptr;
206 this->pd_locals_allocated
= 0;
207 this->pd_locals_used
= 0;
209 delete [] this->pd_referenced
;
210 this->pd_referenced
= nullptr;
211 this->pd_referenced_allocated
= 0;
212 this->pd_referenced_used
= 0;
214 for (long i
= this->pd_name_referenced_used
; i
--;) // NOTE test with i--
216 Identifier
*id
= this->pd_name_referenced
[i
];
221 delete [] this->pd_name_referenced
;
222 this->pd_name_referenced
= nullptr;
223 this->pd_name_referenced_allocated
= 0;
224 this->pd_name_referenced_used
= 0;
227 // Protected operations.
229 // Special version of lookup which only looks at the local name instead of
230 // the fully scoped name, when doing lookups. This version is intended to
231 // be used only by the frontend add_xxx functions.
233 UTL_Scope::lookup_for_add (AST_Decl
*d
)
240 Identifier
*id
= d
->local_name ();
241 if (this->idl_keyword_clash (id
))
246 return this->lookup_by_name_local (id
, false);
250 UTL_Scope::idl_keyword_clash (Identifier
*e
)
257 // Convert the identifier string into a
258 // canonical (uppercase) form as a ACE_CString
259 char *tmp
= e
->get_string ();
260 ACE_CString
ext_id (tmp
);
261 UTL_String::get_canonical_rep (ext_id
);
263 if (!idl_global
->idl_keywords ().find (ext_id
))
265 if (idl_global
->case_diff_error ())
267 idl_global
->err ()->idl_keyword_error (tmp
);
272 idl_global
->err ()->idl_keyword_warning (tmp
);
279 UTL_Scope::redef_clash (AST_Decl::NodeType new_nt
,
280 AST_Decl::NodeType scope_elem_nt
)
284 case AST_Decl::NT_module
:
285 return scope_elem_nt
!= AST_Decl::NT_module
;
287 case AST_Decl::NT_struct
:
288 case AST_Decl::NT_struct_fwd
:
289 return scope_elem_nt
!= AST_Decl::NT_struct_fwd
;
291 case AST_Decl::NT_union
:
292 case AST_Decl::NT_union_fwd
:
293 return scope_elem_nt
!= AST_Decl::NT_union_fwd
;
295 case AST_Decl::NT_interface
:
296 return scope_elem_nt
!= AST_Decl::NT_interface_fwd
;
298 case AST_Decl::NT_component
:
299 return scope_elem_nt
!= AST_Decl::NT_component_fwd
;
301 case AST_Decl::NT_interface_fwd
:
302 return ( scope_elem_nt
!= AST_Decl::NT_interface_fwd
303 && scope_elem_nt
!= AST_Decl::NT_interface
);
305 case AST_Decl::NT_component_fwd
:
306 return ( scope_elem_nt
!= AST_Decl::NT_component_fwd
307 && scope_elem_nt
!= AST_Decl::NT_component
);
309 case AST_Decl::NT_valuetype
:
310 return scope_elem_nt
!= AST_Decl::NT_valuetype_fwd
;
312 case AST_Decl::NT_eventtype
:
313 return scope_elem_nt
!= AST_Decl::NT_eventtype_fwd
;
315 case AST_Decl::NT_valuetype_fwd
:
316 return ( scope_elem_nt
!= AST_Decl::NT_valuetype_fwd
317 && scope_elem_nt
!= AST_Decl::NT_valuetype
);
319 case AST_Decl::NT_eventtype_fwd
:
320 return ( scope_elem_nt
!= AST_Decl::NT_eventtype_fwd
321 && scope_elem_nt
!= AST_Decl::NT_eventtype
);
329 UTL_Scope::check_for_predef_seq (AST_Decl
*d
)
331 // Right now, we're interested only in predefined sequences
332 // referenced in the main IDL file. If we are processing
333 // multiple IDL files in one execution, the bits will
334 // stay set, and be accumulated as each file is parsed.
335 if (!idl_global
->in_main_file ())
340 AST_Type
*bt
= nullptr;
341 AST_Decl::NodeType nt
= d
->node_type ();
343 // We are interested only in members, arguments and typedefs.
346 case AST_Decl::NT_field
:
347 case AST_Decl::NT_union_branch
:
348 case AST_Decl::NT_attr
:
349 case AST_Decl::NT_argument
:
350 bt
= dynamic_cast<AST_Field
*> (d
)->field_type ();
353 case AST_Decl::NT_typedef
:
354 bt
= dynamic_cast<AST_Typedef
*> (d
)->base_type ();
361 // Check to eliminate more candidates.
362 if (!bt
->imported () || bt
->node_type () != AST_Decl::NT_typedef
)
367 bt
= dynamic_cast<AST_Typedef
*> (bt
)->base_type ();
368 nt
= bt
->node_type ();
370 // Must be a sequence with only one level of typedef.
371 if (nt
!= AST_Decl::NT_sequence
)
376 // Must be defined in the CORBA module.
377 AST_Decl
*p
= ScopeAsDecl (bt
->defined_in ());
378 if (ACE_OS::strcmp (p
->local_name ()->get_string (), "CORBA"))
383 // We know this narrowing will be successful.
384 bt
= dynamic_cast<AST_Sequence
*> (bt
)->base_type ();
385 nt
= bt
->node_type ();
387 // First check for string or wstring base type.
388 if (nt
== AST_Decl::NT_string
)
390 idl_global
->string_seq_seen_
= true;
394 if (nt
== AST_Decl::NT_wstring
)
396 idl_global
->wstring_seq_seen_
= true;
400 // Now check for predefined base type.
401 AST_PredefinedType
*pdt
= dynamic_cast<AST_PredefinedType
*> (bt
);
409 case AST_PredefinedType::PT_long
:
410 idl_global
->long_seq_seen_
= true;
413 case AST_PredefinedType::PT_ulong
:
414 idl_global
->ulong_seq_seen_
= true;
417 case AST_PredefinedType::PT_longlong
:
418 idl_global
->longlong_seq_seen_
= true;
421 case AST_PredefinedType::PT_ulonglong
:
422 idl_global
->ulonglong_seq_seen_
= true;
425 case AST_PredefinedType::PT_short
:
426 idl_global
->short_seq_seen_
= true;
429 case AST_PredefinedType::PT_ushort
:
430 idl_global
->ushort_seq_seen_
= true;
433 case AST_PredefinedType::PT_float
:
434 idl_global
->float_seq_seen_
= true;
437 case AST_PredefinedType::PT_double
:
438 idl_global
->double_seq_seen_
= true;
441 case AST_PredefinedType::PT_longdouble
:
442 idl_global
->longdouble_seq_seen_
= true;
445 case AST_PredefinedType::PT_char
:
446 idl_global
->char_seq_seen_
= true;
449 case AST_PredefinedType::PT_wchar
:
450 idl_global
->wchar_seq_seen_
= true;
453 case AST_PredefinedType::PT_boolean
:
454 idl_global
->boolean_seq_seen_
= true;
457 case AST_PredefinedType::PT_octet
:
458 idl_global
->octet_seq_seen_
= true;
461 case AST_PredefinedType::PT_any
:
462 idl_global
->any_seq_seen_
= true;
470 // Protected Front End Scope Management Protocol.
472 // All members of the protocol defined in UTL_Scope simply return NULL
473 // and don't do a thing. This ensures that runtime errors will discover
474 // operations which should have been redefined to allow certain kinds of
475 // AST nodes to appear in a given context.
478 UTL_Scope::fe_add_decl (AST_Decl
*t
)
480 // Already defined and cannot be redefined? Or already used?
481 AST_Decl
*d
= this->lookup_for_add (t
);
485 if (!FE_Utils::can_be_redefined (d
, t
))
487 idl_global
->err ()->error3 (UTL_Error::EIDL_REDEF
,
494 // For convenience, AST_Template_Module_Inst inherits
495 // from AST_Field, but has a node type of NT_module.
496 // Since we then can't add it using fe_add_module(), a
497 // check is needed here to avoid a redefinition error,
498 // if the instantiated module is meant to reopen a
501 AST_Decl::NodeType lnt
= d
->node_type ();
502 AST_Decl::NodeType ant
= t
->node_type ();
503 bool need_ref_check
=
504 ( lnt
!= AST_Decl::NT_module
505 || ant
!= AST_Decl::NT_module
);
507 if (need_ref_check
&& this->referenced (d
, t
->local_name ()))
509 idl_global
->err ()->error3 (UTL_Error::EIDL_DEF_USE
,
516 if (t
->has_ancestor (d
))
518 idl_global
->err ()->redefinition_in_scope (t
, d
);
522 else if (this->inherited_op_attr_clash (t
))
527 if (this->arg_specific_error (t
))
532 this->smart_local_add (t
);
534 // Add it to set of locally referenced symbols, unless it is
535 // a home, in which case it will clash when the equivalent
536 // interface is created.
537 if (t
->node_type () != AST_Decl::NT_home
)
539 this->add_to_referenced (t
,
548 UTL_Scope::fe_add_ref_decl (AST_Field
*t
)
550 AST_Decl
*d
= this->fe_add_decl (t
);
553 AST_Type
*ft
= t
->field_type ();
554 UTL_ScopedName
*mru
= ft
->last_referenced_as ();
557 this->add_to_referenced (ft
,
559 mru
->first_component ());
563 // Catches struct/union/exception which all maintain a queue
564 // for fields as distinct from decls and enum values.
565 AST_Structure
*s
= dynamic_cast<AST_Structure
*> (this);
568 s
->fields ().enqueue_tail (t
);
571 return dynamic_cast<AST_Field
*> (d
);
575 UTL_Scope::fe_add_full_struct_type (AST_Structure
*t
)
577 AST_Decl
*predef
= this->lookup_for_add (t
);
581 if (!FE_Utils::can_be_redefined (predef
, t
))
583 idl_global
->err ()->error3 (UTL_Error::EIDL_REDEF
,
590 if (referenced (predef
, t
->local_name ()) && !t
->is_defined ())
592 idl_global
->err ()->error3 (UTL_Error::EIDL_DEF_USE
,
600 AST_Decl::NodeType nt
= ScopeAsDecl (this)->node_type ();
602 // Decls inside a struct or union are also referenced by
603 // fields, and so must be handled differently.
604 if ( nt
== AST_Decl::NT_struct
605 || nt
== AST_Decl::NT_union
606 || nt
== AST_Decl::NT_except
)
608 this->add_to_local_types (t
);
612 this->add_to_scope (t
);
615 // Add it to set of locally referenced symbols.
616 this->add_to_referenced (t
,
623 UTL_Scope::fe_add_fwd_struct_type (AST_StructureFwd
*t
)
625 // Already defined and cannot be redefined? Or already used?
626 AST_Decl
*d
= this->lookup_for_add (t
);
629 // There used to be another check here ANDed with the one below:
630 // d->defined_in () == this. But lookup_for_add() calls only
631 // lookup_by_name_local(), which does not bump up the scope,
632 // and look_in_prev_mods() for modules. If look_in_prev_mods()
633 // finds something, the scopes will NOT be the same pointer
634 // value, but the result is what we want.
635 if (d
->node_type () == AST_Decl::NT_struct
)
637 t
->set_full_definition (dynamic_cast<AST_Structure
*> (d
));
639 else if (!FE_Utils::can_be_redefined (d
, t
))
641 idl_global
->err ()->error3 (UTL_Error::EIDL_REDEF
,
647 else if (this->referenced (d
, t
->local_name ()))
649 idl_global
->err ()->error3 (UTL_Error::EIDL_DEF_USE
,
658 this->add_to_scope (t
);
660 // Add it to set of locally referenced symbols
661 this->add_to_referenced (t
,
665 // Must check later that all struct and union forward declarations
666 // are defined in the same IDL file.
667 AST_record_fwd_decl (t
);
672 UTL_Scope::fe_add_predefined_type (AST_PredefinedType
*)
678 UTL_Scope::fe_add_module (AST_Module
*)
683 AST_Template_Module_Inst
*
684 UTL_Scope::fe_add_template_module_inst (AST_Template_Module_Inst
*)
689 AST_Template_Module_Ref
*
690 UTL_Scope::fe_add_template_module_ref (AST_Template_Module_Ref
*)
696 UTL_Scope::fe_add_interface (AST_Interface
*)
702 UTL_Scope::fe_add_interface_fwd (AST_InterfaceFwd
*)
708 UTL_Scope::fe_add_valuebox (AST_ValueBox
*)
714 UTL_Scope::fe_add_valuetype (AST_ValueType
*)
720 UTL_Scope::fe_add_valuetype_fwd (AST_ValueTypeFwd
*)
726 UTL_Scope::fe_add_eventtype (AST_EventType
*)
732 UTL_Scope::fe_add_eventtype_fwd (AST_EventTypeFwd
*)
738 UTL_Scope::fe_add_component (AST_Component
*)
744 UTL_Scope::fe_add_component_fwd (AST_ComponentFwd
*)
750 UTL_Scope::fe_add_home (AST_Home
*)
756 UTL_Scope::fe_add_exception (AST_Exception
*)
762 UTL_Scope::fe_add_constant (AST_Constant
*)
768 UTL_Scope::fe_add_context (UTL_StrList
*)
774 UTL_Scope::fe_add_exceptions (UTL_NameList
*)
780 UTL_Scope::fe_add_attribute (AST_Attribute
*)
786 UTL_Scope::fe_add_operation (AST_Operation
*)
792 UTL_Scope::fe_add_argument (AST_Argument
*)
798 UTL_Scope::fe_add_union (AST_Union
*)
804 UTL_Scope::fe_add_union_fwd (AST_UnionFwd
*)
810 UTL_Scope::fe_add_union_branch (AST_UnionBranch
*)
816 UTL_Scope::fe_add_structure (AST_Structure
*)
822 UTL_Scope::fe_add_structure_fwd (AST_StructureFwd
*)
828 UTL_Scope::fe_add_field (AST_Field
*)
834 UTL_Scope::fe_add_enum (AST_Enum
*)
840 UTL_Scope::fe_add_enum_val (AST_EnumVal
*)
846 UTL_Scope::fe_add_typedef (AST_Typedef
*)
852 UTL_Scope::fe_add_sequence (AST_Sequence
*)
858 UTL_Scope::fe_add_string (AST_String
*)
864 UTL_Scope::fe_add_array (AST_Array
*)
870 UTL_Scope::fe_add_native (AST_Native
*)
876 UTL_Scope::fe_add_factory (AST_Factory
*)
882 UTL_Scope::fe_add_finder (AST_Finder
*)
888 UTL_Scope::fe_add_porttype (AST_PortType
*)
894 UTL_Scope::fe_add_provides (AST_Provides
*)
900 UTL_Scope::fe_add_uses (AST_Uses
*)
906 UTL_Scope::fe_add_publishes (AST_Publishes
*)
912 UTL_Scope::fe_add_emits (AST_Emits
*)
918 UTL_Scope::fe_add_consumes (AST_Consumes
*)
924 UTL_Scope::fe_add_extended_port (AST_Extended_Port
*)
930 UTL_Scope::fe_add_mirror_port (AST_Mirror_Port
*)
936 UTL_Scope::fe_add_connector (AST_Connector
*)
941 // Private lookup mechanism.
943 // For dealing with lookups of 'Object' and 'TypeCode'.
945 UTL_Scope::lookup_pseudo (Identifier
*e
)
952 bool *seen
= nullptr;
953 char *name_string
= e
->get_string ();
954 UTL_Scope
*start_scope
= idl_global
->corba_module ();
956 if (ACE_OS::strcasecmp (name_string
, "TypeCode") == 0
957 || ACE_OS::strcasecmp (name_string
, "TCKind") == 0)
959 this->which_pseudo_
= PSEUDO_TYPECODE
;
961 seen
= &idl_global
->typecode_seen_
;
963 else if (ACE_OS::strcasecmp (name_string
, "Object") == 0)
965 this->which_pseudo_
= PSEUDO_OBJECT
;
966 seen
= &idl_global
->base_object_seen_
;
968 else if (ACE_OS::strcasecmp (name_string
, "ValueBase") == 0)
970 this->which_pseudo_
= PSEUDO_VALUEBASE
;
971 seen
= &idl_global
->valuebase_seen_
;
973 else if (ACE_OS::strcasecmp (name_string
, "AbstractBase") == 0)
975 this->which_pseudo_
= PSEUDO_ABSTRACTBASE
;
976 seen
= &idl_global
->abstractbase_seen_
;
983 for (UTL_ScopeActiveIterator
i (start_scope
, IK_decls
);
987 AST_Decl
*d
= i
.item ();
989 if (e
->case_compare (d
->local_name ()))
991 // These have to be located here because we are just looking
992 // up a scoped name - skip for imported nodes.
993 if (idl_global
->in_main_file ())
1002 if (this->which_pseudo_
== PSEUDO_TYPECODE
)
1004 AST_Decl
*d
= this->look_in_prev_mods_local (e
);
1008 // Generation of #includes for Typecode.h
1009 // checks this bit, so we set it for TCKind as well.
1019 UTL_Scope::look_in_prev_mods_local (Identifier
*,
1020 bool /* ignore_fwd */)
1026 UTL_Scope::special_lookup (UTL_ScopedName
*,
1027 bool /* full_def_only */,
1028 AST_Decl
*&/*final_parent_decl*/)
1033 // Lookup the node for a primitive (built-in) type.
1035 UTL_Scope::lookup_primitive_type (AST_Expression::ExprType et
)
1037 UTL_Scope
*search
= idl_global
->corba_module ();
1039 AST_PredefinedType::PredefinedType pdt
=
1040 FE_Utils::ExprTypeToPredefinedType (et
);
1042 /// This return value means there was no PredefinedType match
1043 /// for the ExprType.
1044 if (pdt
== AST_PredefinedType::PT_pseudo
)
1049 /// The only 'predefined type' not in the CORBA module.
1050 if (pdt
== AST_PredefinedType::PT_void
)
1052 search
= idl_global
->root ();
1055 for (UTL_ScopeActiveIterator
i (search
, IK_decls
);
1059 AST_Decl
*as_decl
= i
.item ();
1061 if (as_decl
->node_type () == AST_Decl::NT_pre_defined
)
1063 AST_PredefinedType
*t
=
1064 dynamic_cast<AST_PredefinedType
*> (as_decl
);
1066 if (t
->pt () == pdt
)
1068 if (idl_global
->in_main_file ())
1072 case AST_PredefinedType::PT_any
:
1073 idl_global
->any_seen_
= true;
1075 case AST_PredefinedType::PT_object
:
1076 idl_global
->base_object_seen_
= true;
1091 // Look through inherited list. Overridden in AST_Interface.
1093 UTL_Scope::look_in_inherited (UTL_ScopedName
*,
1099 // Look through supported interface list. Overridden where necessary.
1101 UTL_Scope::look_in_supported (UTL_ScopedName
*,
1108 UTL_Scope::lookup_by_name_local (Identifier
*e
,
1111 // Will catch Object, TypeCode, TCKind, ValueBase and
1112 // AbstractBase. A non-zero result of this lookup determines the
1113 // generation of some #includes and, whether successful or not,
1114 // incurs no extra overhead.
1115 AST_Decl
*d
= this->lookup_pseudo (e
);
1121 if (this->idl_keyword_clash (e
))
1126 bool in_corba
= (ACE_OS::strcmp (e
->get_string (), "CORBA") == 0);
1128 // We search only the decls here, the local types are done
1129 // below as a last resort.
1130 for (UTL_ScopeActiveIterator
i (this, IK_decls
);
1134 d
= i
.item ()->adjust_found (true, full_def_only
);
1138 Identifier
*item_name
= d
->local_name ();
1140 if (item_name
!= nullptr
1141 // Right now we populate the global scope with all the CORBA basic
1142 // types, so something like 'ULong' in an IDL file will find a
1143 // match, unless we skip over these items. This is a workaround until
1144 // there's time to fix the code generation for CORBA basic types.
1146 || (ACE_OS::strcmp (d
->name ()->head ()->get_string (), "CORBA") != 0))
1147 && e
->case_compare (item_name
))
1149 return d
; // We have found the one and only one we are looking for.
1154 // Ok the name wasn't found in the current scope, if this
1155 // scope is a module, we can check it's previous openings!
1156 AST_Module
*m
= dynamic_cast<AST_Module
*> (this);
1159 d
= m
->look_in_prev_mods_local (e
);
1160 if (d
&& (!full_def_only
|| d
->is_defined ()))
1167 // Or if this scope is an interface, we can check if
1168 // it was inherited!
1169 AST_Interface
*i
= dynamic_cast<AST_Interface
*> (this);
1172 d
= i
->look_in_inherited_local (e
);
1180 // There are some cases where the iteration over IK_decls
1181 // above will fail because what we're searching for has been
1182 // added only to the local types. It's less complicated to
1183 // do the iteration below only as a last resort.
1184 for (UTL_ScopeActiveIterator
i (this, IK_localtypes
);
1189 if (e
->case_compare (d
->local_name ()))
1199 UTL_Scope::lookup_by_name (UTL_ScopedName
*e
,
1203 // Empty name? Exit immediately.
1209 UTL_Scope
*work
= this;
1211 // If name starts with "::" or "" start lookup in global scope,
1212 // if we're not there already, short_circuiting the
1213 // scope-expanding iteration below.
1214 Identifier
*name
= e
->head ();
1215 const bool global_scope_name
= work
->is_global_name (name
);
1216 if (global_scope_name
)
1218 // No tail, exit directly
1219 UTL_List
* tail
= e
->tail ();
1224 // Remove the preceeding "::" or "" from the scopename
1225 e
= static_cast<UTL_ScopedName
*> (tail
);
1228 // Move directly to the root scope
1229 work
= idl_global
->root ();
1232 AST_Decl
*first_found_final_parent_decl
= nullptr;
1233 const bool searching_module_path
= (e
->length () != 1);
1234 AST_Decl
*d
= searching_module_path
?
1235 work
->lookup_by_name_r (e
, full_def_only
, first_found_final_parent_decl
) :
1236 work
->lookup_by_name_r (e
, full_def_only
);
1239 // If all else fails, look though each outer scope.
1240 for (UTL_Scope
*outer
= ScopeAsDecl (work
)->defined_in ();
1242 outer
= ScopeAsDecl (outer
)->defined_in ())
1244 AST_Decl
*next_found_final_parent_decl
= nullptr;
1245 d
= outer
->lookup_by_name_r (e
, full_def_only
, next_found_final_parent_decl
);
1249 if (first_found_final_parent_decl
)
1251 // Hidden scopes can't be used indirectly, therefore we didn't actually
1252 // find this one because the "first_found_final_parent_decl" was found and
1253 // this one just found is hidden by it.
1254 idl_global
->err ()->scope_masking_error (d
, first_found_final_parent_decl
);
1255 d
= nullptr; // Ignore this one; continue searching to report other ambiguous matches.
1259 break; // Ok found it, stop searching.
1262 else if (searching_module_path
&& !first_found_final_parent_decl
)
1264 first_found_final_parent_decl
= next_found_final_parent_decl
;
1271 /// Doesn't add if d == 0.
1272 work
->add_to_referenced (d
, false, name
);
1279 UTL_Scope::lookup_by_name_r (UTL_ScopedName
*e
,
1282 AST_Decl
*ignored
= nullptr;
1283 return UTL_Scope::lookup_by_name_r (e
, full_def_only
, ignored
);
1287 UTL_Scope::lookup_by_name_r (UTL_ScopedName
*e
,
1289 AST_Decl
*&final_parent_decl
)
1291 bool work_another_level
;
1292 UTL_Scope
*work
= this;
1293 final_parent_decl
= (e
->length () == 1) ? ScopeAsDecl (work
) : nullptr;
1297 // Will catch Object, TypeCode, TCKind, ValueBase and
1298 // AbstractBase. A non-zero result of this lookup determines the
1299 // generation of some #includes and, whether successful or not,
1300 // incurs no extra overhead.
1301 AST_Decl
*d
= work
->lookup_pseudo (e
->head ());
1307 if (work
->idl_keyword_clash (e
->head ()))
1312 // Before proceeding to normal lookup, check if the name
1313 // matches a template module parameter. If so, the return
1314 // value is created on the heap and is owned by the caller
1316 if (final_parent_decl
)
1318 // Since we are inside the scope of a template module, any
1319 // single-segment scoped name that matches a template
1320 // parameter name has to be a reference to that parameter,
1321 // so we return the created placeholder. If there's no
1322 // match, 0 is returned, and we proceed with the regular
1324 AST_Param_Holder
*param_holder
=
1325 UTL_Scope::match_param (e
);
1329 return param_holder
;
1333 work_another_level
= false; // Until we find something.
1335 (ACE_OS::strcmp (e
->head ()->get_string (), "CORBA") == 0);
1337 for (UTL_ScopeActiveIterator
i (work
, IK_decls
);
1341 d
= i
.item ()->adjust_found (true, full_def_only
);
1343 // Right now we populate the global scope with all the CORBA basic
1344 // types, so something like 'ULong' in an IDL file will find a
1345 // match, unless we skip over these items. This is a workaround until
1346 // there's time to fix the code generation for CORBA basic types.
1348 ACE_OS::strcmp (d
->name ()->head ()->get_string (), "CORBA"))
1349 && d
->local_name ()->case_compare (e
->head ()))
1351 // Ok we found a match, is there any more to find?
1352 if (final_parent_decl
)
1354 return d
; // Last scope name matched
1357 UTL_Scope
*next
= DeclAsScope (d
); // The next scope to search
1362 work_another_level
= true;
1363 e
= static_cast<UTL_ScopedName
*> (e
->tail ());
1364 final_parent_decl
= (e
->length () == 1) ? d
: nullptr;
1368 // Template weirdness, actual one we want should be
1369 // found next in this search, keep going.
1372 } while (work_another_level
);
1374 // A rare enough case that it's worth it to separate it and
1375 // do it as a last resort. Catches anonymnous types, enums
1376 // and members with their types defined all in one statement.
1377 if (final_parent_decl
)
1379 for (UTL_ScopeActiveIterator
i (work
, IK_localtypes
);
1383 AST_Decl
*d
= i
.item ();
1385 if (d
->local_name ()->case_compare (e
->head ()))
1392 // Last resort, check other module openings of working scope.
1393 return work
->special_lookup (e
, full_def_only
, final_parent_decl
);
1396 // Add a node to set of nodes referenced in this scope.
1398 UTL_Scope::add_to_referenced (AST_Decl
*e
,
1403 // Empty name? Exit immediately.
1409 // Special case for forward declared interfaces in the
1410 // scope in which they're defined. Cannot add before full
1411 // definition is seen.
1412 AST_Decl::NodeType nt
= e
->node_type ();
1413 if ( nt
== AST_Decl::NT_interface
1414 || nt
== AST_Decl::NT_component
)
1416 AST_Interface
*itf
= dynamic_cast<AST_Interface
*> (e
);
1418 && itf
->defined_in () == this
1419 && !itf
->is_defined ())
1425 // Only insert if it is not there already.
1426 if (this->referenced (e
, id
))
1431 // Sets the appropriate *_seen_ flag for future use.
1432 this->check_for_predef_seq (e
);
1434 // Make sure there's space for one more decl.
1435 if (this->pd_referenced_allocated
== this->pd_referenced_used
)
1437 long oreferenced_allocated
= this->pd_referenced_allocated
;
1438 this->pd_referenced_allocated
+= INCREMENT
;
1440 AST_Decl
**tmp
= nullptr;
1441 ACE_NEW (tmp
, AST_Decl
*[this->pd_referenced_allocated
]);
1443 for (long i
= 0; i
< oreferenced_allocated
; ++i
)
1445 tmp
[i
] = this->pd_referenced
[i
];
1448 delete [] this->pd_referenced
;
1449 this->pd_referenced
= tmp
;
1452 // Insert new reference.
1455 this->pd_referenced
[this->pd_referenced_used
++] = e
;
1457 else if (this->referenced (ex
))
1460 for (i
= this->pd_referenced_used
;
1461 0 < i
&& this->pd_referenced
[i
- 1] != ex
;
1464 this->pd_referenced
[i
] = this->pd_referenced
[i
- 1];
1466 this->pd_referenced
[i
] = e
;
1467 ++this->pd_referenced_used
;
1470 // Now, if recursive is specified and "this" is not a common ancestor
1471 // of the referencing scope and the scope of definition of "e" then
1472 // add "e" to the set of referenced nodes in the parent of "this".
1473 if (recursive
&& !(e
->has_ancestor (ScopeAsDecl (this))))
1475 UTL_Scope
*s
= e
->defined_in ();
1478 s
->add_to_referenced (e
, recursive
, id
);
1482 // Add the identifier arg, if non-null, to the identifier list.
1485 this->add_to_name_referenced (id
);
1490 UTL_Scope::add_to_name_referenced (Identifier
*id
)
1492 // Make sure we have enough space.
1493 if (this->pd_name_referenced_allocated
== this->pd_name_referenced_used
)
1495 long name_referenced_allocated
= this->pd_name_referenced_allocated
;
1496 this->pd_name_referenced_allocated
+= INCREMENT
;
1498 Identifier
**name_tmp
= nullptr;
1499 ACE_NEW (name_tmp
, Identifier
*[this->pd_name_referenced_allocated
]);
1501 for (long i
= 0; i
< name_referenced_allocated
; ++i
)
1503 name_tmp
[i
] = this->pd_name_referenced
[i
];
1506 delete [] this->pd_name_referenced
;
1507 this->pd_name_referenced
= name_tmp
;
1510 // Insert new identifier.
1511 this->pd_name_referenced
[this->pd_name_referenced_used
++] = id
->copy ();
1515 UTL_Scope::replace_referenced (AST_Decl
*old_decl
,
1518 for (int i
= 0; i
< this->pd_referenced_used
; ++i
)
1520 if (this->pd_referenced
[i
] == old_decl
)
1522 this->pd_referenced
[i
] = new_decl
;
1529 UTL_Scope::replace_scope (AST_Decl
*old_decl
,
1532 for (int i
= 0; i
< pd_decls_used
; ++i
)
1534 if (this->pd_decls
[i
] == old_decl
)
1536 this->pd_decls
[i
] = new_decl
;
1542 // Add a node to set of nodes declared in this scope.
1544 UTL_Scope::add_to_scope (AST_Decl
*e
,
1552 Identifier
*decl_name
= e
->local_name ();
1553 char *decl_string
= decl_name
->get_string ();
1554 AST_Decl::NodeType new_nt
= e
->node_type ();
1556 // First, make sure there's no clash between e, that was
1557 // just declared, and some other identifier referenced
1559 AST_Decl
**tmp
= this->pd_decls
;
1560 for (long i
= this->pd_decls_used
;
1561 i
--; // NOTE i-- test
1564 // A local declaration doesn't use a scoped name.
1565 Identifier
*ref_name
= (*tmp
)->local_name ();
1566 char *ref_string
= ref_name
->get_string ();
1568 // If the names compare exactly, it's a redefini8tion
1569 // error, unless they're both modules (which can be
1570 // reopened) or we have a belated definition of a
1571 // forward-declared interface.
1572 AST_Decl::NodeType scope_elem_nt
= (*tmp
)->node_type ();
1574 if (this->redef_clash (new_nt
, scope_elem_nt
)
1575 && decl_name
->compare (ref_name
))
1577 idl_global
->err ()->redef_error (decl_string
,
1580 // if we try to continue from here, we risk a crash.
1583 // If the spellings differ only by case, it's also an error,
1584 // unless one, but not both of the identifiers were escaped.
1585 else if (!(decl_name
->escaped () ^ ref_name
->escaped ())
1586 && decl_name
->case_compare_quiet (ref_name
))
1588 if (idl_global
->case_diff_error ())
1590 idl_global
->err ()->name_case_error (decl_string
,
1593 // if we try to continue from here, we risk a crash.
1598 idl_global
->err ()->name_case_warning (decl_string
,
1604 // The name of any scope except the unnamed scope formed by an operation
1605 // may not be redefined immediately within (and the root scope has no name).
1606 // As well as OBV factory construct.
1607 AST_Decl
*d
= ScopeAsDecl (this);
1608 AST_Decl::NodeType nt
= d
->node_type ();
1609 if ( nt
!= AST_Decl::NT_root
1610 && nt
!= AST_Decl::NT_op
1611 && nt
!= AST_Decl::NT_factory
)
1613 Identifier
*parent_name
= d
->local_name ();
1614 if (decl_name
->compare (parent_name
))
1616 idl_global
->err ()->redef_error (
1617 decl_name
->get_string (),
1618 parent_name
->get_string ()
1621 // if we try to continue from here, we risk a crash.
1624 else if (decl_name
->case_compare_quiet (parent_name
))
1626 if (idl_global
->case_diff_error ())
1628 idl_global
->err ()->name_case_error (
1629 decl_name
->get_string (),
1630 parent_name
->get_string ()
1633 // if we try to continue from here, we risk a crash.
1638 idl_global
->err ()->name_case_warning (
1639 decl_name
->get_string (),
1640 parent_name
->get_string ()
1646 // Now make sure there's space for one more.
1647 if (this->pd_decls_allocated
== this->pd_decls_used
)
1649 long odecls_allocated
= this->pd_decls_allocated
;
1650 this->pd_decls_allocated
+= INCREMENT
;
1652 ACE_NEW (tmp
, AST_Decl
*[pd_decls_allocated
]);
1653 for (long i
= 0; i
< odecls_allocated
; ++i
)
1655 tmp
[i
] = this->pd_decls
[i
];
1658 delete [] this->pd_decls
;
1659 this->pd_decls
= tmp
;
1665 this->pd_decls
[this->pd_decls_used
++] = e
;
1670 for (i
= this->pd_decls_used
;
1671 0 < i
&& this->pd_decls
[i
- 1] != ex
;
1674 this->pd_decls
[i
] = this->pd_decls
[i
- 1];
1676 this->pd_decls
[i
] = e
;
1677 ++this->pd_decls_used
;
1681 // Add a node to set of nodes representing manifest
1682 // types defined in this scope.
1684 UTL_Scope::add_to_local_types (AST_Decl
*e
)
1691 // Make sure there's space for one more.
1692 if (this->pd_locals_allocated
== this->pd_locals_used
)
1694 long olocals_allocated
= this->pd_locals_allocated
;
1695 this->pd_locals_allocated
+= INCREMENT
;
1697 AST_Decl
**tmp
= nullptr;
1698 ACE_NEW (tmp
, AST_Decl
*[this->pd_locals_allocated
]);
1699 for (long i
= 0; i
< olocals_allocated
; ++i
)
1701 tmp
[i
] = this->pd_local_types
[i
];
1704 delete [] this->pd_local_types
;
1705 this->pd_local_types
= tmp
;
1709 this->pd_local_types
[this->pd_locals_used
++] = e
;
1712 // Has this node been referenced here before?
1714 UTL_Scope::referenced (AST_Decl
*e
,
1717 Identifier
*test
= e
->local_name ();
1718 AST_Decl::NodeType nt
= e
->node_type ();
1720 AST_Decl
**tmp
= this->pd_referenced
;
1721 for (long i
= this->pd_referenced_used
;
1722 i
--; // NOTE test with i--
1731 // Are we definging a forward declared struct, union, or interface,
1732 // or reopening a module?
1733 if (!this->redef_clash (nt
, (*tmp
)->node_type ())
1734 && (*tmp
)->local_name ()->compare (test
))
1740 // pd_referenced is a list of decls, and so there's no
1741 // way of telling how much of its scoped name was used
1742 // when it was referenced in this scope. pd_name_referenced
1743 // is a list of Identifiers that store the identifier (or
1744 // the first segment of a scoped name) used in the reference,
1745 // so we can catch these name reolution clashes.
1748 Identifier
**name_tmp
= this->pd_name_referenced
;
1749 for (long j
= this->pd_name_referenced_used
;
1750 j
--; // NOTE test with j--
1753 // If we are a module, there is no clash, if we
1754 // are an interface, this is not the right place to
1755 // catch a clash, and if it wasn't defined in this
1756 // scope, then it's a type name for something else
1757 // that was, and it can appear any number of times
1758 // in this scope without a clash.
1759 AST_Decl::NodeType nt
= e
->node_type ();
1760 if ( nt
!= AST_Decl::NT_module
1761 && nt
!= AST_Decl::NT_param_holder
1762 && e
->defined_in () == this
1763 && id
->compare (*name_tmp
))
1765 idl_global
->err ()->redef_error (id
->get_string (),
1766 (*name_tmp
)->get_string ());
1769 // No clash if one or the other of the identifiers was escaped.
1770 else if (!(id
->escaped () ^ (*name_tmp
)->escaped ())
1771 && id
->case_compare_quiet (*name_tmp
))
1773 if (idl_global
->case_diff_error ())
1775 idl_global
->err ()->name_case_error (
1777 (*name_tmp
)->get_string ()
1782 idl_global
->err ()->name_case_warning (
1784 (*name_tmp
)->get_string ()
1798 UTL_Scope::has_prefix ()
1800 return this->has_prefix_
;
1804 UTL_Scope::has_prefix (bool val
)
1806 this->has_prefix_
= val
;
1809 // Redefinition of inherited virtual operations.
1813 UTL_Scope::dump (ACE_OSTREAM_TYPE
&o
)
1815 if (!idl_global
->indent ())
1817 UTL_Indenter
*idnt
= nullptr;
1818 ACE_NEW (idnt
, UTL_Indenter
);
1819 idl_global
->set_indent (idnt
);
1821 idl_global
->indent ()->increase ();
1823 if (0 < this->pd_locals_used
)
1826 idl_global
->indent ()->skip_to (o
);
1827 o
<< ACE_TEXT ("/* Locally defined types: */\n");
1829 for (UTL_ScopeActiveIterator
i (this, IK_localtypes
);
1833 AST_Decl
*d
= i
.item ();
1835 if (d
->should_be_dumped () && !d
->imported ())
1837 idl_global
->indent ()->skip_to (o
);
1838 o
<< *d
<< ACE_TEXT (";\n");
1843 if (0 < this->pd_decls_used
)
1846 idl_global
->indent ()->skip_to (o
);
1847 o
<< ACE_TEXT ("/* Declarations: */\n");
1849 for (UTL_ScopeActiveIterator
j (this, IK_decls
);
1853 AST_Decl
*d
= j
.item ();
1855 if (d
->should_be_dumped () && !d
->imported ())
1857 idl_global
->indent ()->skip_to (o
);
1858 o
<< *d
<< ACE_TEXT (";\n");
1863 idl_global
->indent ()->decrease ();
1867 UTL_Scope::ast_accept (ast_visitor
*visitor
)
1869 return visitor
->visit_scope (this);
1872 // How many entries are defined?
1874 UTL_Scope::nmembers ()
1876 return this->pd_decls_used
;
1880 UTL_Scope::match_param (UTL_ScopedName
*e
)
1882 // If this call returns a zero value, we are not in the scope
1883 // of a template module.
1884 FE_Utils::T_PARAMLIST_INFO
const *params
=
1885 idl_global
->current_params ();
1887 if (params
== nullptr)
1892 const char *name
= e
->first_component ()->get_string ();
1893 FE_Utils::T_Param_Info
*param
= nullptr;
1894 unsigned long index
= 0;
1896 UTL_StrList
*alias_params
=
1897 const_cast<UTL_StrList
*> (idl_global
->for_new_holder ());
1899 if (alias_params
== nullptr)
1902 const_cast<UTL_StrList
*> (idl_global
->alias_params ());
1905 UTL_String
*alias_param
= nullptr;
1907 for (FE_Utils::T_PARAMLIST_INFO::CONST_ITERATOR
i (*params
);
1909 i
.advance (), ++index
)
1911 if (param
->name_
== name
)
1913 /// If we are parsing this template module as a
1914 /// reference, the param holder we create must have
1915 /// the name of the corresponding aliased param.
1916 if (alias_params
!= nullptr)
1918 unsigned long slot
= 0;
1920 for (UTL_StrlistActiveIterator
iter (alias_params
);
1922 iter
.next (), ++slot
)
1926 alias_param
= iter
.item ();
1931 if (alias_param
== nullptr)
1933 ACE_ERROR_RETURN ((LM_ERROR
,
1934 ACE_TEXT ("UTL_Scope::match_param - ")
1935 ACE_TEXT ("param not matched\n")),
1939 Identifier
id (alias_param
->get_string ());
1940 UTL_ScopedName
sn (&id
, nullptr);
1943 idl_global
->gen ()->create_param_holder (
1950 idl_global
->gen ()->create_param_holder (
1961 UTL_Scope::inherited_op_attr_clash (AST_Decl
*t
)
1963 AST_Interface
*i
= dynamic_cast<AST_Interface
*> (this);
1969 AST_Decl
*d
= i
->look_in_inherited (t
->name (), false);
1972 AST_Decl::NodeType nt
= d
->node_type ();
1973 if ( nt
== AST_Decl::NT_attr
1974 || nt
== AST_Decl::NT_op
)
1976 idl_global
->err ()->error3 (UTL_Error::EIDL_REDEF
,
1988 UTL_Scope::arg_specific_error (AST_Decl
*t
)
1990 AST_Operation
*op
= dynamic_cast<AST_Operation
*> (this);
1996 AST_Argument
*arg
= dynamic_cast<AST_Argument
*> (t
);
1997 AST_Argument::Direction d
= arg
->direction ();
1999 // Cannot add OUT or INOUT argument to oneway operation.
2000 if (( d
== AST_Argument::dir_OUT
2001 || d
== AST_Argument::dir_INOUT
)
2002 && op
->flags () == AST_Operation::OP_oneway
)
2004 idl_global
->err ()->error2 (UTL_Error::EIDL_ONEWAY_CONFLICT
,
2010 // This error is not caught in y.tab.cpp so we check for it here.
2011 AST_Type
*arg_type
= arg
->field_type ();
2012 if ( arg_type
->node_type () == AST_Decl::NT_array
2013 && arg_type
->anonymous ())
2015 idl_global
->err ()->syntax_error (idl_global
->parse_state ());
2023 UTL_Scope::smart_local_add (AST_Decl
*t
)
2025 // Catches struct, union * exception
2026 AST_Structure
*s
= dynamic_cast<AST_Structure
*> (this);
2028 // Catches AST_Field and AST_UnionBranch.
2029 AST_Field
*f
= dynamic_cast<AST_Field
*> (t
);
2031 // Decls inside a struct/union/exception are also referenced by
2032 // fields, and so must be handled differently.
2035 this->add_to_local_types (t
);
2039 this->add_to_scope (t
);
2042 // If we have an enum discriminator, add the label names to
2043 // the name_referenced list before we add the union branch,
2044 // so a branch name clash with a label name will be caught.
2045 AST_Union
*u
= dynamic_cast<AST_Union
*> (this);
2046 AST_UnionBranch
*ub
= dynamic_cast<AST_UnionBranch
*> (t
);
2049 if (u
->udisc_type () == AST_Expression::EV_enum
)
2055 ub
->coerce_labels (u
);
2060 // Determines if a name is global.
2062 UTL_Scope::is_global_name (Identifier
*i
)
2069 ACE_CString
cmp (i
->get_string (), nullptr, false);
2070 return (cmp
== "" || cmp
== "::");
2074 UTL_Scope::iter_lookup_by_name_local (AST_Decl
*d
,
2078 // Remove all the layers of typedefs.
2079 while (d
&& d
->node_type () == AST_Decl::NT_typedef
)
2081 AST_Typedef
*td
= dynamic_cast<AST_Typedef
*> (d
);
2087 d
= td
->base_type ();
2095 // Try to convert the AST_Decl to a UTL_Scope.
2096 UTL_Scope
*sc
= DeclAsScope (d
);
2102 AST_Decl
*result
= nullptr;
2103 if (0 < sc
->nmembers ())
2105 // Look up the first component of the scoped name.
2106 result
= sc
->lookup_by_name_local (e
->head (),
2111 AST_Interface
*i
= dynamic_cast<AST_Interface
*> (d
);
2112 result
= i
? i
->look_in_inherited_local (e
->head ())
2113 : sc
->look_in_prev_mods_local (e
->head (), true);
2116 UTL_ScopedName
*sn
= (UTL_ScopedName
*) e
->tail ();
2121 result
= UTL_Scope::match_param (e
);
2126 // Look up the next component of the scoped name.
2127 result
= iter_lookup_by_name_local (result
,
2135 // UTL_SCOPE_ACTIVE_ITERATOR
2138 UTL_ScopeActiveIterator::UTL_ScopeActiveIterator (
2140 UTL_Scope::ScopeIterationKind i
2144 stage (i
== UTL_Scope::IK_both
? UTL_Scope::IK_localtypes
: i
),
2149 // Public operations.
2151 // Advance to next item.
2153 UTL_ScopeActiveIterator::next ()
2158 // Get current item.
2160 UTL_ScopeActiveIterator::item ()
2162 if (this->is_done ())
2167 if (stage
== UTL_Scope::IK_decls
)
2169 return this->iter_source
->pd_decls
[il
];
2172 if (stage
== UTL_Scope::IK_localtypes
)
2174 return this->iter_source
->pd_local_types
[il
];
2180 // Is this iteration done?
2182 UTL_ScopeActiveIterator::is_done ()
2185 (stage
== UTL_Scope::IK_decls
)
2186 ? iter_source
->pd_decls_used
2187 : iter_source
->pd_locals_used
;
2192 if (this->il
< limit
)
2198 if (this->stage
== UTL_Scope::IK_decls
)
2203 // Already done local types?
2204 if (this->ik
== UTL_Scope::IK_localtypes
)
2209 // Switch to next stage.
2210 this->stage
= UTL_Scope::IK_decls
;
2212 limit
= this->iter_source
->pd_decls_used
;
2216 // What kind of iterator is this?
2217 UTL_Scope::ScopeIterationKind
2218 UTL_ScopeActiveIterator::iteration_kind ()
2223 // And where are we in the iteration?
2224 UTL_Scope::ScopeIterationKind
2225 UTL_ScopeActiveIterator::iteration_stage ()
2230 AST_Annotation_Decl
*
2231 UTL_Scope::fe_add_annotation_decl (AST_Annotation_Decl
* /*annotation_decl*/)
2236 AST_Annotation_Member
*
2237 UTL_Scope::fe_add_annotation_member (AST_Annotation_Member
* /*annotation_member*/)
2243 UTL_Scope::lookup_by_name (const char *name
)
2245 AST_Decl
*node
= nullptr;
2246 UTL_ScopedName
*scoped_name
= FE_Utils::string_to_scoped_name (name
);
2247 node
= lookup_by_name (scoped_name
);
2248 scoped_name
->destroy ();