Never change BINFO_INHERITANCE_CHAIN.
[gcc.git] / gcc / cp / decl.c
1 /* Process declarations and variables for C compiler.
2 Copyright (C) 1988, 92-97, 1998 Free Software Foundation, Inc.
3 Contributed by Michael Tiemann (tiemann@cygnus.com)
4
5 This file is part of GNU CC.
6
7 GNU CC is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 2, or (at your option)
10 any later version.
11
12 GNU CC is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
16
17 You should have received a copy of the GNU General Public License
18 along with GNU CC; see the file COPYING. If not, write to
19 the Free Software Foundation, 59 Temple Place - Suite 330,
20 Boston, MA 02111-1307, USA. */
21
22
23 /* Process declarations and symbol lookup for C front end.
24 Also constructs types; the standard scalar types at initialization,
25 and structure, union, array and enum types when they are declared. */
26
27 /* ??? not all decl nodes are given the most useful possible
28 line numbers. For example, the CONST_DECLs for enum values. */
29
30 #include "config.h"
31 #include "system.h"
32 #include "tree.h"
33 #include "rtl.h"
34 #include "flags.h"
35 #include "cp-tree.h"
36 #include "decl.h"
37 #include "lex.h"
38 #include <signal.h>
39 #include "obstack.h"
40 #include "defaults.h"
41 #include "output.h"
42 #include "except.h"
43 #include "toplev.h"
44
45 #define obstack_chunk_alloc xmalloc
46 #define obstack_chunk_free free
47
48 extern tree builtin_return_address_fndecl;
49
50 extern struct obstack permanent_obstack;
51 extern struct obstack* saveable_obstack;
52
53 extern int current_class_depth;
54
55 extern tree static_ctors, static_dtors;
56
57 extern int static_labelno;
58
59 extern tree current_namespace;
60 extern tree global_namespace;
61
62 extern void (*print_error_function) PROTO((char *));
63
64 /* Stack of places to restore the search obstack back to. */
65
66 /* Obstack used for remembering local class declarations (like
67 enums and static (const) members. */
68 #include "stack.h"
69 struct obstack decl_obstack;
70 static struct stack_level *decl_stack;
71
72 #ifndef CHAR_TYPE_SIZE
73 #define CHAR_TYPE_SIZE BITS_PER_UNIT
74 #endif
75
76 #ifndef SHORT_TYPE_SIZE
77 #define SHORT_TYPE_SIZE (BITS_PER_UNIT * MIN ((UNITS_PER_WORD + 1) / 2, 2))
78 #endif
79
80 #ifndef INT_TYPE_SIZE
81 #define INT_TYPE_SIZE BITS_PER_WORD
82 #endif
83
84 #ifndef LONG_TYPE_SIZE
85 #define LONG_TYPE_SIZE BITS_PER_WORD
86 #endif
87
88 #ifndef LONG_LONG_TYPE_SIZE
89 #define LONG_LONG_TYPE_SIZE (BITS_PER_WORD * 2)
90 #endif
91
92 #ifndef WCHAR_UNSIGNED
93 #define WCHAR_UNSIGNED 0
94 #endif
95
96 #ifndef FLOAT_TYPE_SIZE
97 #define FLOAT_TYPE_SIZE BITS_PER_WORD
98 #endif
99
100 #ifndef DOUBLE_TYPE_SIZE
101 #define DOUBLE_TYPE_SIZE (BITS_PER_WORD * 2)
102 #endif
103
104 #ifndef LONG_DOUBLE_TYPE_SIZE
105 #define LONG_DOUBLE_TYPE_SIZE (BITS_PER_WORD * 2)
106 #endif
107
108 #ifndef BOOL_TYPE_SIZE
109 #ifdef SLOW_BYTE_ACCESS
110 #define BOOL_TYPE_SIZE ((SLOW_BYTE_ACCESS) ? (POINTER_SIZE) : (CHAR_TYPE_SIZE))
111 #else
112 #define BOOL_TYPE_SIZE CHAR_TYPE_SIZE
113 #endif
114 #endif
115
116 /* We let tm.h override the types used here, to handle trivial differences
117 such as the choice of unsigned int or long unsigned int for size_t.
118 When machines start needing nontrivial differences in the size type,
119 it would be best to do something here to figure out automatically
120 from other information what type to use. */
121
122 #ifndef SIZE_TYPE
123 #define SIZE_TYPE "long unsigned int"
124 #endif
125
126 #ifndef PTRDIFF_TYPE
127 #define PTRDIFF_TYPE "long int"
128 #endif
129
130 #ifndef WCHAR_TYPE
131 #define WCHAR_TYPE "int"
132 #endif
133
134 static tree grokparms PROTO((tree, int));
135 static tree lookup_nested_type PROTO((tree, tree));
136 static char *redeclaration_error_message PROTO((tree, tree));
137 static tree push_overloaded_decl PROTO((tree, int));
138
139 static struct stack_level *push_decl_level PROTO((struct stack_level *,
140 struct obstack *));
141 static void push_binding_level PROTO((struct binding_level *, int,
142 int));
143 static void pop_binding_level PROTO((void));
144 static void suspend_binding_level PROTO((void));
145 static void resume_binding_level PROTO((struct binding_level *));
146 static struct binding_level *make_binding_level PROTO((void));
147 static int namespace_bindings_p PROTO((void));
148 static void declare_namespace_level PROTO((void));
149 static void signal_catch PROTO((int));
150 static void storedecls PROTO((tree));
151 static void storetags PROTO((tree));
152 static void require_complete_types_for_parms PROTO((tree));
153 static void push_overloaded_decl_1 PROTO((tree));
154 static int ambi_op_p PROTO((tree));
155 static int unary_op_p PROTO((tree));
156 static tree store_bindings PROTO((tree, tree));
157 static tree lookup_tag_reverse PROTO((tree, tree));
158 static tree obscure_complex_init PROTO((tree, tree));
159 static tree maybe_build_cleanup_1 PROTO((tree, tree));
160 static tree lookup_name_real PROTO((tree, int, int, int));
161 static void warn_extern_redeclared_static PROTO((tree, tree));
162 static void grok_reference_init PROTO((tree, tree, tree));
163 static tree grokfndecl PROTO((tree, tree, tree, tree, int,
164 enum overload_flags, tree,
165 tree, tree, int, int, int, int, int, int, tree));
166 static tree grokvardecl PROTO((tree, tree, RID_BIT_TYPE *, int, int, tree));
167 static tree lookup_tag PROTO((enum tree_code, tree,
168 struct binding_level *, int));
169 static void set_identifier_type_value_with_scope
170 PROTO((tree, tree, struct binding_level *));
171 static void set_identifier_local_value_with_scope
172 PROTO((tree, tree, struct binding_level *));
173 static void record_builtin_type PROTO((enum rid, char *, tree));
174 static void record_unknown_type PROTO((tree, char *));
175 static int member_function_or_else PROTO((tree, tree, char *));
176 static void bad_specifiers PROTO((tree, char *, int, int, int, int,
177 int));
178 static void lang_print_error_function PROTO((char *));
179 static tree maybe_process_template_type_declaration PROTO((tree, int, struct binding_level*));
180
181 #if defined (DEBUG_CP_BINDING_LEVELS)
182 static void indent PROTO((void));
183 #endif
184
185 /* A node which has tree code ERROR_MARK, and whose type is itself.
186 All erroneous expressions are replaced with this node. All functions
187 that accept nodes as arguments should avoid generating error messages
188 if this node is one of the arguments, since it is undesirable to get
189 multiple error messages from one error in the input. */
190
191 tree error_mark_node;
192
193 /* Erroneous argument lists can use this *IFF* they do not modify it. */
194 tree error_mark_list;
195
196 /* INTEGER_TYPE and REAL_TYPE nodes for the standard data types */
197
198 tree short_integer_type_node;
199 tree integer_type_node;
200 tree long_integer_type_node;
201 tree long_long_integer_type_node;
202
203 tree short_unsigned_type_node;
204 tree unsigned_type_node;
205 tree long_unsigned_type_node;
206 tree long_long_unsigned_type_node;
207
208 tree ptrdiff_type_node;
209
210 tree unsigned_char_type_node;
211 tree signed_char_type_node;
212 tree char_type_node;
213 tree wchar_type_node;
214 tree signed_wchar_type_node;
215 tree unsigned_wchar_type_node;
216
217 tree wchar_decl_node;
218
219 tree float_type_node;
220 tree double_type_node;
221 tree long_double_type_node;
222
223 tree complex_integer_type_node;
224 tree complex_float_type_node;
225 tree complex_double_type_node;
226 tree complex_long_double_type_node;
227
228 tree intQI_type_node;
229 tree intHI_type_node;
230 tree intSI_type_node;
231 tree intDI_type_node;
232 tree intTI_type_node;
233
234 tree unsigned_intQI_type_node;
235 tree unsigned_intHI_type_node;
236 tree unsigned_intSI_type_node;
237 tree unsigned_intDI_type_node;
238 tree unsigned_intTI_type_node;
239
240 tree java_byte_type_node;
241 tree java_short_type_node;
242 tree java_int_type_node;
243 tree java_long_type_node;
244 tree java_float_type_node;
245 tree java_double_type_node;
246 tree java_char_type_node;
247 tree java_boolean_type_node;
248
249 /* A VOID_TYPE node, and the same, packaged in a TREE_LIST. */
250
251 tree void_type_node, void_list_node;
252 tree void_zero_node;
253
254 /* Nodes for types `void *' and `const void *'. */
255
256 tree ptr_type_node;
257 tree const_ptr_type_node;
258
259 /* Nodes for types `char *' and `const char *'. */
260
261 tree string_type_node, const_string_type_node;
262
263 /* Type `char[256]' or something like it.
264 Used when an array of char is needed and the size is irrelevant. */
265
266 tree char_array_type_node;
267
268 /* Type `int[256]' or something like it.
269 Used when an array of int needed and the size is irrelevant. */
270
271 tree int_array_type_node;
272
273 /* Type `wchar_t[256]' or something like it.
274 Used when a wide string literal is created. */
275
276 tree wchar_array_type_node;
277
278 /* The bool data type, and constants */
279 tree boolean_type_node, boolean_true_node, boolean_false_node;
280
281 /* Type `int ()' -- used for implicit declaration of functions. */
282
283 tree default_function_type;
284
285 /* Function types `double (double)' and `double (double, double)', etc. */
286
287 static tree double_ftype_double, double_ftype_double_double;
288 static tree int_ftype_int, long_ftype_long;
289 static tree float_ftype_float;
290 static tree ldouble_ftype_ldouble;
291
292 /* Function type `int (const void *, const void *, size_t)' */
293 static tree int_ftype_cptr_cptr_sizet;
294
295 /* C++ extensions */
296 tree vtable_entry_type;
297 tree delta_type_node;
298 #if 0
299 /* Old rtti stuff. */
300 tree __baselist_desc_type_node;
301 tree __i_desc_type_node, __m_desc_type_node;
302 tree __t_desc_array_type, __i_desc_array_type, __m_desc_array_type;
303 #endif
304 tree __t_desc_type_node;
305 #if 0
306 tree __tp_desc_type_node;
307 #endif
308 tree __access_mode_type_node;
309 tree __bltn_desc_type_node, __user_desc_type_node, __class_desc_type_node;
310 tree __ptr_desc_type_node, __attr_desc_type_node, __func_desc_type_node;
311 tree __ptmf_desc_type_node, __ptmd_desc_type_node;
312 #if 0
313 /* Not needed yet? May be needed one day? */
314 tree __bltn_desc_array_type, __user_desc_array_type, __class_desc_array_type;
315 tree __ptr_desc_array_type, __attr_dec_array_type, __func_desc_array_type;
316 tree __ptmf_desc_array_type, __ptmd_desc_array_type;
317 #endif
318
319 /* Indicates that there is a type value in some namespace, although
320 that is not necessarily in scope at the moment. */
321
322 static tree global_type_node;
323
324 tree class_star_type_node;
325 tree class_type_node, record_type_node, union_type_node, enum_type_node;
326 tree unknown_type_node;
327 tree opaque_type_node, signature_type_node;
328 tree sigtable_entry_type;
329
330 /* Array type `vtable_entry_type[]' */
331 tree vtbl_type_node;
332
333 /* namespace std */
334 tree std_node;
335 int in_std = 0;
336
337 /* Expect only namespace names now. */
338 static int only_namespace_names;
339
340 /* In a destructor, the point at which all derived class destroying
341 has been done, just before any base class destroying will be done. */
342
343 tree dtor_label;
344
345 /* In a destructor, the last insn emitted after the start of the
346 function and the parms. */
347
348 static rtx last_dtor_insn;
349
350 /* In a constructor, the last insn emitted after the start of the
351 function and the parms, the exception specification and any
352 function-try-block. The constructor initializers are emitted after
353 this insn. */
354
355 static rtx last_parm_cleanup_insn;
356
357 /* In a constructor, the point at which we are ready to return
358 the pointer to the initialized object. */
359
360 tree ctor_label;
361
362 /* A FUNCTION_DECL which can call `abort'. Not necessarily the
363 one that the user will declare, but sufficient to be called
364 by routines that want to abort the program. */
365
366 tree abort_fndecl;
367
368 extern rtx cleanup_label, return_label;
369
370 /* If original DECL_RESULT of current function was a register,
371 but due to being an addressable named return value, would up
372 on the stack, this variable holds the named return value's
373 original location. */
374 static rtx original_result_rtx;
375
376 /* Sequence of insns which represents base initialization. */
377 tree base_init_expr;
378
379 /* C++: Keep these around to reduce calls to `get_identifier'.
380 Identifiers for `this' in member functions and the auto-delete
381 parameter for destructors. */
382 tree this_identifier, in_charge_identifier;
383 tree ctor_identifier, dtor_identifier;
384 /* Used in pointer to member functions, in vtables, and in sigtables. */
385 tree pfn_identifier, index_identifier, delta_identifier, delta2_identifier;
386 tree pfn_or_delta2_identifier, tag_identifier;
387 tree vt_off_identifier;
388
389 struct named_label_list
390 {
391 struct binding_level *binding_level;
392 tree names_in_scope;
393 tree label_decl;
394 char *filename_o_goto;
395 int lineno_o_goto;
396 struct named_label_list *next;
397 };
398
399 /* A list (chain of TREE_LIST nodes) of named label uses.
400 The TREE_PURPOSE field is the list of variables defined
401 in the label's scope defined at the point of use.
402 The TREE_VALUE field is the LABEL_DECL used.
403 The TREE_TYPE field holds `current_binding_level' at the
404 point of the label's use.
405
406 BWAHAHAAHAHahhahahahaah. No, no, no, said the little chicken.
407
408 Look at the pretty struct named_label_list. See the pretty struct
409 with the pretty named fields that describe what they do. See the
410 pretty lack of gratuitous casts. Notice the code got a lot cleaner.
411
412 Used only for jumps to as-yet undefined labels, since
413 jumps to defined labels can have their validity checked
414 by stmt.c. */
415
416 static struct named_label_list *named_label_uses = NULL;
417
418 /* A list of objects which have constructors or destructors
419 which reside in the global scope. The decl is stored in
420 the TREE_VALUE slot and the initializer is stored
421 in the TREE_PURPOSE slot. */
422 tree static_aggregates;
423
424 /* -- end of C++ */
425
426 /* Two expressions that are constants with value zero.
427 The first is of type `int', the second of type `void *'. */
428
429 tree integer_zero_node;
430 tree null_pointer_node;
431
432 /* The value for __null (NULL), namely, a zero of an integer type with
433 the same number of bits as a pointer. */
434 tree null_node;
435
436 /* A node for the integer constants 1, 2, and 3. */
437
438 tree integer_one_node, integer_two_node, integer_three_node;
439
440 /* While defining an enum type, this is 1 plus the last enumerator
441 constant value. */
442
443 static tree enum_next_value;
444
445 /* Nonzero means that there was overflow computing enum_next_value. */
446
447 static int enum_overflow;
448
449 /* Parsing a function declarator leaves a list of parameter names
450 or a chain or parameter decls here. */
451
452 tree last_function_parms;
453
454 /* Parsing a function declarator leaves here a chain of structure
455 and enum types declared in the parmlist. */
456
457 static tree last_function_parm_tags;
458
459 /* After parsing the declarator that starts a function definition,
460 `start_function' puts here the list of parameter names or chain of decls.
461 `store_parm_decls' finds it here. */
462
463 static tree current_function_parms;
464
465 /* Similar, for last_function_parm_tags. */
466 static tree current_function_parm_tags;
467
468 /* A list (chain of TREE_LIST nodes) of all LABEL_DECLs in the function
469 that have names. Here so we can clear out their names' definitions
470 at the end of the function. */
471
472 static tree named_labels;
473
474 /* A list of LABEL_DECLs from outer contexts that are currently shadowed. */
475
476 static tree shadowed_labels;
477
478 /* The FUNCTION_DECL for the function currently being compiled,
479 or 0 if between functions. */
480 tree current_function_decl;
481
482 /* Set to 0 at beginning of a function definition, set to 1 if
483 a return statement that specifies a return value is seen. */
484
485 int current_function_returns_value;
486
487 /* Set to 0 at beginning of a function definition, set to 1 if
488 a return statement with no argument is seen. */
489
490 int current_function_returns_null;
491
492 /* Set to 0 at beginning of a function definition, and whenever
493 a label (case or named) is defined. Set to value of expression
494 returned from function when that value can be transformed into
495 a named return value. */
496
497 tree current_function_return_value;
498
499 /* Set to nonzero by `grokdeclarator' for a function
500 whose return type is defaulted, if warnings for this are desired. */
501
502 static int warn_about_return_type;
503
504 /* Nonzero means give `double' the same size as `float'. */
505
506 extern int flag_short_double;
507
508 /* Nonzero means don't recognize any builtin functions. */
509
510 extern int flag_no_builtin;
511
512 /* Nonzero means don't recognize the non-ANSI builtin functions.
513 -ansi sets this. */
514
515 extern int flag_no_nonansi_builtin;
516
517 /* Nonzero means enable obscure ANSI features and disable GNU extensions
518 that might cause ANSI-compliant code to be miscompiled. */
519
520 extern int flag_ansi;
521
522 /* Nonzero if we want to support huge (> 2^(sizeof(short)*8-1) bytes)
523 objects. */
524 extern int flag_huge_objects;
525
526 /* Nonzero if we want to conserve space in the .o files. We do this
527 by putting uninitialized data and runtime initialized data into
528 .common instead of .data at the expense of not flagging multiple
529 definitions. */
530 extern int flag_conserve_space;
531
532 /* Pointers to the base and current top of the language name stack. */
533
534 extern tree *current_lang_base, *current_lang_stack;
535 \f
536 /* C and C++ flags are in decl2.c. */
537
538 /* Set to 0 at beginning of a constructor, set to 1
539 if that function does an allocation before referencing its
540 instance variable. */
541 static int current_function_assigns_this;
542 int current_function_just_assigned_this;
543
544 /* Set to 0 at beginning of a function. Set non-zero when
545 store_parm_decls is called. Don't call store_parm_decls
546 if this flag is non-zero! */
547 int current_function_parms_stored;
548
549 /* Flag used when debugging spew.c */
550
551 extern int spew_debug;
552
553 /* This is a copy of the class_shadowed list of the previous class binding
554 contour when at global scope. It's used to reset IDENTIFIER_CLASS_VALUEs
555 when entering another class scope (i.e. a cache miss). */
556 extern tree previous_class_values;
557
558 /* A expression of value 0 with the same precision as a sizetype
559 node, but signed. */
560 tree signed_size_zero_node;
561
562 \f
563 /* Allocate a level of searching. */
564
565 static
566 struct stack_level *
567 push_decl_level (stack, obstack)
568 struct stack_level *stack;
569 struct obstack *obstack;
570 {
571 struct stack_level tem;
572 tem.prev = stack;
573
574 return push_stack_level (obstack, (char *)&tem, sizeof (tem));
575 }
576 \f
577 /* For each binding contour we allocate a binding_level structure
578 which records the names defined in that contour.
579 Contours include:
580 0) the global one
581 1) one for each function definition,
582 where internal declarations of the parameters appear.
583 2) one for each compound statement,
584 to record its declarations.
585
586 The current meaning of a name can be found by searching the levels
587 from the current one out to the global one.
588
589 Off to the side, may be the class_binding_level. This exists only
590 to catch class-local declarations. It is otherwise nonexistent.
591
592 Also there may be binding levels that catch cleanups that must be
593 run when exceptions occur. */
594
595 /* Note that the information in the `names' component of the global contour
596 is duplicated in the IDENTIFIER_GLOBAL_VALUEs of all identifiers. */
597
598 struct binding_level
599 {
600 /* A chain of _DECL nodes for all variables, constants, functions,
601 and typedef types. These are in the reverse of the order
602 supplied. */
603 tree names;
604
605 /* A list of structure, union and enum definitions, for looking up
606 tag names.
607 It is a chain of TREE_LIST nodes, each of whose TREE_PURPOSE is a name,
608 or NULL_TREE; and whose TREE_VALUE is a RECORD_TYPE, UNION_TYPE,
609 or ENUMERAL_TYPE node.
610
611 C++: the TREE_VALUE nodes can be simple types for
612 component_bindings. */
613 tree tags;
614
615 /* A list of USING_DECL nodes. */
616 tree usings;
617
618 /* A list of used namespaces. PURPOSE is the namespace,
619 VALUE the common ancestor with this binding_level's namespace. */
620 tree using_directives;
621
622 /* For each level, a list of shadowed outer-level local definitions
623 to be restored when this level is popped.
624 Each link is a TREE_LIST whose TREE_PURPOSE is an identifier and
625 whose TREE_VALUE is its old definition (a kind of ..._DECL node). */
626 tree shadowed;
627
628 /* Same, for IDENTIFIER_CLASS_VALUE. */
629 tree class_shadowed;
630
631 /* Same, for IDENTIFIER_TYPE_VALUE. */
632 tree type_shadowed;
633
634 /* For each level (except not the global one),
635 a chain of BLOCK nodes for all the levels
636 that were entered and exited one level down. */
637 tree blocks;
638
639 /* The BLOCK node for this level, if one has been preallocated.
640 If 0, the BLOCK is allocated (if needed) when the level is popped. */
641 tree this_block;
642
643 /* The binding level which this one is contained in (inherits from). */
644 struct binding_level *level_chain;
645
646 /* List of decls in `names' that have incomplete
647 structure or union types. */
648 tree incomplete;
649
650 /* List of VAR_DECLS saved from a previous for statement.
651 These would be dead in ANSI-conforming code, but might
652 be referenced in ARM-era code. */
653 tree dead_vars_from_for;
654
655 /* 1 for the level that holds the parameters of a function.
656 2 for the level that holds a class declaration.
657 3 for levels that hold parameter declarations. */
658 unsigned parm_flag : 4;
659
660 /* 1 means make a BLOCK for this level regardless of all else.
661 2 for temporary binding contours created by the compiler. */
662 unsigned keep : 3;
663
664 /* Nonzero if this level "doesn't exist" for tags. */
665 unsigned tag_transparent : 1;
666
667 /* Nonzero if this level can safely have additional
668 cleanup-needing variables added to it. */
669 unsigned more_cleanups_ok : 1;
670 unsigned have_cleanups : 1;
671
672 /* Nonzero if this level is for storing the decls for template
673 parameters and generic decls; these decls will be discarded and
674 replaced with a TEMPLATE_DECL. */
675 unsigned pseudo_global : 1;
676
677 /* This is set for a namespace binding level. */
678 unsigned namespace_p : 1;
679
680 /* True if this level is that of a for-statement where we need to
681 worry about ambiguous (ARM or ANSI) scope rules. */
682 unsigned is_for_scope : 1;
683
684 /* Two bits left for this word. */
685
686 #if defined(DEBUG_CP_BINDING_LEVELS)
687 /* Binding depth at which this level began. */
688 unsigned binding_depth;
689 #endif /* defined(DEBUG_CP_BINDING_LEVELS) */
690 };
691
692 #define NULL_BINDING_LEVEL ((struct binding_level *) NULL)
693
694 /* The (non-class) binding level currently in effect. */
695
696 static struct binding_level *current_binding_level;
697
698 /* The binding level of the current class, if any. */
699
700 static struct binding_level *class_binding_level;
701
702 /* The current (class or non-class) binding level currently in effect. */
703
704 #define inner_binding_level \
705 (class_binding_level ? class_binding_level : current_binding_level)
706
707 /* A chain of binding_level structures awaiting reuse. */
708
709 static struct binding_level *free_binding_level;
710
711 /* The outermost binding level, for names of file scope.
712 This is created when the compiler is started and exists
713 through the entire run. */
714
715 static struct binding_level *global_binding_level;
716
717 /* Binding level structures are initialized by copying this one. */
718
719 static struct binding_level clear_binding_level;
720
721 /* Nonzero means unconditionally make a BLOCK for the next level pushed. */
722
723 static int keep_next_level_flag;
724
725 #if defined(DEBUG_CP_BINDING_LEVELS)
726 static int binding_depth = 0;
727 static int is_class_level = 0;
728
729 static void
730 indent ()
731 {
732 register unsigned i;
733
734 for (i = 0; i < binding_depth*2; i++)
735 putc (' ', stderr);
736 }
737 #endif /* defined(DEBUG_CP_BINDING_LEVELS) */
738
739 static tree pushdecl_with_scope PROTO((tree, struct binding_level *));
740
741 static void
742 push_binding_level (newlevel, tag_transparent, keep)
743 struct binding_level *newlevel;
744 int tag_transparent, keep;
745 {
746 /* Add this level to the front of the chain (stack) of levels that
747 are active. */
748 *newlevel = clear_binding_level;
749 if (class_binding_level)
750 {
751 newlevel->level_chain = class_binding_level;
752 class_binding_level = (struct binding_level *)0;
753 }
754 else
755 {
756 newlevel->level_chain = current_binding_level;
757 }
758 current_binding_level = newlevel;
759 newlevel->tag_transparent = tag_transparent;
760 newlevel->more_cleanups_ok = 1;
761 newlevel->keep = keep;
762 #if defined(DEBUG_CP_BINDING_LEVELS)
763 newlevel->binding_depth = binding_depth;
764 indent ();
765 fprintf (stderr, "push %s level 0x%08x line %d\n",
766 (is_class_level) ? "class" : "block", newlevel, lineno);
767 is_class_level = 0;
768 binding_depth++;
769 #endif /* defined(DEBUG_CP_BINDING_LEVELS) */
770 }
771
772 static void
773 pop_binding_level ()
774 {
775 if (class_binding_level)
776 current_binding_level = class_binding_level;
777
778 if (global_binding_level)
779 {
780 /* Cannot pop a level, if there are none left to pop. */
781 if (current_binding_level == global_binding_level)
782 my_friendly_abort (123);
783 }
784 /* Pop the current level, and free the structure for reuse. */
785 #if defined(DEBUG_CP_BINDING_LEVELS)
786 binding_depth--;
787 indent ();
788 fprintf (stderr, "pop %s level 0x%08x line %d\n",
789 (is_class_level) ? "class" : "block",
790 current_binding_level, lineno);
791 if (is_class_level != (current_binding_level == class_binding_level))
792 {
793 indent ();
794 fprintf (stderr, "XXX is_class_level != (current_binding_level == class_binding_level)\n");
795 }
796 is_class_level = 0;
797 #endif /* defined(DEBUG_CP_BINDING_LEVELS) */
798 {
799 register struct binding_level *level = current_binding_level;
800 current_binding_level = current_binding_level->level_chain;
801 level->level_chain = free_binding_level;
802 #if 0 /* defined(DEBUG_CP_BINDING_LEVELS) */
803 if (level->binding_depth != binding_depth)
804 abort ();
805 #endif /* defined(DEBUG_CP_BINDING_LEVELS) */
806 free_binding_level = level;
807
808 class_binding_level = current_binding_level;
809 if (class_binding_level->parm_flag != 2)
810 class_binding_level = 0;
811 while (current_binding_level->parm_flag == 2)
812 current_binding_level = current_binding_level->level_chain;
813 }
814 }
815
816 static void
817 suspend_binding_level ()
818 {
819 if (class_binding_level)
820 current_binding_level = class_binding_level;
821
822 if (global_binding_level)
823 {
824 /* Cannot suspend a level, if there are none left to suspend. */
825 if (current_binding_level == global_binding_level)
826 my_friendly_abort (123);
827 }
828 /* Suspend the current level. */
829 #if defined(DEBUG_CP_BINDING_LEVELS)
830 binding_depth--;
831 indent ();
832 fprintf (stderr, "suspend %s level 0x%08x line %d\n",
833 (is_class_level) ? "class" : "block",
834 current_binding_level, lineno);
835 if (is_class_level != (current_binding_level == class_binding_level))
836 {
837 indent ();
838 fprintf (stderr, "XXX is_class_level != (current_binding_level == class_binding_level)\n");
839 }
840 is_class_level = 0;
841 #endif /* defined(DEBUG_CP_BINDING_LEVELS) */
842 {
843 current_binding_level = current_binding_level->level_chain;
844 class_binding_level = current_binding_level;
845 if (class_binding_level->parm_flag != 2)
846 class_binding_level = 0;
847 while (current_binding_level->parm_flag == 2)
848 current_binding_level = current_binding_level->level_chain;
849 }
850 }
851
852 static void
853 resume_binding_level (b)
854 struct binding_level *b;
855 {
856 /* Resuming binding levels is meant only for namespaces,
857 and those cannot nest into classes. */
858 my_friendly_assert(!class_binding_level, 386);
859 /* Also, resuming a non-directly nested namespace is a no-no. */
860 my_friendly_assert(b->level_chain == current_binding_level, 386);
861 current_binding_level = b;
862 #if defined(DEBUG_CP_BINDING_LEVELS)
863 b->binding_depth = binding_depth;
864 indent ();
865 fprintf (stderr, "resume %s level 0x%08x line %d\n",
866 (is_class_level) ? "class" : "block", b, lineno);
867 is_class_level = 0;
868 binding_depth++;
869 #endif /* defined(DEBUG_CP_BINDING_LEVELS) */
870 }
871 \f
872 /* Create a new `struct binding_level'. */
873
874 static
875 struct binding_level *
876 make_binding_level ()
877 {
878 /* NOSTRICT */
879 return (struct binding_level *) xmalloc (sizeof (struct binding_level));
880 }
881
882 /* Nonzero if we are currently in the global binding level. */
883
884 int
885 global_bindings_p ()
886 {
887 return current_binding_level == global_binding_level;
888 }
889
890 /* Nonzero if we are currently in a toplevel binding level. This
891 means either the global binding level or a namespace in a toplevel
892 binding level.
893 Since there are no non-toplevel namespace levels, this really
894 means any namespace or pseudo-global level. */
895
896 int
897 toplevel_bindings_p ()
898 {
899 return current_binding_level->namespace_p
900 || current_binding_level->pseudo_global;
901 }
902
903 /* Nonzero if this is a namespace scope. */
904
905 static int
906 namespace_bindings_p ()
907 {
908 return current_binding_level->namespace_p;
909 }
910
911 void
912 keep_next_level ()
913 {
914 keep_next_level_flag = 1;
915 }
916
917 /* Nonzero if the current level needs to have a BLOCK made. */
918
919 int
920 kept_level_p ()
921 {
922 return (current_binding_level->blocks != NULL_TREE
923 || current_binding_level->keep
924 || current_binding_level->names != NULL_TREE
925 || (current_binding_level->tags != NULL_TREE
926 && !current_binding_level->tag_transparent));
927 }
928
929 /* Identify this binding level as a level of parameters. */
930
931 void
932 declare_parm_level ()
933 {
934 current_binding_level->parm_flag = 1;
935 }
936
937 void
938 declare_pseudo_global_level ()
939 {
940 current_binding_level->pseudo_global = 1;
941 }
942
943 static void
944 declare_namespace_level ()
945 {
946 current_binding_level->namespace_p = 1;
947 }
948
949 int
950 pseudo_global_level_p ()
951 {
952 return current_binding_level->pseudo_global;
953 }
954
955 void
956 set_class_shadows (shadows)
957 tree shadows;
958 {
959 class_binding_level->class_shadowed = shadows;
960 }
961
962 /* Enter a new binding level.
963 If TAG_TRANSPARENT is nonzero, do so only for the name space of variables,
964 not for that of tags. */
965
966 void
967 pushlevel (tag_transparent)
968 int tag_transparent;
969 {
970 register struct binding_level *newlevel = NULL_BINDING_LEVEL;
971
972 /* If this is the top level of a function,
973 just make sure that NAMED_LABELS is 0.
974 They should have been set to 0 at the end of the previous function. */
975
976 if (current_binding_level == global_binding_level)
977 my_friendly_assert (named_labels == NULL_TREE, 134);
978
979 /* Reuse or create a struct for this binding level. */
980
981 #if defined(DEBUG_CP_BINDING_LEVELS)
982 if (0)
983 #else /* !defined(DEBUG_CP_BINDING_LEVELS) */
984 if (free_binding_level)
985 #endif /* !defined(DEBUG_CP_BINDING_LEVELS) */
986 {
987 newlevel = free_binding_level;
988 free_binding_level = free_binding_level->level_chain;
989 }
990 else
991 {
992 newlevel = make_binding_level ();
993 }
994
995 push_binding_level (newlevel, tag_transparent, keep_next_level_flag);
996 GNU_xref_start_scope ((HOST_WIDE_INT) newlevel);
997 keep_next_level_flag = 0;
998 }
999
1000 void
1001 note_level_for_for ()
1002 {
1003 current_binding_level->is_for_scope = 1;
1004 }
1005
1006 void
1007 pushlevel_temporary (tag_transparent)
1008 int tag_transparent;
1009 {
1010 pushlevel (tag_transparent);
1011 current_binding_level->keep = 2;
1012 clear_last_expr ();
1013
1014 /* Note we don't call push_momentary() here. Otherwise, it would cause
1015 cleanups to be allocated on the momentary obstack, and they will be
1016 overwritten by the next statement. */
1017
1018 expand_start_bindings (0);
1019 }
1020
1021 /* Exit a binding level.
1022 Pop the level off, and restore the state of the identifier-decl mappings
1023 that were in effect when this level was entered.
1024
1025 If KEEP == 1, this level had explicit declarations, so
1026 and create a "block" (a BLOCK node) for the level
1027 to record its declarations and subblocks for symbol table output.
1028
1029 If KEEP == 2, this level's subblocks go to the front,
1030 not the back of the current binding level. This happens,
1031 for instance, when code for constructors and destructors
1032 need to generate code at the end of a function which must
1033 be moved up to the front of the function.
1034
1035 If FUNCTIONBODY is nonzero, this level is the body of a function,
1036 so create a block as if KEEP were set and also clear out all
1037 label names.
1038
1039 If REVERSE is nonzero, reverse the order of decls before putting
1040 them into the BLOCK. */
1041
1042 tree
1043 poplevel (keep, reverse, functionbody)
1044 int keep;
1045 int reverse;
1046 int functionbody;
1047 {
1048 register tree link;
1049 /* The chain of decls was accumulated in reverse order.
1050 Put it into forward order, just for cleanliness. */
1051 tree decls;
1052 int tmp = functionbody;
1053 int real_functionbody = current_binding_level->keep == 2
1054 ? ((functionbody = 0), tmp) : functionbody;
1055 tree tags = functionbody >= 0 ? current_binding_level->tags : 0;
1056 tree subblocks = functionbody >= 0 ? current_binding_level->blocks : 0;
1057 tree block = NULL_TREE;
1058 tree decl;
1059 int block_previously_created;
1060
1061 GNU_xref_end_scope ((HOST_WIDE_INT) current_binding_level,
1062 (HOST_WIDE_INT) current_binding_level->level_chain,
1063 current_binding_level->parm_flag,
1064 current_binding_level->keep);
1065
1066 if (current_binding_level->keep == 1)
1067 keep = 1;
1068
1069 /* Get the decls in the order they were written.
1070 Usually current_binding_level->names is in reverse order.
1071 But parameter decls were previously put in forward order. */
1072
1073 if (reverse)
1074 current_binding_level->names
1075 = decls = nreverse (current_binding_level->names);
1076 else
1077 decls = current_binding_level->names;
1078
1079 /* Output any nested inline functions within this block
1080 if they weren't already output. */
1081
1082 for (decl = decls; decl; decl = TREE_CHAIN (decl))
1083 if (TREE_CODE (decl) == FUNCTION_DECL
1084 && ! TREE_ASM_WRITTEN (decl)
1085 && DECL_INITIAL (decl) != NULL_TREE
1086 && TREE_ADDRESSABLE (decl)
1087 && decl_function_context (decl) == current_function_decl)
1088 {
1089 /* If this decl was copied from a file-scope decl
1090 on account of a block-scope extern decl,
1091 propagate TREE_ADDRESSABLE to the file-scope decl. */
1092 if (DECL_ABSTRACT_ORIGIN (decl) != NULL_TREE)
1093 TREE_ADDRESSABLE (DECL_ABSTRACT_ORIGIN (decl)) = 1;
1094 else
1095 {
1096 push_function_context ();
1097 output_inline_function (decl);
1098 pop_function_context ();
1099 }
1100 }
1101
1102 /* If there were any declarations or structure tags in that level,
1103 or if this level is a function body,
1104 create a BLOCK to record them for the life of this function. */
1105
1106 block = NULL_TREE;
1107 block_previously_created = (current_binding_level->this_block != NULL_TREE);
1108 if (block_previously_created)
1109 block = current_binding_level->this_block;
1110 else if (keep == 1 || functionbody)
1111 block = make_node (BLOCK);
1112 if (block != NULL_TREE)
1113 {
1114 if (block_previously_created)
1115 {
1116 if (decls || tags || subblocks)
1117 {
1118 if (BLOCK_VARS (block) || BLOCK_TYPE_TAGS (block))
1119 {
1120 warning ("internal compiler error: debugging info corrupted");
1121 }
1122 BLOCK_VARS (block) = decls;
1123 BLOCK_TYPE_TAGS (block) = tags;
1124
1125 /* We can have previous subblocks and new subblocks when
1126 doing fixup_gotos with complex cleanups. We chain the new
1127 subblocks onto the end of any pre-existing subblocks. */
1128 BLOCK_SUBBLOCKS (block) = chainon (BLOCK_SUBBLOCKS (block),
1129 subblocks);
1130 }
1131 /* If we created the block earlier on, and we are just
1132 diddling it now, then it already should have a proper
1133 BLOCK_END_NOTE value associated with it. */
1134 }
1135 else
1136 {
1137 BLOCK_VARS (block) = decls;
1138 BLOCK_TYPE_TAGS (block) = tags;
1139 BLOCK_SUBBLOCKS (block) = subblocks;
1140 /* Otherwise, for a new block, install a new BLOCK_END_NOTE value. */
1141 remember_end_note (block);
1142 }
1143 }
1144
1145 /* In each subblock, record that this is its superior. */
1146
1147 if (keep >= 0)
1148 for (link = subblocks; link; link = TREE_CHAIN (link))
1149 BLOCK_SUPERCONTEXT (link) = block;
1150
1151 /* Clear out the meanings of the local variables of this level. */
1152
1153 if (current_binding_level->is_for_scope && flag_new_for_scope == 1)
1154 {
1155 struct binding_level *outer = current_binding_level->level_chain;
1156 for (link = decls; link; link = TREE_CHAIN (link))
1157 {
1158 if (TREE_CODE (link) == VAR_DECL)
1159 DECL_DEAD_FOR_LOCAL (link) = 1;
1160 else
1161 IDENTIFIER_LOCAL_VALUE (DECL_NAME (link)) = NULL_TREE;
1162 }
1163
1164 /* Save declarations made in a 'for' statement so we can support pre-ANSI
1165 'for' scoping semantics. */
1166
1167 for (link = current_binding_level->shadowed; link; link = TREE_CHAIN (link))
1168 {
1169 tree id = TREE_PURPOSE (link);
1170 tree decl = IDENTIFIER_LOCAL_VALUE (id);
1171
1172 if (decl && DECL_DEAD_FOR_LOCAL (decl))
1173 {
1174 /* In this case keep the dead for-decl visible,
1175 but remember what (if anything) it shadowed. */
1176 DECL_SHADOWED_FOR_VAR (decl) = TREE_VALUE (link);
1177 TREE_CHAIN (decl) = outer->dead_vars_from_for;
1178 outer->dead_vars_from_for = decl;
1179 }
1180 else
1181 IDENTIFIER_LOCAL_VALUE (id) = TREE_VALUE (link);
1182 }
1183 }
1184 else /* Not special for scope. */
1185 {
1186 for (link = decls; link; link = TREE_CHAIN (link))
1187 {
1188 if (DECL_NAME (link) != NULL_TREE)
1189 {
1190 /* If the ident. was used or addressed via a local extern decl,
1191 don't forget that fact. */
1192 if (DECL_EXTERNAL (link))
1193 {
1194 if (TREE_USED (link))
1195 TREE_USED (DECL_ASSEMBLER_NAME (link)) = 1;
1196 if (TREE_ADDRESSABLE (link))
1197 TREE_ADDRESSABLE (DECL_ASSEMBLER_NAME (link)) = 1;
1198 }
1199 IDENTIFIER_LOCAL_VALUE (DECL_NAME (link)) = NULL_TREE;
1200 }
1201 }
1202
1203 /* Restore all name-meanings of the outer levels
1204 that were shadowed by this level. */
1205
1206 for (link = current_binding_level->shadowed;
1207 link; link = TREE_CHAIN (link))
1208 IDENTIFIER_LOCAL_VALUE (TREE_PURPOSE (link)) = TREE_VALUE (link);
1209
1210 /* We first restore the regular decls and *then* the dead_vars_from_for
1211 to handle this case:
1212
1213 int i; // i#1
1214 {
1215 for (int i; ; ) { ...} // i#2
1216 int i; // i#3
1217 } // we are here
1218
1219 In this case, we want remove the binding for i#3, restoring
1220 that of i#2. Then we want to remove the binding for i#2,
1221 and restore that of i#1. */
1222
1223 link = current_binding_level->dead_vars_from_for;
1224 for (; link != NULL_TREE; link = TREE_CHAIN (link))
1225 {
1226 tree id = DECL_NAME (link);
1227 if (IDENTIFIER_LOCAL_VALUE (id) == link)
1228 IDENTIFIER_LOCAL_VALUE (id) = DECL_SHADOWED_FOR_VAR (link);
1229 }
1230
1231 for (link = current_binding_level->class_shadowed;
1232 link; link = TREE_CHAIN (link))
1233 IDENTIFIER_CLASS_VALUE (TREE_PURPOSE (link)) = TREE_VALUE (link);
1234 for (link = current_binding_level->type_shadowed;
1235 link; link = TREE_CHAIN (link))
1236 SET_IDENTIFIER_TYPE_VALUE (TREE_PURPOSE (link), TREE_VALUE (link));
1237 }
1238
1239 /* If the level being exited is the top level of a function,
1240 check over all the labels. */
1241
1242 if (functionbody)
1243 {
1244 /* If this is the top level block of a function,
1245 the vars are the function's parameters.
1246 Don't leave them in the BLOCK because they are
1247 found in the FUNCTION_DECL instead. */
1248
1249 BLOCK_VARS (block) = 0;
1250
1251 /* Clear out the definitions of all label names,
1252 since their scopes end here. */
1253
1254 for (link = named_labels; link; link = TREE_CHAIN (link))
1255 {
1256 register tree label = TREE_VALUE (link);
1257
1258 if (DECL_INITIAL (label) == NULL_TREE)
1259 {
1260 cp_error_at ("label `%D' used but not defined", label);
1261 /* Avoid crashing later. */
1262 define_label (input_filename, 1, DECL_NAME (label));
1263 }
1264 else if (warn_unused && !TREE_USED (label))
1265 cp_warning_at ("label `%D' defined but not used", label);
1266 SET_IDENTIFIER_LABEL_VALUE (DECL_NAME (label), NULL_TREE);
1267
1268 /* Put the labels into the "variables" of the
1269 top-level block, so debugger can see them. */
1270 TREE_CHAIN (label) = BLOCK_VARS (block);
1271 BLOCK_VARS (block) = label;
1272 }
1273
1274 named_labels = NULL_TREE;
1275 }
1276
1277 /* Any uses of undefined labels now operate under constraints
1278 of next binding contour. */
1279 {
1280 struct binding_level *level_chain;
1281 level_chain = current_binding_level->level_chain;
1282 if (level_chain)
1283 {
1284 struct named_label_list *labels;
1285 for (labels = named_label_uses; labels; labels = labels->next)
1286 if (labels->binding_level == current_binding_level)
1287 {
1288 labels->binding_level = level_chain;
1289 labels->names_in_scope = level_chain->names;
1290 }
1291 }
1292 }
1293
1294 tmp = current_binding_level->keep;
1295
1296 pop_binding_level ();
1297 if (functionbody)
1298 DECL_INITIAL (current_function_decl) = block;
1299 else if (block)
1300 {
1301 if (!block_previously_created)
1302 current_binding_level->blocks
1303 = chainon (current_binding_level->blocks, block);
1304 }
1305 /* If we did not make a block for the level just exited,
1306 any blocks made for inner levels
1307 (since they cannot be recorded as subblocks in that level)
1308 must be carried forward so they will later become subblocks
1309 of something else. */
1310 else if (subblocks)
1311 {
1312 if (keep == 2)
1313 current_binding_level->blocks
1314 = chainon (subblocks, current_binding_level->blocks);
1315 else
1316 current_binding_level->blocks
1317 = chainon (current_binding_level->blocks, subblocks);
1318 }
1319
1320 /* Take care of compiler's internal binding structures. */
1321 if (tmp == 2)
1322 {
1323 expand_end_bindings (getdecls (), keep, 1);
1324 /* Each and every BLOCK node created here in `poplevel' is important
1325 (e.g. for proper debugging information) so if we created one
1326 earlier, mark it as "used". */
1327 if (block)
1328 TREE_USED (block) = 1;
1329 block = poplevel (keep, reverse, real_functionbody);
1330 }
1331
1332 /* Each and every BLOCK node created here in `poplevel' is important
1333 (e.g. for proper debugging information) so if we created one
1334 earlier, mark it as "used". */
1335 if (block)
1336 TREE_USED (block) = 1;
1337 return block;
1338 }
1339
1340 /* Delete the node BLOCK from the current binding level.
1341 This is used for the block inside a stmt expr ({...})
1342 so that the block can be reinserted where appropriate. */
1343
1344 void
1345 delete_block (block)
1346 tree block;
1347 {
1348 tree t;
1349 if (current_binding_level->blocks == block)
1350 current_binding_level->blocks = TREE_CHAIN (block);
1351 for (t = current_binding_level->blocks; t;)
1352 {
1353 if (TREE_CHAIN (t) == block)
1354 TREE_CHAIN (t) = TREE_CHAIN (block);
1355 else
1356 t = TREE_CHAIN (t);
1357 }
1358 TREE_CHAIN (block) = NULL_TREE;
1359 /* Clear TREE_USED which is always set by poplevel.
1360 The flag is set again if insert_block is called. */
1361 TREE_USED (block) = 0;
1362 }
1363
1364 /* Insert BLOCK at the end of the list of subblocks of the
1365 current binding level. This is used when a BIND_EXPR is expanded,
1366 to handle the BLOCK node inside the BIND_EXPR. */
1367
1368 void
1369 insert_block (block)
1370 tree block;
1371 {
1372 TREE_USED (block) = 1;
1373 current_binding_level->blocks
1374 = chainon (current_binding_level->blocks, block);
1375 }
1376
1377 /* Set the BLOCK node for the innermost scope
1378 (the one we are currently in). */
1379
1380 void
1381 set_block (block)
1382 register tree block;
1383 {
1384 current_binding_level->this_block = block;
1385 }
1386
1387 /* Do a pushlevel for class declarations. */
1388
1389 void
1390 pushlevel_class ()
1391 {
1392 register struct binding_level *newlevel;
1393
1394 /* Reuse or create a struct for this binding level. */
1395 #if defined(DEBUG_CP_BINDING_LEVELS)
1396 if (0)
1397 #else /* !defined(DEBUG_CP_BINDING_LEVELS) */
1398 if (free_binding_level)
1399 #endif /* !defined(DEBUG_CP_BINDING_LEVELS) */
1400 {
1401 newlevel = free_binding_level;
1402 free_binding_level = free_binding_level->level_chain;
1403 }
1404 else
1405 {
1406 newlevel = make_binding_level ();
1407 }
1408
1409 #if defined(DEBUG_CP_BINDING_LEVELS)
1410 is_class_level = 1;
1411 #endif /* defined(DEBUG_CP_BINDING_LEVELS) */
1412
1413 push_binding_level (newlevel, 0, 0);
1414
1415 decl_stack = push_decl_level (decl_stack, &decl_obstack);
1416 class_binding_level = current_binding_level;
1417 class_binding_level->parm_flag = 2;
1418 /* We have just pushed into a new binding level. Now, fake out the rest
1419 of the compiler. Set the `current_binding_level' back to point to
1420 the most closely containing non-class binding level. */
1421 do
1422 {
1423 current_binding_level = current_binding_level->level_chain;
1424 }
1425 while (current_binding_level->parm_flag == 2);
1426 }
1427
1428 /* ...and a poplevel for class declarations. FORCE is used to force
1429 clearing out of CLASS_VALUEs after a class definition. */
1430
1431 tree
1432 poplevel_class (force)
1433 int force;
1434 {
1435 register struct binding_level *level = class_binding_level;
1436 tree block = NULL_TREE;
1437 tree shadowed;
1438
1439 my_friendly_assert (level != 0, 354);
1440
1441 decl_stack = pop_stack_level (decl_stack);
1442 for (shadowed = level->shadowed; shadowed; shadowed = TREE_CHAIN (shadowed))
1443 IDENTIFIER_LOCAL_VALUE (TREE_PURPOSE (shadowed)) = TREE_VALUE (shadowed);
1444 /* If we're leaving a toplevel class, don't bother to do the setting
1445 of IDENTIFIER_CLASS_VALUE to NULL_TREE, since first of all this slot
1446 shouldn't even be used when current_class_type isn't set, and second,
1447 if we don't touch it here, we're able to use the cache effect if the
1448 next time we're entering a class scope, it is the same class. */
1449 if (current_class_depth != 1 || force)
1450 for (shadowed = level->class_shadowed;
1451 shadowed;
1452 shadowed = TREE_CHAIN (shadowed))
1453 IDENTIFIER_CLASS_VALUE (TREE_PURPOSE (shadowed)) = TREE_VALUE (shadowed);
1454 else
1455 /* Remember to save what IDENTIFIER's were bound in this scope so we
1456 can recover from cache misses. */
1457 {
1458 previous_class_type = current_class_type;
1459 previous_class_values = class_binding_level->class_shadowed;
1460 }
1461 for (shadowed = level->type_shadowed;
1462 shadowed;
1463 shadowed = TREE_CHAIN (shadowed))
1464 SET_IDENTIFIER_TYPE_VALUE (TREE_PURPOSE (shadowed), TREE_VALUE (shadowed));
1465
1466 GNU_xref_end_scope ((HOST_WIDE_INT) class_binding_level,
1467 (HOST_WIDE_INT) class_binding_level->level_chain,
1468 class_binding_level->parm_flag,
1469 class_binding_level->keep);
1470
1471 if (class_binding_level->parm_flag != 2)
1472 class_binding_level = (struct binding_level *)0;
1473
1474 /* Now, pop out of the binding level which we created up in the
1475 `pushlevel_class' routine. */
1476 #if defined(DEBUG_CP_BINDING_LEVELS)
1477 is_class_level = 1;
1478 #endif /* defined(DEBUG_CP_BINDING_LEVELS) */
1479
1480 pop_binding_level ();
1481
1482 return block;
1483 }
1484 \f
1485 /* For debugging. */
1486 static int no_print_functions = 0;
1487 static int no_print_builtins = 0;
1488
1489 void
1490 print_binding_level (lvl)
1491 struct binding_level *lvl;
1492 {
1493 tree t;
1494 int i = 0, len;
1495 fprintf (stderr, " blocks=");
1496 fprintf (stderr, HOST_PTR_PRINTF, lvl->blocks);
1497 fprintf (stderr, " n_incomplete=%d parm_flag=%d keep=%d",
1498 list_length (lvl->incomplete), lvl->parm_flag, lvl->keep);
1499 if (lvl->tag_transparent)
1500 fprintf (stderr, " tag-transparent");
1501 if (lvl->more_cleanups_ok)
1502 fprintf (stderr, " more-cleanups-ok");
1503 if (lvl->have_cleanups)
1504 fprintf (stderr, " have-cleanups");
1505 fprintf (stderr, "\n");
1506 if (lvl->names)
1507 {
1508 fprintf (stderr, " names:\t");
1509 /* We can probably fit 3 names to a line? */
1510 for (t = lvl->names; t; t = TREE_CHAIN (t))
1511 {
1512 if (no_print_functions && (TREE_CODE (t) == FUNCTION_DECL))
1513 continue;
1514 if (no_print_builtins
1515 && (TREE_CODE (t) == TYPE_DECL)
1516 && (!strcmp (DECL_SOURCE_FILE (t),"<built-in>")))
1517 continue;
1518
1519 /* Function decls tend to have longer names. */
1520 if (TREE_CODE (t) == FUNCTION_DECL)
1521 len = 3;
1522 else
1523 len = 2;
1524 i += len;
1525 if (i > 6)
1526 {
1527 fprintf (stderr, "\n\t");
1528 i = len;
1529 }
1530 print_node_brief (stderr, "", t, 0);
1531 if (t == error_mark_node)
1532 break;
1533 }
1534 if (i)
1535 fprintf (stderr, "\n");
1536 }
1537 if (lvl->tags)
1538 {
1539 fprintf (stderr, " tags:\t");
1540 i = 0;
1541 for (t = lvl->tags; t; t = TREE_CHAIN (t))
1542 {
1543 if (TREE_PURPOSE (t) == NULL_TREE)
1544 len = 3;
1545 else if (TREE_PURPOSE (t) == TYPE_IDENTIFIER (TREE_VALUE (t)))
1546 len = 2;
1547 else
1548 len = 4;
1549 i += len;
1550 if (i > 5)
1551 {
1552 fprintf (stderr, "\n\t");
1553 i = len;
1554 }
1555 if (TREE_PURPOSE (t) == NULL_TREE)
1556 {
1557 print_node_brief (stderr, "<unnamed-typedef", TREE_VALUE (t), 0);
1558 fprintf (stderr, ">");
1559 }
1560 else if (TREE_PURPOSE (t) == TYPE_IDENTIFIER (TREE_VALUE (t)))
1561 print_node_brief (stderr, "", TREE_VALUE (t), 0);
1562 else
1563 {
1564 print_node_brief (stderr, "<typedef", TREE_PURPOSE (t), 0);
1565 print_node_brief (stderr, "", TREE_VALUE (t), 0);
1566 fprintf (stderr, ">");
1567 }
1568 }
1569 if (i)
1570 fprintf (stderr, "\n");
1571 }
1572 if (lvl->shadowed)
1573 {
1574 fprintf (stderr, " shadowed:");
1575 for (t = lvl->shadowed; t; t = TREE_CHAIN (t))
1576 {
1577 fprintf (stderr, " %s ", IDENTIFIER_POINTER (TREE_PURPOSE (t)));
1578 }
1579 fprintf (stderr, "\n");
1580 }
1581 if (lvl->class_shadowed)
1582 {
1583 fprintf (stderr, " class-shadowed:");
1584 for (t = lvl->class_shadowed; t; t = TREE_CHAIN (t))
1585 {
1586 fprintf (stderr, " %s ", IDENTIFIER_POINTER (TREE_PURPOSE (t)));
1587 }
1588 fprintf (stderr, "\n");
1589 }
1590 if (lvl->type_shadowed)
1591 {
1592 fprintf (stderr, " type-shadowed:");
1593 for (t = lvl->type_shadowed; t; t = TREE_CHAIN (t))
1594 {
1595 fprintf (stderr, " %s ", IDENTIFIER_POINTER (TREE_PURPOSE (t)));
1596 }
1597 fprintf (stderr, "\n");
1598 }
1599 }
1600
1601 void
1602 print_other_binding_stack (stack)
1603 struct binding_level *stack;
1604 {
1605 struct binding_level *level;
1606 for (level = stack; level != global_binding_level; level = level->level_chain)
1607 {
1608 fprintf (stderr, "binding level ");
1609 fprintf (stderr, HOST_PTR_PRINTF, level);
1610 fprintf (stderr, "\n");
1611 print_binding_level (level);
1612 }
1613 }
1614
1615 void
1616 print_binding_stack ()
1617 {
1618 struct binding_level *b;
1619 fprintf (stderr, "current_binding_level=");
1620 fprintf (stderr, HOST_PTR_PRINTF, current_binding_level);
1621 fprintf (stderr, "\nclass_binding_level=");
1622 fprintf (stderr, HOST_PTR_PRINTF, class_binding_level);
1623 fprintf (stderr, "\nglobal_binding_level=");
1624 fprintf (stderr, HOST_PTR_PRINTF, global_binding_level);
1625 fprintf (stderr, "\n");
1626 if (class_binding_level)
1627 {
1628 for (b = class_binding_level; b; b = b->level_chain)
1629 if (b == current_binding_level)
1630 break;
1631 if (b)
1632 b = class_binding_level;
1633 else
1634 b = current_binding_level;
1635 }
1636 else
1637 b = current_binding_level;
1638 print_other_binding_stack (b);
1639 fprintf (stderr, "global:\n");
1640 print_binding_level (global_binding_level);
1641 }
1642
1643 /* Namespace binding access routines: The namespace_bindings field of
1644 the identifier is polymorphic, with three possible values:
1645 NULL_TREE, a list of CPLUS_BINDINGS, or any other tree_node
1646 indicating the BINDING_VALUE of global_namespace. */
1647
1648 /* Check whether the a binding for the name to scope is known.
1649 Assumes that the bindings of the name are already a list
1650 of bindings. Returns the binding found, or NULL_TREE. */
1651
1652 static tree
1653 find_binding (name, scope)
1654 tree name;
1655 tree scope;
1656 {
1657 tree iter, prev = NULL_TREE;
1658
1659 scope = ORIGINAL_NAMESPACE (scope);
1660
1661 for (iter = IDENTIFIER_NAMESPACE_BINDINGS (name); iter;
1662 iter = TREE_CHAIN (iter))
1663 {
1664 my_friendly_assert (TREE_CODE (iter) == CPLUS_BINDING, 374);
1665 if (BINDING_SCOPE (iter) == scope)
1666 {
1667 /* Move binding found to the fron of the list, so
1668 subsequent lookups will find it faster. */
1669 if (prev)
1670 {
1671 TREE_CHAIN (prev) = TREE_CHAIN (iter);
1672 TREE_CHAIN (iter) = IDENTIFIER_NAMESPACE_BINDINGS (name);
1673 IDENTIFIER_NAMESPACE_BINDINGS (name) = iter;
1674 }
1675 return iter;
1676 }
1677 prev = iter;
1678 }
1679 return NULL_TREE;
1680 }
1681
1682 /* Always returns a binding for name in scope. If the
1683 namespace_bindings is not a list, convert it to one first.
1684 If no binding is found, make a new one. */
1685
1686 tree
1687 binding_for_name (name, scope)
1688 tree name;
1689 tree scope;
1690 {
1691 tree b = IDENTIFIER_NAMESPACE_BINDINGS (name);
1692 tree result;
1693
1694 scope = ORIGINAL_NAMESPACE (scope);
1695
1696 if (b && TREE_CODE (b) != CPLUS_BINDING)
1697 {
1698 /* Get rid of optimization for global scope. */
1699 IDENTIFIER_NAMESPACE_BINDINGS (name) = NULL_TREE;
1700 BINDING_VALUE (binding_for_name (name, global_namespace)) = b;
1701 b = IDENTIFIER_NAMESPACE_BINDINGS (name);
1702 }
1703 if (b && (result = find_binding (name, scope)))
1704 return result;
1705 /* Not found, make a new permanent one. */
1706 push_obstacks (&permanent_obstack, &permanent_obstack);
1707 result = make_node (CPLUS_BINDING);
1708 TREE_CHAIN (result) = b;
1709 IDENTIFIER_NAMESPACE_BINDINGS (name) = result;
1710 BINDING_SCOPE (result) = scope;
1711 BINDING_TYPE (result) = NULL_TREE;
1712 BINDING_VALUE (result) = NULL_TREE;
1713 pop_obstacks ();
1714 return result;
1715 }
1716
1717 /* Return the binding value for name in scope, considering that
1718 namespace_binding may or may not be a list of CPLUS_BINDINGS. */
1719
1720 tree
1721 namespace_binding (name, scope)
1722 tree name;
1723 tree scope;
1724 {
1725 tree b = IDENTIFIER_NAMESPACE_BINDINGS (name);
1726 if (b == NULL_TREE)
1727 return NULL_TREE;
1728 if (scope == NULL_TREE)
1729 scope = global_namespace;
1730 if (TREE_CODE (b) != CPLUS_BINDING)
1731 return (scope == global_namespace) ? b : NULL_TREE;
1732 name = find_binding (name,scope);
1733 if (name == NULL_TREE)
1734 return name;
1735 return BINDING_VALUE (name);
1736 }
1737
1738 /* Set the binding value for name in scope. If modifying the binding
1739 of global_namespace is attempted, try to optimize it. */
1740
1741 void
1742 set_namespace_binding (name, scope, val)
1743 tree name;
1744 tree scope;
1745 tree val;
1746 {
1747 tree b;
1748
1749 if (scope == NULL_TREE)
1750 scope = global_namespace;
1751
1752 if (scope == global_namespace)
1753 {
1754 b = IDENTIFIER_NAMESPACE_BINDINGS (name);
1755 if (b == NULL_TREE || TREE_CODE (b) != CPLUS_BINDING)
1756 {
1757 IDENTIFIER_NAMESPACE_BINDINGS (name) = val;
1758 return;
1759 }
1760 }
1761 b = binding_for_name (name, scope);
1762 BINDING_VALUE (b) = val;
1763 }
1764
1765 /* Push into the scope of the NAME namespace. If NAME is NULL_TREE, then we
1766 select a name that is unique to this compilation unit. */
1767
1768 void
1769 push_namespace (name)
1770 tree name;
1771 {
1772 tree d;
1773 int need_new = 1;
1774 int implicit_use = 0;
1775 int global = 0;
1776 if (!global_namespace)
1777 {
1778 /* This must be ::. */
1779 my_friendly_assert (name == get_identifier ("::"), 377);
1780 global = 1;
1781 }
1782 else if (!name)
1783 {
1784 /* The name of anonymous namespace is unique for the translation
1785 unit. */
1786 static tree anon_name = NULL_TREE;
1787 if (!anon_name)
1788 anon_name = get_file_function_name ('N');
1789 name = anon_name;
1790 d = IDENTIFIER_NAMESPACE_VALUE (name);
1791 if (d)
1792 /* Reopening anonymous namespace. */
1793 need_new = 0;
1794 implicit_use = 1;
1795 }
1796 else if (current_namespace == global_namespace
1797 && name == DECL_NAME (std_node))
1798 {
1799 in_std++;
1800 return;
1801 }
1802 else
1803 {
1804 /* Check whether this is an extended namespace definition. */
1805 d = IDENTIFIER_NAMESPACE_VALUE (name);
1806 if (d != NULL_TREE && TREE_CODE (d) == NAMESPACE_DECL)
1807 {
1808 need_new = 0;
1809 if (DECL_NAMESPACE_ALIAS (d))
1810 {
1811 cp_error ("namespace alias `%D' not allowed here, assuming `%D'",
1812 d, DECL_NAMESPACE_ALIAS (d));
1813 d = DECL_NAMESPACE_ALIAS (d);
1814 }
1815 }
1816 }
1817
1818 if (need_new)
1819 {
1820 /* Make a new namespace, binding the name to it. */
1821 d = build_lang_decl (NAMESPACE_DECL, name, void_type_node);
1822 /* The global namespace is not pushed, and the global binding
1823 level is set elsewhere. */
1824 if (!global)
1825 {
1826 d = pushdecl (d);
1827 pushlevel (0);
1828 declare_namespace_level ();
1829 NAMESPACE_LEVEL (d) = current_binding_level;
1830 }
1831 }
1832 else
1833 resume_binding_level (NAMESPACE_LEVEL (d));
1834
1835 if (implicit_use)
1836 do_using_directive (d);
1837 /* Enter the name space. */
1838 current_namespace = d;
1839 }
1840
1841 /* Pop from the scope of the current namespace. */
1842
1843 void
1844 pop_namespace ()
1845 {
1846 if (current_namespace == global_namespace)
1847 {
1848 my_friendly_assert (in_std>0, 980421);
1849 in_std--;
1850 return;
1851 }
1852 current_namespace = CP_DECL_CONTEXT (current_namespace);
1853 /* The binding level is not popped, as it might be re-opened later. */
1854 suspend_binding_level ();
1855 }
1856
1857 /* Concatenate the binding levels of all namespaces. */
1858
1859 void
1860 cat_namespace_levels()
1861 {
1862 tree current;
1863 tree last;
1864 struct binding_level *b;
1865
1866 last = NAMESPACE_LEVEL (global_namespace) -> names;
1867 /* The nested namespaces appear in the names list of their ancestors. */
1868 for (current = last; current; current = TREE_CHAIN (current))
1869 {
1870 if (TREE_CODE (current) != NAMESPACE_DECL
1871 || DECL_NAMESPACE_ALIAS (current))
1872 continue;
1873 if (!DECL_LANG_SPECIFIC (current))
1874 {
1875 /* Hmm. std. */
1876 my_friendly_assert (current == std_node, 393);
1877 continue;
1878 }
1879 b = NAMESPACE_LEVEL (current);
1880 while (TREE_CHAIN (last))
1881 last = TREE_CHAIN (last);
1882 TREE_CHAIN (last) = NAMESPACE_LEVEL (current) -> names;
1883 }
1884 }
1885 \f
1886 /* Subroutines for reverting temporarily to top-level for instantiation
1887 of templates and such. We actually need to clear out the class- and
1888 local-value slots of all identifiers, so that only the global values
1889 are at all visible. Simply setting current_binding_level to the global
1890 scope isn't enough, because more binding levels may be pushed. */
1891 struct saved_scope {
1892 struct binding_level *old_binding_level;
1893 tree old_bindings;
1894 tree old_namespace;
1895 struct saved_scope *prev;
1896 tree class_name, class_type, function_decl;
1897 struct binding_level *class_bindings;
1898 tree *lang_base, *lang_stack, lang_name;
1899 int lang_stacksize;
1900 int minimal_parse_mode;
1901 tree last_function_parms;
1902 tree template_parms;
1903 HOST_WIDE_INT processing_template_decl;
1904 tree previous_class_type, previous_class_values;
1905 int processing_specialization;
1906 int processing_explicit_instantiation;
1907 };
1908 static struct saved_scope *current_saved_scope;
1909
1910 /* A chain of the binding vecs created by store_bindings. We create a
1911 whole bunch of these during compilation, on permanent_obstack, so we
1912 can't just throw them away. */
1913 static tree free_binding_vecs;
1914
1915 static tree
1916 store_bindings (names, old_bindings)
1917 tree names, old_bindings;
1918 {
1919 tree t;
1920 for (t = names; t; t = TREE_CHAIN (t))
1921 {
1922 tree binding, t1, id;
1923
1924 if (TREE_CODE (t) == TREE_LIST)
1925 id = TREE_PURPOSE (t);
1926 else
1927 id = DECL_NAME (t);
1928
1929 if (!id
1930 || (!IDENTIFIER_LOCAL_VALUE (id)
1931 && !IDENTIFIER_CLASS_VALUE (id)))
1932 continue;
1933
1934 for (t1 = old_bindings; t1; t1 = TREE_CHAIN (t1))
1935 if (TREE_VEC_ELT (t1, 0) == id)
1936 goto skip_it;
1937
1938 if (free_binding_vecs)
1939 {
1940 binding = free_binding_vecs;
1941 free_binding_vecs = TREE_CHAIN (free_binding_vecs);
1942 }
1943 else
1944 binding = make_tree_vec (4);
1945
1946 if (id)
1947 {
1948 my_friendly_assert (TREE_CODE (id) == IDENTIFIER_NODE, 135);
1949 TREE_VEC_ELT (binding, 0) = id;
1950 TREE_VEC_ELT (binding, 1) = REAL_IDENTIFIER_TYPE_VALUE (id);
1951 TREE_VEC_ELT (binding, 2) = IDENTIFIER_LOCAL_VALUE (id);
1952 TREE_VEC_ELT (binding, 3) = IDENTIFIER_CLASS_VALUE (id);
1953 IDENTIFIER_LOCAL_VALUE (id) = NULL_TREE;
1954 IDENTIFIER_CLASS_VALUE (id) = NULL_TREE;
1955 }
1956 TREE_CHAIN (binding) = old_bindings;
1957 old_bindings = binding;
1958 skip_it:
1959 ;
1960 }
1961 return old_bindings;
1962 }
1963
1964 void
1965 maybe_push_to_top_level (pseudo)
1966 int pseudo;
1967 {
1968 extern int current_lang_stacksize;
1969 struct saved_scope *s
1970 = (struct saved_scope *) xmalloc (sizeof (struct saved_scope));
1971 struct binding_level *b = inner_binding_level;
1972 tree old_bindings = NULL_TREE;
1973
1974 if (current_function_decl)
1975 push_cp_function_context (NULL_TREE);
1976
1977 if (previous_class_type)
1978 old_bindings = store_bindings (previous_class_values, old_bindings);
1979
1980 /* Have to include global_binding_level, because class-level decls
1981 aren't listed anywhere useful. */
1982 for (; b; b = b->level_chain)
1983 {
1984 tree t;
1985
1986 /* Template IDs are inserted into the global level. If they were
1987 inserted into namespace level, finish_file wouldn't find them
1988 when doing pending instantiations. Therefore, don't stop at
1989 namespace level, but continue until :: . */
1990 if (b == global_binding_level || (pseudo && b->pseudo_global))
1991 break;
1992
1993 old_bindings = store_bindings (b->names, old_bindings);
1994 /* We also need to check class_shadowed to save class-level type
1995 bindings, since pushclass doesn't fill in b->names. */
1996 if (b->parm_flag == 2)
1997 old_bindings = store_bindings (b->class_shadowed, old_bindings);
1998
1999 /* Unwind type-value slots back to top level. */
2000 for (t = b->type_shadowed; t; t = TREE_CHAIN (t))
2001 SET_IDENTIFIER_TYPE_VALUE (TREE_PURPOSE (t), TREE_VALUE (t));
2002 }
2003
2004 s->old_binding_level = current_binding_level;
2005 current_binding_level = b;
2006
2007 s->old_namespace = current_namespace;
2008 s->class_name = current_class_name;
2009 s->class_type = current_class_type;
2010 s->function_decl = current_function_decl;
2011 s->class_bindings = class_binding_level;
2012 s->lang_stack = current_lang_stack;
2013 s->lang_base = current_lang_base;
2014 s->lang_stacksize = current_lang_stacksize;
2015 s->lang_name = current_lang_name;
2016 s->minimal_parse_mode = minimal_parse_mode;
2017 s->last_function_parms = last_function_parms;
2018 s->template_parms = current_template_parms;
2019 s->processing_template_decl = processing_template_decl;
2020 s->previous_class_type = previous_class_type;
2021 s->previous_class_values = previous_class_values;
2022 s->processing_specialization = processing_specialization;
2023 s->processing_explicit_instantiation = processing_explicit_instantiation;
2024
2025 current_class_name = current_class_type = NULL_TREE;
2026 current_function_decl = NULL_TREE;
2027 class_binding_level = (struct binding_level *)0;
2028 current_lang_stacksize = 10;
2029 current_lang_stack = current_lang_base
2030 = (tree *) xmalloc (current_lang_stacksize * sizeof (tree));
2031 current_lang_name = lang_name_cplusplus;
2032 strict_prototype = strict_prototypes_lang_cplusplus;
2033 named_labels = NULL_TREE;
2034 shadowed_labels = NULL_TREE;
2035 minimal_parse_mode = 0;
2036 previous_class_type = previous_class_values = NULL_TREE;
2037 processing_specialization = 0;
2038 processing_explicit_instantiation = 0;
2039 current_template_parms = NULL_TREE;
2040 processing_template_decl = 0;
2041 current_namespace = global_namespace;
2042
2043 s->prev = current_saved_scope;
2044 s->old_bindings = old_bindings;
2045 current_saved_scope = s;
2046
2047 push_obstacks (&permanent_obstack, &permanent_obstack);
2048 }
2049
2050 void
2051 push_to_top_level ()
2052 {
2053 maybe_push_to_top_level (0);
2054 }
2055
2056 void
2057 pop_from_top_level ()
2058 {
2059 extern int current_lang_stacksize;
2060 struct saved_scope *s = current_saved_scope;
2061 tree t;
2062
2063 /* Clear out class-level bindings cache. */
2064 if (previous_class_type)
2065 {
2066 popclass (-1);
2067 previous_class_type = NULL_TREE;
2068 }
2069
2070 pop_obstacks ();
2071
2072 current_binding_level = s->old_binding_level;
2073 current_saved_scope = s->prev;
2074 for (t = s->old_bindings; t; )
2075 {
2076 tree save = t;
2077 tree id = TREE_VEC_ELT (t, 0);
2078 if (id)
2079 {
2080 SET_IDENTIFIER_TYPE_VALUE (id, TREE_VEC_ELT (t, 1));
2081 IDENTIFIER_LOCAL_VALUE (id) = TREE_VEC_ELT (t, 2);
2082 IDENTIFIER_CLASS_VALUE (id) = TREE_VEC_ELT (t, 3);
2083 }
2084 t = TREE_CHAIN (t);
2085 TREE_CHAIN (save) = free_binding_vecs;
2086 free_binding_vecs = save;
2087 }
2088 current_namespace = s->old_namespace;
2089 current_class_name = s->class_name;
2090 current_class_type = s->class_type;
2091 current_function_decl = s->function_decl;
2092 class_binding_level = s->class_bindings;
2093 free (current_lang_base);
2094 current_lang_base = s->lang_base;
2095 current_lang_stack = s->lang_stack;
2096 current_lang_name = s->lang_name;
2097 current_lang_stacksize = s->lang_stacksize;
2098 if (current_lang_name == lang_name_cplusplus)
2099 strict_prototype = strict_prototypes_lang_cplusplus;
2100 else if (current_lang_name == lang_name_c)
2101 strict_prototype = strict_prototypes_lang_c;
2102 minimal_parse_mode = s->minimal_parse_mode;
2103 last_function_parms = s->last_function_parms;
2104 current_template_parms = s->template_parms;
2105 processing_template_decl = s->processing_template_decl;
2106 previous_class_type = s->previous_class_type;
2107 previous_class_values = s->previous_class_values;
2108 processing_specialization = s->processing_specialization;
2109 processing_explicit_instantiation = s->processing_explicit_instantiation;
2110
2111 free (s);
2112
2113 if (current_function_decl)
2114 pop_cp_function_context (NULL_TREE);
2115 }
2116 \f
2117 /* Push a definition of struct, union or enum tag "name".
2118 into binding_level "b". "type" should be the type node,
2119 We assume that the tag "name" is not already defined.
2120
2121 Note that the definition may really be just a forward reference.
2122 In that case, the TYPE_SIZE will be a NULL_TREE.
2123
2124 C++ gratuitously puts all these tags in the name space. */
2125
2126 /* When setting the IDENTIFIER_TYPE_VALUE field of an identifier ID,
2127 record the shadowed value for this binding contour. TYPE is
2128 the type that ID maps to. */
2129
2130 static void
2131 set_identifier_type_value_with_scope (id, type, b)
2132 tree id;
2133 tree type;
2134 struct binding_level *b;
2135 {
2136 if (!b->namespace_p)
2137 {
2138 /* Shadow the marker, not the real thing, so that the marker
2139 gets restored later. */
2140 tree old_type_value = REAL_IDENTIFIER_TYPE_VALUE (id);
2141 b->type_shadowed
2142 = tree_cons (id, old_type_value, b->type_shadowed);
2143 }
2144 else
2145 {
2146 tree binding = binding_for_name (id, current_namespace);
2147 BINDING_TYPE (binding) = type;
2148 /* Store marker instead of real type. */
2149 type = global_type_node;
2150 }
2151 SET_IDENTIFIER_TYPE_VALUE (id, type);
2152 }
2153
2154 /* As set_identifier_type_value_with_scope, but using inner_binding_level. */
2155
2156 void
2157 set_identifier_type_value (id, type)
2158 tree id;
2159 tree type;
2160 {
2161 set_identifier_type_value_with_scope (id, type, inner_binding_level);
2162 }
2163
2164 static void
2165 set_identifier_local_value_with_scope (id, val, b)
2166 tree id, val;
2167 struct binding_level *b;
2168 {
2169 tree oldlocal;
2170 my_friendly_assert (! b->namespace_p, 980716);
2171
2172 oldlocal = IDENTIFIER_LOCAL_VALUE (id);
2173 b->shadowed = tree_cons (id, oldlocal, b->shadowed);
2174 IDENTIFIER_LOCAL_VALUE (id) = val;
2175 }
2176
2177 void
2178 set_identifier_local_value (id, val)
2179 tree id, val;
2180 {
2181 set_identifier_local_value_with_scope (id, val, current_binding_level);
2182 }
2183
2184 /* Return the type associated with id. */
2185
2186 tree
2187 identifier_type_value (id)
2188 tree id;
2189 {
2190 /* There is no type with that name, anywhere. */
2191 if (REAL_IDENTIFIER_TYPE_VALUE (id) == NULL_TREE)
2192 return NULL_TREE;
2193 /* This is not the type marker, but the real thing. */
2194 if (REAL_IDENTIFIER_TYPE_VALUE (id) != global_type_node)
2195 return REAL_IDENTIFIER_TYPE_VALUE (id);
2196 /* Have to search for it. It must be on the global level, now.
2197 Ask lookup_name not to return non-types. */
2198 id = lookup_name_real (id, 2, 1, 0);
2199 if (id)
2200 return TREE_TYPE (id);
2201 return NULL_TREE;
2202 }
2203
2204 /* Pop off extraneous binding levels left over due to syntax errors.
2205
2206 We don't pop past namespaces, as they might be valid. */
2207
2208 void
2209 pop_everything ()
2210 {
2211 #ifdef DEBUG_CP_BINDING_LEVELS
2212 fprintf (stderr, "XXX entering pop_everything ()\n");
2213 #endif
2214 while (! toplevel_bindings_p () && ! pseudo_global_level_p ())
2215 {
2216 if (class_binding_level)
2217 pop_nested_class (1);
2218 else
2219 poplevel (0, 0, 0);
2220 }
2221 #ifdef DEBUG_CP_BINDING_LEVELS
2222 fprintf (stderr, "XXX leaving pop_everything ()\n");
2223 #endif
2224 }
2225
2226 /* The type TYPE is being declared. If it is a class template, or a
2227 specialization of a class template, do any processing required and
2228 perform error-checking. If IS_FRIEND is non-zero, this TYPE is
2229 being declared a friend. B is the binding level at which this TYPE
2230 should be bound.
2231
2232 Returns the TYPE_DECL for TYPE, which may have been altered by this
2233 processing. */
2234
2235 static tree
2236 maybe_process_template_type_declaration (type, globalize, b)
2237 tree type;
2238 int globalize;
2239 struct binding_level* b;
2240 {
2241 tree decl = TYPE_NAME (type);
2242
2243 if (processing_template_parmlist)
2244 /* You can't declare a new template type in a template parameter
2245 list. But, you can declare a non-template type:
2246
2247 template <class A*> struct S;
2248
2249 is a forward-declaration of `A'. */
2250 ;
2251 else
2252 {
2253 maybe_check_template_type (type);
2254
2255 my_friendly_assert (IS_AGGR_TYPE (type)
2256 || TREE_CODE (type) == ENUMERAL_TYPE, 0);
2257
2258
2259 if (/* If !GLOBALIZE then we are looking at a definition.
2260 It may not be a primary template. (For example, in:
2261
2262 template <class T>
2263 struct S1 { class S2 {}; }
2264
2265 we have to push_template_decl for S2.) */
2266 (processing_template_decl && !globalize)
2267 /* If we are declaring a friend template class, we will
2268 have GLOBALIZE set, since something like:
2269
2270 template <class T>
2271 struct S1 {
2272 template <class U>
2273 friend class S2;
2274 };
2275
2276 declares S2 to be at global scope. */
2277 || PROCESSING_REAL_TEMPLATE_DECL_P ())
2278 {
2279 /* This may change after the call to
2280 push_template_decl_real, but we want the original value. */
2281 tree name = DECL_NAME (decl);
2282
2283 decl = push_template_decl_real (decl, globalize);
2284 /* If the current binding level is the binding level for the
2285 template parameters (see the comment in
2286 begin_template_parm_list) and the enclosing level is a class
2287 scope, and we're not looking at a friend, push the
2288 declaration of the member class into the class scope. In the
2289 friend case, push_template_decl will already have put the
2290 friend into global scope, if appropriate. */
2291 if (TREE_CODE (type) != ENUMERAL_TYPE
2292 && !globalize && b->pseudo_global
2293 && b->level_chain->parm_flag == 2)
2294 {
2295 pushdecl_with_scope (CLASSTYPE_TI_TEMPLATE (type),
2296 b->level_chain);
2297 /* Put this tag on the list of tags for the class, since
2298 that won't happen below because B is not the class
2299 binding level, but is instead the pseudo-global level. */
2300 b->level_chain->tags =
2301 saveable_tree_cons (name, type, b->level_chain->tags);
2302 TREE_NONLOCAL_FLAG (type) = 1;
2303 if (TYPE_SIZE (current_class_type) == NULL_TREE)
2304 CLASSTYPE_TAGS (current_class_type) = b->level_chain->tags;
2305 }
2306 }
2307 }
2308
2309 return decl;
2310 }
2311
2312 /* Push a tag name NAME for struct/class/union/enum type TYPE.
2313 Normally put it into the inner-most non-tag-transparent scope,
2314 but if GLOBALIZE is true, put it in the inner-most non-class scope.
2315 The latter is needed for implicit declarations. */
2316
2317 void
2318 pushtag (name, type, globalize)
2319 tree name, type;
2320 int globalize;
2321 {
2322 register struct binding_level *b;
2323 tree context = 0;
2324 tree c_decl = 0;
2325
2326 b = inner_binding_level;
2327 while (b->tag_transparent
2328 || (globalize && b->parm_flag == 2))
2329 b = b->level_chain;
2330
2331 if (toplevel_bindings_p ())
2332 b->tags = perm_tree_cons (name, type, b->tags);
2333 else
2334 b->tags = saveable_tree_cons (name, type, b->tags);
2335
2336 if (name)
2337 {
2338 context = type ? TYPE_CONTEXT (type) : NULL_TREE;
2339 if (! context)
2340 {
2341 tree cs = current_scope ();
2342
2343 if (! globalize)
2344 context = cs;
2345 else if (cs != NULL_TREE
2346 && TREE_CODE_CLASS (TREE_CODE (cs)) == 't')
2347 /* When declaring a friend class of a local class, we want
2348 to inject the newly named class into the scope
2349 containing the local class, not the namespace scope. */
2350 context = hack_decl_function_context (get_type_decl (cs));
2351 }
2352 if (context)
2353 c_decl = TREE_CODE (context) == FUNCTION_DECL
2354 ? context : TYPE_MAIN_DECL (context);
2355
2356 if (!context)
2357 context = current_namespace;
2358
2359 /* Do C++ gratuitous typedefing. */
2360 if (IDENTIFIER_TYPE_VALUE (name) != type)
2361 {
2362 register tree d = NULL_TREE;
2363 int newdecl = 0, in_class = 0;
2364
2365 if ((b->pseudo_global && b->level_chain->parm_flag == 2)
2366 || b->parm_flag == 2)
2367 in_class = 1;
2368 else
2369 d = lookup_nested_type (type, c_decl);
2370
2371 if (d == NULL_TREE)
2372 {
2373 newdecl = 1;
2374 d = build_decl (TYPE_DECL, name, type);
2375 if (current_lang_name == lang_name_java)
2376 TYPE_FOR_JAVA (type) = 1;
2377 SET_DECL_ARTIFICIAL (d);
2378 if (! in_class)
2379 set_identifier_type_value_with_scope (name, type, b);
2380 }
2381 else
2382 d = TYPE_MAIN_DECL (d);
2383
2384 TYPE_NAME (type) = d;
2385 DECL_CONTEXT (d) = FROB_CONTEXT (context);
2386
2387 d = maybe_process_template_type_declaration (type,
2388 globalize, b);
2389
2390 if (b->parm_flag == 2)
2391 d = pushdecl_class_level (d);
2392 else
2393 d = pushdecl_with_scope (d, b);
2394
2395 if (newdecl)
2396 {
2397 if (ANON_AGGRNAME_P (name))
2398 DECL_IGNORED_P (d) = 1;
2399
2400 TYPE_CONTEXT (type) = DECL_CONTEXT (d);
2401 DECL_ASSEMBLER_NAME (d) = DECL_NAME (d);
2402 if (!uses_template_parms (type))
2403 DECL_ASSEMBLER_NAME (d)
2404 = get_identifier (build_overload_name (type, 1, 1));
2405 }
2406 }
2407 if (b->parm_flag == 2)
2408 {
2409 TREE_NONLOCAL_FLAG (type) = 1;
2410 if (TYPE_SIZE (current_class_type) == NULL_TREE)
2411 CLASSTYPE_TAGS (current_class_type) = b->tags;
2412 }
2413 }
2414
2415 if (TREE_CODE (TYPE_NAME (type)) == TYPE_DECL)
2416 /* Use the canonical TYPE_DECL for this node. */
2417 TYPE_STUB_DECL (type) = TYPE_NAME (type);
2418 else
2419 {
2420 /* Create a fake NULL-named TYPE_DECL node whose TREE_TYPE
2421 will be the tagged type we just added to the current
2422 binding level. This fake NULL-named TYPE_DECL node helps
2423 dwarfout.c to know when it needs to output a
2424 representation of a tagged type, and it also gives us a
2425 convenient place to record the "scope start" address for
2426 the tagged type. */
2427
2428 tree d = build_decl (TYPE_DECL, NULL_TREE, type);
2429 TYPE_STUB_DECL (type) = pushdecl_with_scope (d, b);
2430 }
2431 }
2432
2433 /* Counter used to create anonymous type names. */
2434
2435 static int anon_cnt = 0;
2436
2437 /* Return an IDENTIFIER which can be used as a name for
2438 anonymous structs and unions. */
2439
2440 tree
2441 make_anon_name ()
2442 {
2443 char buf[32];
2444
2445 sprintf (buf, ANON_AGGRNAME_FORMAT, anon_cnt++);
2446 return get_identifier (buf);
2447 }
2448
2449 /* Clear the TREE_PURPOSE slot of tags which have anonymous typenames.
2450 This keeps dbxout from getting confused. */
2451
2452 void
2453 clear_anon_tags ()
2454 {
2455 register struct binding_level *b;
2456 register tree tags;
2457 static int last_cnt = 0;
2458
2459 /* Fast out if no new anon names were declared. */
2460 if (last_cnt == anon_cnt)
2461 return;
2462
2463 b = current_binding_level;
2464 while (b->tag_transparent)
2465 b = b->level_chain;
2466 tags = b->tags;
2467 while (tags)
2468 {
2469 /* A NULL purpose means we have already processed all tags
2470 from here to the end of the list. */
2471 if (TREE_PURPOSE (tags) == NULL_TREE)
2472 break;
2473 if (ANON_AGGRNAME_P (TREE_PURPOSE (tags)))
2474 TREE_PURPOSE (tags) = NULL_TREE;
2475 tags = TREE_CHAIN (tags);
2476 }
2477 last_cnt = anon_cnt;
2478 }
2479 \f
2480 /* Subroutine of duplicate_decls: return truthvalue of whether
2481 or not types of these decls match.
2482
2483 For C++, we must compare the parameter list so that `int' can match
2484 `int&' in a parameter position, but `int&' is not confused with
2485 `const int&'. */
2486
2487 int
2488 decls_match (newdecl, olddecl)
2489 tree newdecl, olddecl;
2490 {
2491 int types_match;
2492
2493 if (TREE_CODE (newdecl) == FUNCTION_DECL
2494 && TREE_CODE (olddecl) == FUNCTION_DECL)
2495 {
2496 tree f1 = TREE_TYPE (newdecl);
2497 tree f2 = TREE_TYPE (olddecl);
2498 tree p1 = TYPE_ARG_TYPES (f1);
2499 tree p2 = TYPE_ARG_TYPES (f2);
2500
2501 if (DECL_REAL_CONTEXT (newdecl) != DECL_REAL_CONTEXT (olddecl)
2502 && ! (DECL_LANGUAGE (newdecl) == lang_c
2503 && DECL_LANGUAGE (olddecl) == lang_c))
2504 return 0;
2505
2506 /* When we parse a static member function definition,
2507 we put together a FUNCTION_DECL which thinks its type
2508 is METHOD_TYPE. Change that to FUNCTION_TYPE, and
2509 proceed. */
2510 if (TREE_CODE (f1) == METHOD_TYPE && DECL_STATIC_FUNCTION_P (olddecl))
2511 revert_static_member_fn (&newdecl, &f1, &p1);
2512 else if (TREE_CODE (f2) == METHOD_TYPE
2513 && DECL_STATIC_FUNCTION_P (newdecl))
2514 revert_static_member_fn (&olddecl, &f2, &p2);
2515
2516 /* Here we must take care of the case where new default
2517 parameters are specified. Also, warn if an old
2518 declaration becomes ambiguous because default
2519 parameters may cause the two to be ambiguous. */
2520 if (TREE_CODE (f1) != TREE_CODE (f2))
2521 {
2522 if (TREE_CODE (f1) == OFFSET_TYPE)
2523 cp_compiler_error ("`%D' redeclared as member function", newdecl);
2524 else
2525 cp_compiler_error ("`%D' redeclared as non-member function", newdecl);
2526 return 0;
2527 }
2528
2529 if (comptypes (TREE_TYPE (f1), TREE_TYPE (f2), 1))
2530 {
2531 if (! strict_prototypes_lang_c && DECL_LANGUAGE (olddecl) == lang_c
2532 && p2 == NULL_TREE)
2533 {
2534 types_match = self_promoting_args_p (p1);
2535 if (p1 == void_list_node)
2536 TREE_TYPE (newdecl) = TREE_TYPE (olddecl);
2537 }
2538 else if (!strict_prototypes_lang_c && DECL_LANGUAGE (olddecl)==lang_c
2539 && DECL_LANGUAGE (newdecl) == lang_c && p1 == NULL_TREE)
2540 {
2541 types_match = self_promoting_args_p (p2);
2542 TREE_TYPE (newdecl) = TREE_TYPE (olddecl);
2543 }
2544 else
2545 types_match = compparms (p1, p2, 3);
2546 }
2547 else
2548 types_match = 0;
2549 }
2550 else if (TREE_CODE (newdecl) == TEMPLATE_DECL
2551 && TREE_CODE (olddecl) == TEMPLATE_DECL)
2552 {
2553 if (!comp_template_parms (DECL_TEMPLATE_PARMS (newdecl),
2554 DECL_TEMPLATE_PARMS (olddecl)))
2555 return 0;
2556
2557 if (TREE_CODE (DECL_TEMPLATE_RESULT (newdecl)) == TYPE_DECL)
2558 types_match = 1;
2559 else
2560 types_match = decls_match (DECL_TEMPLATE_RESULT (olddecl),
2561 DECL_TEMPLATE_RESULT (newdecl));
2562 }
2563 else
2564 {
2565 if (TREE_TYPE (newdecl) == error_mark_node)
2566 types_match = TREE_TYPE (olddecl) == error_mark_node;
2567 else if (TREE_TYPE (olddecl) == NULL_TREE)
2568 types_match = TREE_TYPE (newdecl) == NULL_TREE;
2569 else if (TREE_TYPE (newdecl) == NULL_TREE)
2570 types_match = 0;
2571 /* Qualifiers must match, and they may be present on either, the type
2572 or the decl. */
2573 else if ((TREE_READONLY (newdecl)
2574 || TYPE_READONLY (TREE_TYPE (newdecl)))
2575 == (TREE_READONLY (olddecl)
2576 || TYPE_READONLY (TREE_TYPE (olddecl)))
2577 && (TREE_THIS_VOLATILE (newdecl)
2578 || TYPE_VOLATILE (TREE_TYPE (newdecl)))
2579 == (TREE_THIS_VOLATILE (olddecl)
2580 || TYPE_VOLATILE (TREE_TYPE (olddecl))))
2581 types_match = comptypes (TYPE_MAIN_VARIANT (TREE_TYPE (newdecl)),
2582 TYPE_MAIN_VARIANT (TREE_TYPE (olddecl)), 1);
2583 else
2584 types_match = 0;
2585 }
2586
2587 return types_match;
2588 }
2589
2590 /* If NEWDECL is `static' and an `extern' was seen previously,
2591 warn about it. (OLDDECL may be NULL_TREE; NAME contains
2592 information about previous usage as an `extern'.)
2593
2594 Note that this does not apply to the C++ case of declaring
2595 a variable `extern const' and then later `const'.
2596
2597 Don't complain about built-in functions, since they are beyond
2598 the user's control. */
2599
2600 static void
2601 warn_extern_redeclared_static (newdecl, olddecl)
2602 tree newdecl, olddecl;
2603 {
2604 tree name;
2605
2606 static char *explicit_extern_static_warning
2607 = "`%D' was declared `extern' and later `static'";
2608 static char *implicit_extern_static_warning
2609 = "`%D' was declared implicitly `extern' and later `static'";
2610
2611 if (TREE_CODE (newdecl) == TYPE_DECL)
2612 return;
2613
2614 name = DECL_ASSEMBLER_NAME (newdecl);
2615 if (TREE_PUBLIC (name) && DECL_THIS_STATIC (newdecl))
2616 {
2617 /* It's okay to redeclare an ANSI built-in function as static,
2618 or to declare a non-ANSI built-in function as anything. */
2619 if (! (TREE_CODE (newdecl) == FUNCTION_DECL
2620 && olddecl != NULL_TREE
2621 && TREE_CODE (olddecl) == FUNCTION_DECL
2622 && (DECL_BUILT_IN (olddecl)
2623 || DECL_BUILT_IN_NONANSI (olddecl))))
2624 {
2625 cp_pedwarn (IDENTIFIER_IMPLICIT_DECL (name)
2626 ? implicit_extern_static_warning
2627 : explicit_extern_static_warning, newdecl);
2628 if (olddecl != NULL_TREE)
2629 cp_pedwarn_at ("previous declaration of `%D'", olddecl);
2630 }
2631 }
2632 }
2633
2634 /* Handle when a new declaration NEWDECL has the same name as an old
2635 one OLDDECL in the same binding contour. Prints an error message
2636 if appropriate.
2637
2638 If safely possible, alter OLDDECL to look like NEWDECL, and return 1.
2639 Otherwise, return 0. */
2640
2641 int
2642 duplicate_decls (newdecl, olddecl)
2643 tree newdecl, olddecl;
2644 {
2645 extern struct obstack permanent_obstack;
2646 unsigned olddecl_uid = DECL_UID (olddecl);
2647 int olddecl_friend = 0, types_match = 0;
2648 int new_defines_function = 0;
2649
2650 if (newdecl == olddecl)
2651 return 1;
2652
2653 types_match = decls_match (newdecl, olddecl);
2654
2655 /* If either the type of the new decl or the type of the old decl is an
2656 error_mark_node, then that implies that we have already issued an
2657 error (earlier) for some bogus type specification, and in that case,
2658 it is rather pointless to harass the user with yet more error message
2659 about the same declaration, so just pretend the types match here. */
2660 if (TREE_TYPE (newdecl) == error_mark_node
2661 || TREE_TYPE (olddecl) == error_mark_node)
2662 types_match = 1;
2663
2664 /* Check for redeclaration and other discrepancies. */
2665 if (TREE_CODE (olddecl) == FUNCTION_DECL
2666 && DECL_ARTIFICIAL (olddecl)
2667 && (DECL_BUILT_IN (olddecl) || DECL_BUILT_IN_NONANSI (olddecl)))
2668 {
2669 /* If you declare a built-in or predefined function name as static,
2670 the old definition is overridden, but optionally warn this was a
2671 bad choice of name. Ditto for overloads. */
2672 if (! TREE_PUBLIC (newdecl)
2673 || (TREE_CODE (newdecl) == FUNCTION_DECL
2674 && DECL_LANGUAGE (newdecl) != DECL_LANGUAGE (olddecl)))
2675 {
2676 if (warn_shadow)
2677 cp_warning ("shadowing %s function `%#D'",
2678 DECL_BUILT_IN (olddecl) ? "built-in" : "library",
2679 olddecl);
2680 /* Discard the old built-in function. */
2681 return 0;
2682 }
2683 else if (! types_match)
2684 {
2685 if (TREE_CODE (newdecl) != FUNCTION_DECL)
2686 {
2687 /* If the built-in is not ansi, then programs can override
2688 it even globally without an error. */
2689 if (! DECL_BUILT_IN (olddecl))
2690 cp_warning ("library function `%#D' redeclared as non-function `%#D'",
2691 olddecl, newdecl);
2692 else
2693 {
2694 cp_error ("declaration of `%#D'", newdecl);
2695 cp_error ("conflicts with built-in declaration `%#D'",
2696 olddecl);
2697 }
2698 return 0;
2699 }
2700
2701 cp_warning ("declaration of `%#D'", newdecl);
2702 cp_warning ("conflicts with built-in declaration `%#D'",
2703 olddecl);
2704 }
2705 }
2706 else if (TREE_CODE (olddecl) != TREE_CODE (newdecl))
2707 {
2708 if ((TREE_CODE (olddecl) == TYPE_DECL && DECL_ARTIFICIAL (olddecl)
2709 && TREE_CODE (newdecl) != TYPE_DECL
2710 && ! (TREE_CODE (newdecl) == TEMPLATE_DECL
2711 && TREE_CODE (DECL_TEMPLATE_RESULT (newdecl)) == TYPE_DECL))
2712 || (TREE_CODE (newdecl) == TYPE_DECL && DECL_ARTIFICIAL (newdecl)
2713 && TREE_CODE (olddecl) != TYPE_DECL
2714 && ! (TREE_CODE (olddecl) == TEMPLATE_DECL
2715 && (TREE_CODE (DECL_TEMPLATE_RESULT (olddecl))
2716 == TYPE_DECL))))
2717 {
2718 /* We do nothing special here, because C++ does such nasty
2719 things with TYPE_DECLs. Instead, just let the TYPE_DECL
2720 get shadowed, and know that if we need to find a TYPE_DECL
2721 for a given name, we can look in the IDENTIFIER_TYPE_VALUE
2722 slot of the identifier. */
2723 return 0;
2724 }
2725
2726 if ((TREE_CODE (newdecl) == FUNCTION_DECL
2727 && DECL_FUNCTION_TEMPLATE_P (olddecl))
2728 || (TREE_CODE (olddecl) == FUNCTION_DECL
2729 && DECL_FUNCTION_TEMPLATE_P (newdecl)))
2730 return 0;
2731
2732 cp_error ("`%#D' redeclared as different kind of symbol", newdecl);
2733 if (TREE_CODE (olddecl) == TREE_LIST)
2734 olddecl = TREE_VALUE (olddecl);
2735 cp_error_at ("previous declaration of `%#D'", olddecl);
2736
2737 /* New decl is completely inconsistent with the old one =>
2738 tell caller to replace the old one. */
2739
2740 return 0;
2741 }
2742 else if (!types_match)
2743 {
2744 if (TREE_CODE (newdecl) == TEMPLATE_DECL)
2745 {
2746 /* The name of a class template may not be declared to refer to
2747 any other template, class, function, object, namespace, value,
2748 or type in the same scope. */
2749 if (TREE_CODE (DECL_TEMPLATE_RESULT (olddecl)) == TYPE_DECL
2750 || TREE_CODE (DECL_TEMPLATE_RESULT (newdecl)) == TYPE_DECL)
2751 {
2752 cp_error ("declaration of template `%#D'", newdecl);
2753 cp_error_at ("conflicts with previous declaration `%#D'",
2754 olddecl);
2755 }
2756 else if (TREE_CODE (DECL_TEMPLATE_RESULT (olddecl)) == FUNCTION_DECL
2757 && TREE_CODE (DECL_TEMPLATE_RESULT (newdecl)) == FUNCTION_DECL
2758 && compparms (TYPE_ARG_TYPES (TREE_TYPE (DECL_TEMPLATE_RESULT (olddecl))),
2759 TYPE_ARG_TYPES (TREE_TYPE (DECL_TEMPLATE_RESULT (newdecl))), 3)
2760 && comp_template_parms (DECL_TEMPLATE_PARMS (newdecl),
2761 DECL_TEMPLATE_PARMS (olddecl)))
2762 {
2763 cp_error ("new declaration `%#D'", newdecl);
2764 cp_error_at ("ambiguates old declaration `%#D'", olddecl);
2765 }
2766 return 0;
2767 }
2768 if (TREE_CODE (newdecl) == FUNCTION_DECL)
2769 {
2770 if (DECL_LANGUAGE (newdecl) == lang_c
2771 && DECL_LANGUAGE (olddecl) == lang_c)
2772 {
2773 cp_error ("declaration of C function `%#D' conflicts with",
2774 newdecl);
2775 cp_error_at ("previous declaration `%#D' here", olddecl);
2776 }
2777 else if (compparms (TYPE_ARG_TYPES (TREE_TYPE (newdecl)),
2778 TYPE_ARG_TYPES (TREE_TYPE (olddecl)), 3))
2779 {
2780 cp_error ("new declaration `%#D'", newdecl);
2781 cp_error_at ("ambiguates old declaration `%#D'", olddecl);
2782 }
2783 else
2784 return 0;
2785 }
2786
2787 /* Already complained about this, so don't do so again. */
2788 else if (current_class_type == NULL_TREE
2789 || IDENTIFIER_ERROR_LOCUS (DECL_ASSEMBLER_NAME (newdecl)) != current_class_type)
2790 {
2791 cp_error ("conflicting types for `%#D'", newdecl);
2792 cp_error_at ("previous declaration as `%#D'", olddecl);
2793 }
2794 }
2795 else if (TREE_CODE (newdecl) == FUNCTION_DECL
2796 && ((DECL_TEMPLATE_SPECIALIZATION (olddecl)
2797 && (!DECL_TEMPLATE_INFO (newdecl)
2798 || (DECL_TI_TEMPLATE (newdecl)
2799 != DECL_TI_TEMPLATE (olddecl))))
2800 || (DECL_TEMPLATE_SPECIALIZATION (newdecl)
2801 && (!DECL_TEMPLATE_INFO (olddecl)
2802 || (DECL_TI_TEMPLATE (olddecl)
2803 != DECL_TI_TEMPLATE (newdecl))))))
2804 /* It's OK to have a template specialization and a non-template
2805 with the same type, or to have specializations of two
2806 different templates with the same type. Note that if one is a
2807 specialization, and the other is an instantiation of the same
2808 template, that we do not exit at this point. That situation
2809 can occur if we instantiate a template class, and then
2810 specialize one of its methods. This situation is legal, but
2811 the declarations must be merged in the usual way. */
2812 return 0;
2813 else if (TREE_CODE (newdecl) == FUNCTION_DECL
2814 && ((DECL_TEMPLATE_INSTANTIATION (olddecl)
2815 && !DECL_USE_TEMPLATE (newdecl))
2816 || (DECL_TEMPLATE_INSTANTIATION (newdecl)
2817 && !DECL_USE_TEMPLATE (olddecl))))
2818 /* One of the declarations is a template instantiation, and the
2819 other is not a template at all. That's OK. */
2820 return 0;
2821 else if (TREE_CODE (newdecl) == NAMESPACE_DECL
2822 && DECL_NAMESPACE_ALIAS (newdecl)
2823 && DECL_NAMESPACE_ALIAS (newdecl) == DECL_NAMESPACE_ALIAS (olddecl))
2824 /* Redeclaration of namespace alias, ignore it. */
2825 return 1;
2826 else
2827 {
2828 char *errmsg = redeclaration_error_message (newdecl, olddecl);
2829 if (errmsg)
2830 {
2831 cp_error (errmsg, newdecl);
2832 if (DECL_NAME (olddecl) != NULL_TREE)
2833 cp_error_at ((DECL_INITIAL (olddecl)
2834 && namespace_bindings_p ())
2835 ? "`%#D' previously defined here"
2836 : "`%#D' previously declared here", olddecl);
2837 }
2838 else if (TREE_CODE (olddecl) == FUNCTION_DECL
2839 && DECL_INITIAL (olddecl) != NULL_TREE
2840 && TYPE_ARG_TYPES (TREE_TYPE (olddecl)) == NULL_TREE
2841 && TYPE_ARG_TYPES (TREE_TYPE (newdecl)) != NULL_TREE)
2842 {
2843 /* Prototype decl follows defn w/o prototype. */
2844 cp_warning_at ("prototype for `%#D'", newdecl);
2845 cp_warning_at ("follows non-prototype definition here", olddecl);
2846 }
2847 else if (TREE_CODE (olddecl) == FUNCTION_DECL
2848 && DECL_LANGUAGE (newdecl) != DECL_LANGUAGE (olddecl))
2849 {
2850 /* extern "C" int foo ();
2851 int foo () { bar (); }
2852 is OK. */
2853 if (current_lang_stack == current_lang_base)
2854 DECL_LANGUAGE (newdecl) = DECL_LANGUAGE (olddecl);
2855 else
2856 {
2857 cp_error_at ("previous declaration of `%#D' with %L linkage",
2858 olddecl, DECL_LANGUAGE (olddecl));
2859 cp_error ("conflicts with new declaration with %L linkage",
2860 DECL_LANGUAGE (newdecl));
2861 }
2862 }
2863
2864 if (DECL_LANG_SPECIFIC (olddecl) && DECL_USE_TEMPLATE (olddecl))
2865 ;
2866 else if (TREE_CODE (olddecl) == FUNCTION_DECL)
2867 {
2868 tree t1 = TYPE_ARG_TYPES (TREE_TYPE (olddecl));
2869 tree t2 = TYPE_ARG_TYPES (TREE_TYPE (newdecl));
2870 int i = 1;
2871
2872 if (TREE_CODE (TREE_TYPE (newdecl)) == METHOD_TYPE)
2873 t1 = TREE_CHAIN (t1), t2 = TREE_CHAIN (t2);
2874
2875 for (; t1 && t1 != void_list_node;
2876 t1 = TREE_CHAIN (t1), t2 = TREE_CHAIN (t2), i++)
2877 if (TREE_PURPOSE (t1) && TREE_PURPOSE (t2))
2878 {
2879 if (1 == simple_cst_equal (TREE_PURPOSE (t1),
2880 TREE_PURPOSE (t2)))
2881 {
2882 if (pedantic)
2883 {
2884 cp_pedwarn ("default argument given for parameter %d of `%#D'",
2885 i, newdecl);
2886 cp_pedwarn_at ("after previous specification in `%#D'",
2887 olddecl);
2888 }
2889 }
2890 else
2891 {
2892 cp_error ("default argument given for parameter %d of `%#D'",
2893 i, newdecl);
2894 cp_error_at ("after previous specification in `%#D'",
2895 olddecl);
2896 }
2897 }
2898
2899 if (DECL_THIS_INLINE (newdecl) && ! DECL_THIS_INLINE (olddecl)
2900 && TREE_ADDRESSABLE (olddecl) && warn_inline)
2901 {
2902 cp_warning ("`%#D' was used before it was declared inline",
2903 newdecl);
2904 cp_warning_at ("previous non-inline declaration here",
2905 olddecl);
2906 }
2907 }
2908 /* These bits are logically part of the type for non-functions. */
2909 else if (TREE_READONLY (newdecl) != TREE_READONLY (olddecl)
2910 || TREE_THIS_VOLATILE (newdecl) != TREE_THIS_VOLATILE (olddecl))
2911 {
2912 cp_pedwarn ("type qualifiers for `%#D'", newdecl);
2913 cp_pedwarn_at ("conflict with previous decl `%#D'", olddecl);
2914 }
2915 }
2916
2917 /* If new decl is `static' and an `extern' was seen previously,
2918 warn about it. */
2919 warn_extern_redeclared_static (newdecl, olddecl);
2920
2921 /* We have committed to returning 1 at this point. */
2922 if (TREE_CODE (newdecl) == FUNCTION_DECL)
2923 {
2924 /* Now that functions must hold information normally held
2925 by field decls, there is extra work to do so that
2926 declaration information does not get destroyed during
2927 definition. */
2928 if (DECL_VINDEX (olddecl))
2929 DECL_VINDEX (newdecl) = DECL_VINDEX (olddecl);
2930 if (DECL_CONTEXT (olddecl))
2931 DECL_CONTEXT (newdecl) = DECL_CONTEXT (olddecl);
2932 if (DECL_CLASS_CONTEXT (olddecl))
2933 DECL_CLASS_CONTEXT (newdecl) = DECL_CLASS_CONTEXT (olddecl);
2934 if (DECL_PENDING_INLINE_INFO (newdecl) == (struct pending_inline *)0)
2935 DECL_PENDING_INLINE_INFO (newdecl) = DECL_PENDING_INLINE_INFO (olddecl);
2936 DECL_STATIC_CONSTRUCTOR (newdecl) |= DECL_STATIC_CONSTRUCTOR (olddecl);
2937 DECL_STATIC_DESTRUCTOR (newdecl) |= DECL_STATIC_DESTRUCTOR (olddecl);
2938 DECL_ABSTRACT_VIRTUAL_P (newdecl) |= DECL_ABSTRACT_VIRTUAL_P (olddecl);
2939 DECL_VIRTUAL_P (newdecl) |= DECL_VIRTUAL_P (olddecl);
2940 DECL_NEEDS_FINAL_OVERRIDER_P (newdecl) |= DECL_NEEDS_FINAL_OVERRIDER_P (olddecl);
2941 new_defines_function = DECL_INITIAL (newdecl) != NULL_TREE;
2942
2943 /* Optionally warn about more than one declaration for the same
2944 name, but don't warn about a function declaration followed by a
2945 definition. */
2946 if (warn_redundant_decls && ! DECL_ARTIFICIAL (olddecl)
2947 && !(new_defines_function && DECL_INITIAL (olddecl) == NULL_TREE)
2948 /* Don't warn about extern decl followed by definition. */
2949 && !(DECL_EXTERNAL (olddecl) && ! DECL_EXTERNAL (newdecl))
2950 /* Don't warn about friends, let add_friend take care of it. */
2951 && ! DECL_FRIEND_P (newdecl))
2952 {
2953 cp_warning ("redundant redeclaration of `%D' in same scope", newdecl);
2954 cp_warning_at ("previous declaration of `%D'", olddecl);
2955 }
2956 }
2957
2958 /* Deal with C++: must preserve virtual function table size. */
2959 if (TREE_CODE (olddecl) == TYPE_DECL)
2960 {
2961 register tree newtype = TREE_TYPE (newdecl);
2962 register tree oldtype = TREE_TYPE (olddecl);
2963
2964 if (newtype != error_mark_node && oldtype != error_mark_node
2965 && TYPE_LANG_SPECIFIC (newtype) && TYPE_LANG_SPECIFIC (oldtype))
2966 {
2967 CLASSTYPE_VSIZE (newtype) = CLASSTYPE_VSIZE (oldtype);
2968 CLASSTYPE_FRIEND_CLASSES (newtype)
2969 = CLASSTYPE_FRIEND_CLASSES (oldtype);
2970 }
2971 }
2972
2973 /* Copy all the DECL_... slots specified in the new decl
2974 except for any that we copy here from the old type. */
2975 DECL_MACHINE_ATTRIBUTES (newdecl)
2976 = merge_machine_decl_attributes (olddecl, newdecl);
2977
2978 if (TREE_CODE (newdecl) == TEMPLATE_DECL)
2979 {
2980 if (! duplicate_decls (DECL_TEMPLATE_RESULT (newdecl),
2981 DECL_TEMPLATE_RESULT (olddecl)))
2982 cp_error ("invalid redeclaration of %D", newdecl);
2983 TREE_TYPE (olddecl) = TREE_TYPE (DECL_TEMPLATE_RESULT (olddecl));
2984 DECL_TEMPLATE_PARMS (olddecl) = DECL_TEMPLATE_PARMS (newdecl);
2985 if (DECL_TEMPLATE_INFO (newdecl))
2986 DECL_TEMPLATE_INFO (olddecl) = DECL_TEMPLATE_INFO (newdecl);
2987 DECL_TEMPLATE_SPECIALIZATIONS (olddecl)
2988 = chainon (DECL_TEMPLATE_SPECIALIZATIONS (olddecl),
2989 DECL_TEMPLATE_SPECIALIZATIONS (newdecl));
2990
2991 return 1;
2992 }
2993
2994 if (types_match)
2995 {
2996 /* Automatically handles default parameters. */
2997 tree oldtype = TREE_TYPE (olddecl);
2998 tree newtype;
2999
3000 /* Make sure we put the new type in the same obstack as the old one. */
3001 if (oldtype)
3002 push_obstacks (TYPE_OBSTACK (oldtype), TYPE_OBSTACK (oldtype));
3003 else
3004 {
3005 push_obstacks_nochange ();
3006 end_temporary_allocation ();
3007 }
3008
3009 /* Merge the data types specified in the two decls. */
3010 newtype = common_type (TREE_TYPE (newdecl), TREE_TYPE (olddecl));
3011
3012 if (TREE_CODE (newdecl) == VAR_DECL)
3013 DECL_THIS_EXTERN (newdecl) |= DECL_THIS_EXTERN (olddecl);
3014 /* Do this after calling `common_type' so that default
3015 parameters don't confuse us. */
3016 else if (TREE_CODE (newdecl) == FUNCTION_DECL
3017 && (TYPE_RAISES_EXCEPTIONS (TREE_TYPE (newdecl))
3018 != TYPE_RAISES_EXCEPTIONS (TREE_TYPE (olddecl))))
3019 {
3020 TREE_TYPE (newdecl) = build_exception_variant (newtype,
3021 TYPE_RAISES_EXCEPTIONS (TREE_TYPE (newdecl)));
3022 TREE_TYPE (olddecl) = build_exception_variant (newtype,
3023 TYPE_RAISES_EXCEPTIONS (oldtype));
3024
3025 if ((pedantic || ! DECL_IN_SYSTEM_HEADER (olddecl))
3026 && DECL_SOURCE_LINE (olddecl) != 0
3027 && flag_exceptions
3028 && ! compexcepttypes (TREE_TYPE (newdecl), TREE_TYPE (olddecl)))
3029 {
3030 cp_pedwarn ("declaration of `%D' throws different exceptions",
3031 newdecl);
3032 cp_pedwarn_at ("previous declaration here", olddecl);
3033 }
3034 }
3035 TREE_TYPE (newdecl) = TREE_TYPE (olddecl) = newtype;
3036
3037 /* Lay the type out, unless already done. */
3038 if (newtype != canonical_type_variant (oldtype)
3039 && TREE_TYPE (newdecl) != error_mark_node
3040 && !(processing_template_decl && uses_template_parms (newdecl)))
3041 layout_type (TREE_TYPE (newdecl));
3042
3043 if ((TREE_CODE (newdecl) == VAR_DECL
3044 || TREE_CODE (newdecl) == PARM_DECL
3045 || TREE_CODE (newdecl) == RESULT_DECL
3046 || TREE_CODE (newdecl) == FIELD_DECL
3047 || TREE_CODE (newdecl) == TYPE_DECL)
3048 && !(processing_template_decl && uses_template_parms (newdecl)))
3049 layout_decl (newdecl, 0);
3050
3051 /* Merge the type qualifiers. */
3052 if (TREE_READONLY (newdecl))
3053 TREE_READONLY (olddecl) = 1;
3054 if (TREE_THIS_VOLATILE (newdecl))
3055 TREE_THIS_VOLATILE (olddecl) = 1;
3056
3057 /* Merge the initialization information. */
3058 if (DECL_INITIAL (newdecl) == NULL_TREE
3059 && DECL_INITIAL (olddecl) != NULL_TREE)
3060 {
3061 DECL_INITIAL (newdecl) = DECL_INITIAL (olddecl);
3062 DECL_SOURCE_FILE (newdecl) = DECL_SOURCE_FILE (olddecl);
3063 DECL_SOURCE_LINE (newdecl) = DECL_SOURCE_LINE (olddecl);
3064 if (DECL_LANG_SPECIFIC (newdecl)
3065 && DECL_LANG_SPECIFIC (olddecl))
3066 DECL_SAVED_TREE (newdecl) = DECL_SAVED_TREE (olddecl);
3067 }
3068
3069 /* Merge the section attribute.
3070 We want to issue an error if the sections conflict but that must be
3071 done later in decl_attributes since we are called before attributes
3072 are assigned. */
3073 if (DECL_SECTION_NAME (newdecl) == NULL_TREE)
3074 DECL_SECTION_NAME (newdecl) = DECL_SECTION_NAME (olddecl);
3075
3076 /* Keep the old rtl since we can safely use it, unless it's the
3077 call to abort() used for abstract virtuals. */
3078 if ((DECL_LANG_SPECIFIC (olddecl)
3079 && !DECL_ABSTRACT_VIRTUAL_P (olddecl))
3080 || DECL_RTL (olddecl) != DECL_RTL (abort_fndecl))
3081 DECL_RTL (newdecl) = DECL_RTL (olddecl);
3082
3083 pop_obstacks ();
3084 }
3085 /* If cannot merge, then use the new type and qualifiers,
3086 and don't preserve the old rtl. */
3087 else
3088 {
3089 /* Clean out any memory we had of the old declaration. */
3090 tree oldstatic = value_member (olddecl, static_aggregates);
3091 if (oldstatic)
3092 TREE_VALUE (oldstatic) = error_mark_node;
3093
3094 TREE_TYPE (olddecl) = TREE_TYPE (newdecl);
3095 TREE_READONLY (olddecl) = TREE_READONLY (newdecl);
3096 TREE_THIS_VOLATILE (olddecl) = TREE_THIS_VOLATILE (newdecl);
3097 TREE_SIDE_EFFECTS (olddecl) = TREE_SIDE_EFFECTS (newdecl);
3098 }
3099
3100 /* Merge the storage class information. */
3101 DECL_WEAK (newdecl) |= DECL_WEAK (olddecl);
3102 DECL_ONE_ONLY (newdecl) |= DECL_ONE_ONLY (olddecl);
3103 TREE_PUBLIC (newdecl) = TREE_PUBLIC (olddecl);
3104 TREE_STATIC (olddecl) = TREE_STATIC (newdecl) |= TREE_STATIC (olddecl);
3105 if (! DECL_EXTERNAL (olddecl))
3106 DECL_EXTERNAL (newdecl) = 0;
3107
3108 if (DECL_LANG_SPECIFIC (newdecl) && DECL_LANG_SPECIFIC (olddecl))
3109 {
3110 DECL_INTERFACE_KNOWN (newdecl) |= DECL_INTERFACE_KNOWN (olddecl);
3111 DECL_NOT_REALLY_EXTERN (newdecl) |= DECL_NOT_REALLY_EXTERN (olddecl);
3112 DECL_COMDAT (newdecl) |= DECL_COMDAT (olddecl);
3113 /* Don't really know how much of the language-specific
3114 values we should copy from old to new. */
3115 DECL_IN_AGGR_P (newdecl) = DECL_IN_AGGR_P (olddecl);
3116 DECL_ACCESS (newdecl) = DECL_ACCESS (olddecl);
3117 DECL_NONCONVERTING_P (newdecl) = DECL_NONCONVERTING_P (olddecl);
3118 if (DECL_TEMPLATE_INFO (newdecl) == NULL_TREE)
3119 {
3120 DECL_TEMPLATE_INFO (newdecl) = DECL_TEMPLATE_INFO (olddecl);
3121 DECL_USE_TEMPLATE (newdecl) = DECL_USE_TEMPLATE (olddecl);
3122 }
3123 olddecl_friend = DECL_FRIEND_P (olddecl);
3124 }
3125
3126 if (TREE_CODE (newdecl) == FUNCTION_DECL)
3127 {
3128 if (DECL_TEMPLATE_INSTANTIATION (olddecl)
3129 && !DECL_TEMPLATE_INSTANTIATION (newdecl))
3130 {
3131 /* If newdecl is not a specialization, then it is not a
3132 template-related function at all. And that means that we
3133 shoud have exited above, returning 0. */
3134 my_friendly_assert (DECL_TEMPLATE_SPECIALIZATION (newdecl),
3135 0);
3136
3137 if (TREE_USED (olddecl))
3138 /* From [temp.expl.spec]:
3139
3140 If a template, a member template or the member of a class
3141 template is explicitly specialized then that
3142 specialization shall be declared before the first use of
3143 that specialization that would cause an implicit
3144 instantiation to take place, in every translation unit in
3145 which such a use occurs. */
3146 cp_error ("explicit specialization of %D after first use",
3147 olddecl);
3148
3149 SET_DECL_TEMPLATE_SPECIALIZATION (olddecl);
3150 }
3151 DECL_THIS_INLINE (newdecl) |= DECL_THIS_INLINE (olddecl);
3152
3153 /* If either decl says `inline', this fn is inline, unless its
3154 definition was passed already. */
3155 if (DECL_INLINE (newdecl) && DECL_INITIAL (olddecl) == NULL_TREE)
3156 DECL_INLINE (olddecl) = 1;
3157 DECL_INLINE (newdecl) = DECL_INLINE (olddecl);
3158
3159 if (! types_match)
3160 {
3161 DECL_LANGUAGE (olddecl) = DECL_LANGUAGE (newdecl);
3162 DECL_ASSEMBLER_NAME (olddecl) = DECL_ASSEMBLER_NAME (newdecl);
3163 DECL_RTL (olddecl) = DECL_RTL (newdecl);
3164 }
3165 if (! types_match || new_defines_function)
3166 {
3167 /* These need to be copied so that the names are available. */
3168 DECL_ARGUMENTS (olddecl) = DECL_ARGUMENTS (newdecl);
3169 DECL_RESULT (olddecl) = DECL_RESULT (newdecl);
3170 }
3171 if (new_defines_function)
3172 /* If defining a function declared with other language
3173 linkage, use the previously declared language linkage. */
3174 DECL_LANGUAGE (newdecl) = DECL_LANGUAGE (olddecl);
3175 else
3176 {
3177 /* If redeclaring a builtin function, and not a definition,
3178 it stays built in. */
3179 if (DECL_BUILT_IN (olddecl))
3180 {
3181 DECL_BUILT_IN (newdecl) = 1;
3182 DECL_FUNCTION_CODE (newdecl) = DECL_FUNCTION_CODE (olddecl);
3183 /* If we're keeping the built-in definition, keep the rtl,
3184 regardless of declaration matches. */
3185 DECL_RTL (newdecl) = DECL_RTL (olddecl);
3186 }
3187 else
3188 DECL_FRAME_SIZE (newdecl) = DECL_FRAME_SIZE (olddecl);
3189
3190 DECL_RESULT (newdecl) = DECL_RESULT (olddecl);
3191 if ((DECL_SAVED_INSNS (newdecl) = DECL_SAVED_INSNS (olddecl)))
3192 /* Previously saved insns go together with
3193 the function's previous definition. */
3194 DECL_INITIAL (newdecl) = DECL_INITIAL (olddecl);
3195 /* Don't clear out the arguments if we're redefining a function. */
3196 if (DECL_ARGUMENTS (olddecl))
3197 DECL_ARGUMENTS (newdecl) = DECL_ARGUMENTS (olddecl);
3198 }
3199 if (DECL_LANG_SPECIFIC (olddecl))
3200 DECL_MAIN_VARIANT (newdecl) = DECL_MAIN_VARIANT (olddecl);
3201 }
3202
3203 if (TREE_CODE (newdecl) == NAMESPACE_DECL)
3204 {
3205 NAMESPACE_LEVEL (newdecl) = NAMESPACE_LEVEL (olddecl);
3206 }
3207
3208 /* Now preserve various other info from the definition. */
3209 TREE_ADDRESSABLE (newdecl) = TREE_ADDRESSABLE (olddecl);
3210 TREE_ASM_WRITTEN (newdecl) = TREE_ASM_WRITTEN (olddecl);
3211 DECL_COMMON (newdecl) = DECL_COMMON (olddecl);
3212 DECL_ASSEMBLER_NAME (newdecl) = DECL_ASSEMBLER_NAME (olddecl);
3213
3214 if (TREE_CODE (newdecl) == FUNCTION_DECL)
3215 {
3216 int function_size;
3217 struct lang_decl *ol = DECL_LANG_SPECIFIC (olddecl);
3218 struct lang_decl *nl = DECL_LANG_SPECIFIC (newdecl);
3219
3220 function_size = sizeof (struct tree_decl);
3221
3222 bcopy ((char *) newdecl + sizeof (struct tree_common),
3223 (char *) olddecl + sizeof (struct tree_common),
3224 function_size - sizeof (struct tree_common));
3225
3226 /* Can we safely free the storage used by newdecl? */
3227
3228 #define ROUND(x) ((x + obstack_alignment_mask (&permanent_obstack)) \
3229 & ~ obstack_alignment_mask (&permanent_obstack))
3230
3231 if (DECL_TEMPLATE_INSTANTIATION (newdecl))
3232 {
3233 /* If newdecl is a template instantiation, it is possible that
3234 the following sequence of events has occurred:
3235
3236 o A friend function was declared in a class template. The
3237 class template was instantiated.
3238
3239 o The instantiation of the friend declaration was
3240 recorded on the instantiation list, and is newdecl.
3241
3242 o Later, however, instantiate_class_template called pushdecl
3243 on the newdecl to perform name injection. But, pushdecl in
3244 turn called duplicate_decls when it discovered that another
3245 declaration of a global function with the same name already
3246 existed.
3247
3248 o Here, in duplicate_decls, we decided to clobber newdecl.
3249
3250 If we're going to do that, we'd better make sure that
3251 olddecl, and not newdecl, is on the list of
3252 instantiations so that if we try to do the instantiation
3253 again we won't get the clobbered declaration. */
3254
3255 tree tmpl = DECL_TI_TEMPLATE (newdecl);
3256 tree decls = DECL_TEMPLATE_SPECIALIZATIONS (tmpl);
3257
3258 for (; decls; decls = TREE_CHAIN (decls))
3259 if (TREE_VALUE (decls) == newdecl)
3260 TREE_VALUE (decls) = olddecl;
3261 }
3262
3263 if (((char *)newdecl + ROUND (function_size) == (char *)nl
3264 && ((char *)newdecl + ROUND (function_size)
3265 + ROUND (sizeof (struct lang_decl))
3266 == obstack_next_free (&permanent_obstack)))
3267 || ((char *)newdecl + ROUND (function_size)
3268 == obstack_next_free (&permanent_obstack)))
3269 {
3270 DECL_MAIN_VARIANT (newdecl) = olddecl;
3271 DECL_LANG_SPECIFIC (olddecl) = ol;
3272 bcopy ((char *)nl, (char *)ol, sizeof (struct lang_decl));
3273
3274 obstack_free (&permanent_obstack, newdecl);
3275 }
3276 else if (LANG_DECL_PERMANENT (ol) && ol != nl)
3277 {
3278 if (DECL_MAIN_VARIANT (olddecl) == olddecl)
3279 {
3280 /* Save these lang_decls that would otherwise be lost. */
3281 extern tree free_lang_decl_chain;
3282 tree free_lang_decl = (tree) ol;
3283
3284 if (DECL_LANG_SPECIFIC (olddecl) == ol)
3285 abort ();
3286
3287 TREE_CHAIN (free_lang_decl) = free_lang_decl_chain;
3288 free_lang_decl_chain = free_lang_decl;
3289 }
3290 else
3291 {
3292 /* Storage leak. */;
3293 }
3294 }
3295 }
3296 else
3297 {
3298 bcopy ((char *) newdecl + sizeof (struct tree_common),
3299 (char *) olddecl + sizeof (struct tree_common),
3300 sizeof (struct tree_decl) - sizeof (struct tree_common)
3301 + tree_code_length [(int)TREE_CODE (newdecl)] * sizeof (char *));
3302 }
3303
3304 DECL_UID (olddecl) = olddecl_uid;
3305 if (olddecl_friend)
3306 DECL_FRIEND_P (olddecl) = 1;
3307
3308 /* NEWDECL contains the merged attribute lists.
3309 Update OLDDECL to be the same. */
3310 DECL_MACHINE_ATTRIBUTES (olddecl) = DECL_MACHINE_ATTRIBUTES (newdecl);
3311
3312 return 1;
3313 }
3314
3315 /* Record a decl-node X as belonging to the current lexical scope.
3316 Check for errors (such as an incompatible declaration for the same
3317 name already seen in the same scope).
3318
3319 Returns either X or an old decl for the same name.
3320 If an old decl is returned, it may have been smashed
3321 to agree with what X says. */
3322
3323 tree
3324 pushdecl (x)
3325 tree x;
3326 {
3327 register tree t;
3328 register tree name = DECL_ASSEMBLER_NAME (x);
3329 register struct binding_level *b = current_binding_level;
3330
3331 if (current_function_decl && x != current_function_decl
3332 /* A local declaration for a function doesn't constitute nesting. */
3333 && (TREE_CODE (x) != FUNCTION_DECL || DECL_INITIAL (x))
3334 /* Don't change DECL_CONTEXT of virtual methods. */
3335 && (TREE_CODE (x) != FUNCTION_DECL || !DECL_VIRTUAL_P (x))
3336 && ! DECL_CONTEXT (x))
3337 DECL_CONTEXT (x) = current_function_decl;
3338 if (!DECL_CONTEXT (x))
3339 DECL_CONTEXT (x) = FROB_CONTEXT (current_namespace);
3340
3341 /* Type are looked up using the DECL_NAME, as that is what the rest of the
3342 compiler wants to use. */
3343 if (TREE_CODE (x) == TYPE_DECL || TREE_CODE (x) == VAR_DECL
3344 || TREE_CODE (x) == NAMESPACE_DECL || TREE_CODE (x) == TEMPLATE_TYPE_PARM
3345 || TREE_CODE (x) == TEMPLATE_TEMPLATE_PARM)
3346 name = DECL_NAME (x);
3347
3348 if (name)
3349 {
3350 #if 0
3351 /* Not needed...see below. */
3352 char *file;
3353 int line;
3354 #endif
3355 if (TREE_CODE (name) == TEMPLATE_ID_EXPR)
3356 name = TREE_OPERAND (name, 0);
3357
3358 /* Namespace-scoped variables are not found in the current level. */
3359 if (TREE_CODE (x) == VAR_DECL && DECL_NAMESPACE_SCOPE_P (x))
3360 t = namespace_binding (name, DECL_CONTEXT (x));
3361 else
3362 t = lookup_name_current_level (name);
3363 if (t == error_mark_node)
3364 {
3365 /* error_mark_node is 0 for a while during initialization! */
3366 t = NULL_TREE;
3367 cp_error_at ("`%#D' used prior to declaration", x);
3368 }
3369
3370 else if (t != NULL_TREE)
3371 {
3372 #if 0
3373 /* This is turned off until I have time to do it right (bpk). */
3374 /* With the code below that uses it... */
3375 file = DECL_SOURCE_FILE (t);
3376 line = DECL_SOURCE_LINE (t);
3377 #endif
3378 if (TREE_CODE (t) == PARM_DECL)
3379 {
3380 if (DECL_CONTEXT (t) == NULL_TREE)
3381 fatal ("parse errors have confused me too much");
3382
3383 /* Check for duplicate params. */
3384 if (duplicate_decls (x, t))
3385 return t;
3386 }
3387 else if (((TREE_CODE (x) == FUNCTION_DECL && DECL_LANGUAGE (x) == lang_c)
3388 || DECL_FUNCTION_TEMPLATE_P (x))
3389 && is_overloaded_fn (t))
3390 /* Don't do anything just yet. */;
3391 else if (t == wchar_decl_node)
3392 {
3393 if (pedantic && ! DECL_IN_SYSTEM_HEADER (x))
3394 cp_pedwarn ("redeclaration of wchar_t as `%T'", TREE_TYPE (x));
3395
3396 /* Throw away the redeclaration. */
3397 return t;
3398 }
3399 else if (TREE_CODE (t) != TREE_CODE (x))
3400 {
3401 if (duplicate_decls (x, t))
3402 return t;
3403 }
3404 else if (duplicate_decls (x, t))
3405 {
3406 #if 0
3407 /* This is turned off until I have time to do it right (bpk). */
3408
3409 /* Also warn if they did a prototype with `static' on it, but
3410 then later left the `static' off. */
3411 if (! TREE_PUBLIC (name) && TREE_PUBLIC (x))
3412 {
3413 if (DECL_LANG_SPECIFIC (t) && DECL_FRIEND_P (t))
3414 return t;
3415
3416 if (extra_warnings)
3417 {
3418 cp_warning ("`static' missing from declaration of `%D'",
3419 t);
3420 warning_with_file_and_line (file, line,
3421 "previous declaration of `%s'",
3422 decl_as_string (t, 0));
3423 }
3424
3425 /* Now fix things so it'll do what they expect. */
3426 if (current_function_decl)
3427 TREE_PUBLIC (current_function_decl) = 0;
3428 }
3429 /* Due to interference in memory reclamation (X may be
3430 obstack-deallocated at this point), we must guard against
3431 one really special case. [jason: This should be handled
3432 by start_function] */
3433 if (current_function_decl == x)
3434 current_function_decl = t;
3435 #endif
3436 if (TREE_CODE (t) == TYPE_DECL)
3437 SET_IDENTIFIER_TYPE_VALUE (name, TREE_TYPE (t));
3438 else if (TREE_CODE (t) == FUNCTION_DECL)
3439 check_default_args (t);
3440
3441 return t;
3442 }
3443 else if (DECL_MAIN_P (x))
3444 {
3445 /* A redeclaration of main, but not a duplicate of the
3446 previous one.
3447
3448 [basic.start.main]
3449
3450 This function shall not be overloaded. */
3451 cp_error_at ("invalid redeclaration of `%D'", t);
3452 cp_error ("as `%D'", x);
3453 /* We don't try to push this declaration since that
3454 causes a crash. */
3455 return x;
3456 }
3457 }
3458
3459 if (TREE_CODE (x) == FUNCTION_DECL && ! DECL_FUNCTION_MEMBER_P (x))
3460 {
3461 t = push_overloaded_decl (x, 1);
3462 if (t != x || DECL_LANGUAGE (x) == lang_c)
3463 return t;
3464 }
3465 else if (DECL_FUNCTION_TEMPLATE_P (x) && DECL_NAMESPACE_SCOPE_P (x))
3466 return push_overloaded_decl (x, 0);
3467
3468 /* If declaring a type as a typedef, copy the type (unless we're
3469 at line 0), and install this TYPE_DECL as the new type's typedef
3470 name. See the extensive comment in ../c-decl.c (pushdecl). */
3471 if (TREE_CODE (x) == TYPE_DECL)
3472 {
3473 tree type = TREE_TYPE (x);
3474 if (DECL_SOURCE_LINE (x) == 0)
3475 {
3476 if (TYPE_NAME (type) == 0)
3477 TYPE_NAME (type) = x;
3478 }
3479 else if (type != error_mark_node && TYPE_NAME (type) != x)
3480 {
3481 push_obstacks (TYPE_OBSTACK (type), TYPE_OBSTACK (type));
3482
3483 DECL_ORIGINAL_TYPE (x) = type;
3484 type = build_type_copy (type);
3485 TYPE_STUB_DECL (type) = TYPE_STUB_DECL (DECL_ORIGINAL_TYPE (x));
3486 TYPE_NAME (type) = x;
3487 TREE_TYPE (x) = type;
3488
3489 pop_obstacks ();
3490 }
3491
3492 if (type != error_mark_node
3493 && TYPE_NAME (type)
3494 && TYPE_IDENTIFIER (type))
3495 set_identifier_type_value_with_scope (DECL_NAME (x), type, b);
3496 }
3497
3498 /* Multiple external decls of the same identifier ought to match.
3499
3500 We get warnings about inline functions where they are defined.
3501 We get warnings about other functions from push_overloaded_decl.
3502
3503 Avoid duplicate warnings where they are used. */
3504 if (TREE_PUBLIC (x) && TREE_CODE (x) != FUNCTION_DECL)
3505 {
3506 tree decl;
3507
3508 if (IDENTIFIER_NAMESPACE_VALUE (name) != NULL_TREE
3509 && (DECL_EXTERNAL (IDENTIFIER_NAMESPACE_VALUE (name))
3510 || TREE_PUBLIC (IDENTIFIER_NAMESPACE_VALUE (name))))
3511 decl = IDENTIFIER_NAMESPACE_VALUE (name);
3512 else
3513 decl = NULL_TREE;
3514
3515 if (decl
3516 /* If different sort of thing, we already gave an error. */
3517 && TREE_CODE (decl) == TREE_CODE (x)
3518 && ! comptypes (TREE_TYPE (x), TREE_TYPE (decl), 1))
3519 {
3520 cp_pedwarn ("type mismatch with previous external decl", x);
3521 cp_pedwarn_at ("previous external decl of `%#D'", decl);
3522 }
3523 }
3524
3525 /* This name is new in its binding level.
3526 Install the new declaration and return it. */
3527 if (namespace_bindings_p ())
3528 {
3529 /* Install a global value. */
3530
3531 /* If the first global decl has external linkage,
3532 warn if we later see static one. */
3533 if (IDENTIFIER_GLOBAL_VALUE (name) == NULL_TREE && TREE_PUBLIC (x))
3534 TREE_PUBLIC (name) = 1;
3535
3536 /* Don't install an artificial TYPE_DECL if we already have
3537 another _DECL with that name. */
3538 if (TREE_CODE (x) != TYPE_DECL
3539 || t == NULL_TREE
3540 || ! DECL_ARTIFICIAL (x))
3541 {
3542 if (TREE_CODE (x) == FUNCTION_DECL)
3543 my_friendly_assert
3544 ((IDENTIFIER_GLOBAL_VALUE (name) == NULL_TREE)
3545 || (IDENTIFIER_GLOBAL_VALUE (name) == x), 378);
3546 SET_IDENTIFIER_NAMESPACE_VALUE (name, x);
3547 }
3548
3549 /* Don't forget if the function was used via an implicit decl. */
3550 if (IDENTIFIER_IMPLICIT_DECL (name)
3551 && TREE_USED (IDENTIFIER_IMPLICIT_DECL (name)))
3552 TREE_USED (x) = 1;
3553
3554 /* Don't forget if its address was taken in that way. */
3555 if (IDENTIFIER_IMPLICIT_DECL (name)
3556 && TREE_ADDRESSABLE (IDENTIFIER_IMPLICIT_DECL (name)))
3557 TREE_ADDRESSABLE (x) = 1;
3558
3559 /* Warn about mismatches against previous implicit decl. */
3560 if (IDENTIFIER_IMPLICIT_DECL (name) != NULL_TREE
3561 /* If this real decl matches the implicit, don't complain. */
3562 && ! (TREE_CODE (x) == FUNCTION_DECL
3563 && TREE_TYPE (TREE_TYPE (x)) == integer_type_node))
3564 cp_warning
3565 ("`%D' was previously implicitly declared to return `int'", x);
3566
3567 /* If new decl is `static' and an `extern' was seen previously,
3568 warn about it. */
3569 if (x != NULL_TREE && t != NULL_TREE && decls_match (x, t))
3570 warn_extern_redeclared_static (x, t);
3571 }
3572 else
3573 {
3574 /* Here to install a non-global value. */
3575 tree oldlocal = IDENTIFIER_LOCAL_VALUE (name);
3576 tree oldglobal = IDENTIFIER_NAMESPACE_VALUE (name);
3577
3578 /* Don't install an artificial TYPE_DECL if we already have
3579 another _DECL with that name. */
3580 if (TREE_CODE (x) != TYPE_DECL
3581 || t == NULL_TREE
3582 || ! DECL_ARTIFICIAL (x))
3583 set_identifier_local_value_with_scope (name, x, b);
3584
3585 /* If this is a TYPE_DECL, push it into the type value slot. */
3586 if (TREE_CODE (x) == TYPE_DECL)
3587 set_identifier_type_value_with_scope (name, TREE_TYPE (x), b);
3588
3589 /* Clear out any TYPE_DECL shadowed by a namespace so that
3590 we won't think this is a type. The C struct hack doesn't
3591 go through namespaces. */
3592 if (TREE_CODE (x) == NAMESPACE_DECL)
3593 set_identifier_type_value_with_scope (name, NULL_TREE, b);
3594
3595 /* If this is an extern function declaration, see if we
3596 have a global definition or declaration for the function. */
3597 if (oldlocal == NULL_TREE
3598 && DECL_EXTERNAL (x)
3599 && oldglobal != NULL_TREE
3600 && TREE_CODE (x) == FUNCTION_DECL
3601 && TREE_CODE (oldglobal) == FUNCTION_DECL)
3602 {
3603 /* We have one. Their types must agree. */
3604 if (decls_match (x, oldglobal))
3605 /* OK */;
3606 else
3607 {
3608 cp_warning ("extern declaration of `%#D' doesn't match", x);
3609 cp_warning_at ("global declaration `%#D'", oldglobal);
3610 }
3611 }
3612 /* If we have a local external declaration,
3613 and no file-scope declaration has yet been seen,
3614 then if we later have a file-scope decl it must not be static. */
3615 if (oldlocal == NULL_TREE
3616 && oldglobal == NULL_TREE
3617 && DECL_EXTERNAL (x)
3618 && TREE_PUBLIC (x))
3619 {
3620 TREE_PUBLIC (name) = 1;
3621 }
3622
3623 if (DECL_FROM_INLINE (x))
3624 /* Inline decls shadow nothing. */;
3625
3626 /* Warn if shadowing an argument at the top level of the body. */
3627 else if (oldlocal != NULL_TREE && !DECL_EXTERNAL (x)
3628 && TREE_CODE (oldlocal) == PARM_DECL
3629 && TREE_CODE (x) != PARM_DECL)
3630 {
3631 /* Go to where the parms should be and see if we
3632 find them there. */
3633 struct binding_level *b = current_binding_level->level_chain;
3634
3635 if (cleanup_label)
3636 b = b->level_chain;
3637
3638 /* ARM $8.3 */
3639 if (b->parm_flag == 1)
3640 cp_error ("declaration of `%#D' shadows a parameter", name);
3641 }
3642 else if (warn_shadow && oldlocal != NULL_TREE && b->is_for_scope
3643 && !DECL_DEAD_FOR_LOCAL (oldlocal))
3644 {
3645 warning ("variable `%s' shadows local",
3646 IDENTIFIER_POINTER (name));
3647 cp_warning_at (" this is the shadowed declaration", oldlocal);
3648 }
3649 /* Maybe warn if shadowing something else. */
3650 else if (warn_shadow && !DECL_EXTERNAL (x)
3651 /* No shadow warnings for internally generated vars. */
3652 && ! DECL_ARTIFICIAL (x)
3653 /* No shadow warnings for vars made for inlining. */
3654 && ! DECL_FROM_INLINE (x))
3655 {
3656 char *warnstring = NULL;
3657
3658 if (oldlocal != NULL_TREE && TREE_CODE (oldlocal) == PARM_DECL)
3659 warnstring = "declaration of `%s' shadows a parameter";
3660 else if (IDENTIFIER_CLASS_VALUE (name) != NULL_TREE
3661 && current_class_ptr
3662 && !TREE_STATIC (name))
3663 warnstring = "declaration of `%s' shadows a member of `this'";
3664 else if (oldlocal != NULL_TREE)
3665 warnstring = "declaration of `%s' shadows previous local";
3666 else if (oldglobal != NULL_TREE)
3667 /* XXX shadow warnings in outer-more namespaces */
3668 warnstring = "declaration of `%s' shadows global declaration";
3669
3670 if (warnstring)
3671 warning (warnstring, IDENTIFIER_POINTER (name));
3672 }
3673 /* Check to see if decl redeclares a template parameter. */
3674 if (oldlocal && (current_class_type || current_function_decl )
3675 && current_template_parms)
3676 {
3677 if (decl_template_parm_p (oldlocal))
3678 {
3679 cp_error ("redeclaration of template parameter `%T'", name);
3680 cp_error_at (" previously declared here `%#D'", oldlocal);
3681 }
3682 }
3683 }
3684
3685 if (TREE_CODE (x) == FUNCTION_DECL)
3686 check_default_args (x);
3687
3688 /* Keep count of variables in this level with incomplete type. */
3689 if (TREE_CODE (x) == VAR_DECL
3690 && TREE_TYPE (x) != error_mark_node
3691 && ((TYPE_SIZE (TREE_TYPE (x)) == NULL_TREE
3692 && PROMOTES_TO_AGGR_TYPE (TREE_TYPE (x), ARRAY_TYPE))
3693 /* RTTI TD entries are created while defining the type_info. */
3694 || (TYPE_LANG_SPECIFIC (TREE_TYPE (x))
3695 && TYPE_BEING_DEFINED (TREE_TYPE (x)))))
3696 b->incomplete = tree_cons (NULL_TREE, x, b->incomplete);
3697 }
3698
3699 /* Put decls on list in reverse order.
3700 We will reverse them later if necessary. */
3701 TREE_CHAIN (x) = b->names;
3702 b->names = x;
3703 if (! (b != global_binding_level || TREE_PERMANENT (x)))
3704 my_friendly_abort (124);
3705
3706 return x;
3707 }
3708
3709 /* Same as pushdecl, but define X in binding-level LEVEL. We rely on the
3710 caller to set DECL_CONTEXT properly. */
3711
3712 static tree
3713 pushdecl_with_scope (x, level)
3714 tree x;
3715 struct binding_level *level;
3716 {
3717 register struct binding_level *b;
3718 tree function_decl = current_function_decl;
3719
3720 current_function_decl = NULL_TREE;
3721 if (level->parm_flag == 2)
3722 {
3723 b = class_binding_level;
3724 class_binding_level = level;
3725 pushdecl_class_level (x);
3726 class_binding_level = b;
3727 }
3728 else
3729 {
3730 b = current_binding_level;
3731 current_binding_level = level;
3732 x = pushdecl (x);
3733 current_binding_level = b;
3734 }
3735 current_function_decl = function_decl;
3736 return x;
3737 }
3738
3739 /* Like pushdecl, only it places X in the current namespace,
3740 if appropriate. */
3741
3742 tree
3743 pushdecl_namespace_level (x)
3744 tree x;
3745 {
3746 register struct binding_level *b = inner_binding_level;
3747 register tree t;
3748
3749 t = pushdecl_with_scope (x, NAMESPACE_LEVEL (current_namespace));
3750
3751 /* Now, the type_shadowed stack may screw us. Munge it so it does
3752 what we want. */
3753 if (TREE_CODE (x) == TYPE_DECL)
3754 {
3755 tree name = DECL_NAME (x);
3756 tree newval;
3757 tree *ptr = (tree *)0;
3758 for (; b != global_binding_level; b = b->level_chain)
3759 {
3760 tree shadowed = b->type_shadowed;
3761 for (; shadowed; shadowed = TREE_CHAIN (shadowed))
3762 if (TREE_PURPOSE (shadowed) == name)
3763 {
3764 ptr = &TREE_VALUE (shadowed);
3765 /* Can't break out of the loop here because sometimes
3766 a binding level will have duplicate bindings for
3767 PT names. It's gross, but I haven't time to fix it. */
3768 }
3769 }
3770 newval = TREE_TYPE (x);
3771 if (ptr == (tree *)0)
3772 {
3773 /* @@ This shouldn't be needed. My test case "zstring.cc" trips
3774 up here if this is changed to an assertion. --KR */
3775 SET_IDENTIFIER_TYPE_VALUE (name, newval);
3776 }
3777 else
3778 {
3779 *ptr = newval;
3780 }
3781 }
3782 return t;
3783 }
3784
3785 /* Like pushdecl, only it places X in GLOBAL_BINDING_LEVEL,
3786 if appropriate. */
3787
3788 tree
3789 pushdecl_top_level (x)
3790 tree x;
3791 {
3792 tree cur_namespace = current_namespace;
3793 current_namespace = global_namespace;
3794 x = pushdecl_namespace_level (x);
3795 current_namespace = cur_namespace;
3796 return x;
3797 }
3798
3799 /* Make the declaration of X appear in CLASS scope. */
3800
3801 tree
3802 pushdecl_class_level (x)
3803 tree x;
3804 {
3805 /* Don't use DECL_ASSEMBLER_NAME here! Everything that looks in class
3806 scope looks for the pre-mangled name. */
3807 register tree name = DECL_NAME (x);
3808
3809 if (name)
3810 {
3811 if (TYPE_BEING_DEFINED (current_class_type))
3812 {
3813 /* A name N used in a class S shall refer to the same declaration
3814 in its context and when re-evaluated in the completed scope of S.
3815
3816 Types, enums, and static vars are checked here; other
3817 members are checked in finish_struct. */
3818 tree icv = IDENTIFIER_CLASS_VALUE (name);
3819
3820 if (icv && icv != x
3821 && flag_optional_diags
3822 /* Don't complain about inherited names. */
3823 && id_in_current_class (name)
3824 /* Or shadowed tags. */
3825 && !(DECL_DECLARES_TYPE_P (icv)
3826 && DECL_CONTEXT (icv) == current_class_type))
3827 {
3828 cp_pedwarn ("declaration of identifier `%D' as `%#D'", name, x);
3829 cp_pedwarn_at ("conflicts with previous use in class as `%#D'",
3830 icv);
3831 }
3832 }
3833
3834 push_class_level_binding (name, x);
3835 if (TREE_CODE (x) == TYPE_DECL)
3836 {
3837 set_identifier_type_value (name, TREE_TYPE (x));
3838 }
3839 }
3840 return x;
3841 }
3842
3843 #if 0
3844 /* This function is used to push the mangled decls for nested types into
3845 the appropriate scope. Previously pushdecl_top_level was used, but that
3846 is incorrect for members of local classes. */
3847
3848 void
3849 pushdecl_nonclass_level (x)
3850 tree x;
3851 {
3852 struct binding_level *b = current_binding_level;
3853
3854 my_friendly_assert (b->parm_flag != 2, 180);
3855
3856 #if 0
3857 /* Get out of template binding levels */
3858 while (b->pseudo_global)
3859 b = b->level_chain;
3860 #endif
3861
3862 pushdecl_with_scope (x, b);
3863 }
3864 #endif
3865
3866 /* Make the declaration(s) of X appear in CLASS scope
3867 under the name NAME. */
3868
3869 void
3870 push_class_level_binding (name, x)
3871 tree name;
3872 tree x;
3873 {
3874 /* The class_binding_level will be NULL if x is a template
3875 parameter name in a member template. */
3876 if (!class_binding_level)
3877 return;
3878
3879 if (TREE_CODE (x) == TYPE_DECL && DECL_ARTIFICIAL (x)
3880 && purpose_member (name, class_binding_level->class_shadowed))
3881 return;
3882
3883 maybe_push_cache_obstack ();
3884 class_binding_level->class_shadowed
3885 = tree_cons (name, IDENTIFIER_CLASS_VALUE (name),
3886 class_binding_level->class_shadowed);
3887 pop_obstacks ();
3888 IDENTIFIER_CLASS_VALUE (name) = x;
3889 obstack_ptr_grow (&decl_obstack, x);
3890 }
3891
3892 /* Insert another USING_DECL into the current binding level,
3893 returning this declaration. If this is a redeclaration,
3894 do nothing and return NULL_TREE. */
3895
3896 tree
3897 push_using_decl (scope, name)
3898 tree scope;
3899 tree name;
3900 {
3901 tree decl;
3902
3903 my_friendly_assert (TREE_CODE (scope) == NAMESPACE_DECL, 383);
3904 my_friendly_assert (TREE_CODE (name) == IDENTIFIER_NODE, 384);
3905 for (decl = current_binding_level->usings; decl; decl = TREE_CHAIN (decl))
3906 if (DECL_INITIAL (decl) == scope && DECL_NAME (decl) == name)
3907 break;
3908 if (decl)
3909 return NULL_TREE;
3910 decl = build_lang_decl (USING_DECL, name, void_type_node);
3911 DECL_INITIAL (decl) = scope;
3912 TREE_CHAIN (decl) = current_binding_level->usings;
3913 current_binding_level->usings = decl;
3914 return decl;
3915 }
3916
3917 /* Add namespace to using_directives. Return NULL_TREE if nothing was
3918 changed (i.e. there was already a directive), or the fresh
3919 TREE_LIST otherwise. */
3920
3921 tree
3922 push_using_directive (used)
3923 tree used;
3924 {
3925 tree ud = current_binding_level->using_directives;
3926 tree iter, ancestor;
3927
3928 /* Check if we already have this. */
3929 if (purpose_member (used, ud) != NULL_TREE)
3930 return NULL_TREE;
3931
3932 /* Recursively add all namespaces used. */
3933 for (iter = DECL_NAMESPACE_USING (used); iter; iter = TREE_CHAIN (iter))
3934 push_using_directive (TREE_PURPOSE (iter));
3935
3936 ancestor = namespace_ancestor (current_decl_namespace (), used);
3937 ud = current_binding_level->using_directives;
3938 ud = perm_tree_cons (used, ancestor, ud);
3939 current_binding_level->using_directives = ud;
3940 return ud;
3941 }
3942
3943 /* DECL is a FUNCTION_DECL which may have other definitions already in
3944 place. We get around this by making the value of the identifier point
3945 to a list of all the things that want to be referenced by that name. It
3946 is then up to the users of that name to decide what to do with that
3947 list.
3948
3949 DECL may also be a TEMPLATE_DECL, with a FUNCTION_DECL in its DECL_RESULT
3950 slot. It is dealt with the same way.
3951
3952 The value returned may be a previous declaration if we guessed wrong
3953 about what language DECL should belong to (C or C++). Otherwise,
3954 it's always DECL (and never something that's not a _DECL). */
3955
3956 static tree
3957 push_overloaded_decl (decl, forgettable)
3958 tree decl;
3959 int forgettable;
3960 {
3961 tree orig_name = DECL_NAME (decl);
3962 tree old;
3963 int doing_global = (namespace_bindings_p () || ! forgettable);
3964
3965 if (doing_global)
3966 {
3967 old = namespace_binding (orig_name, DECL_CONTEXT (decl));
3968 if (old && TREE_CODE (old) == FUNCTION_DECL
3969 && DECL_ARTIFICIAL (old)
3970 && (DECL_BUILT_IN (old) || DECL_BUILT_IN_NONANSI (old)))
3971 {
3972 if (duplicate_decls (decl, old))
3973 return old;
3974 old = NULL_TREE;
3975 }
3976 }
3977 else
3978 {
3979 old = IDENTIFIER_LOCAL_VALUE (orig_name);
3980
3981 if (! purpose_member (orig_name, current_binding_level->shadowed))
3982 {
3983 current_binding_level->shadowed
3984 = tree_cons (orig_name, old, current_binding_level->shadowed);
3985 old = NULL_TREE;
3986 }
3987 }
3988
3989 if (old)
3990 {
3991 if (TREE_CODE (old) == TYPE_DECL && DECL_ARTIFICIAL (old))
3992 {
3993 tree t = TREE_TYPE (old);
3994 if (IS_AGGR_TYPE (t) && warn_shadow
3995 && (! DECL_IN_SYSTEM_HEADER (decl)
3996 || ! DECL_IN_SYSTEM_HEADER (old)))
3997 cp_warning ("`%#D' hides constructor for `%#T'", decl, t);
3998 old = NULL_TREE;
3999 }
4000 else if (is_overloaded_fn (old))
4001 {
4002 tree tmp;
4003
4004 for (tmp = old; tmp; tmp = OVL_NEXT (tmp))
4005 if (decl == OVL_CURRENT (tmp)
4006 || duplicate_decls (decl, OVL_CURRENT (tmp)))
4007 return OVL_CURRENT (tmp);
4008 }
4009 else
4010 {
4011 cp_error_at ("previous non-function declaration `%#D'", old);
4012 cp_error ("conflicts with function declaration `%#D'", decl);
4013 return decl;
4014 }
4015 }
4016
4017 if (old || TREE_CODE (decl) == TEMPLATE_DECL)
4018 {
4019 if (old && TREE_CODE (old) != OVERLOAD)
4020 old = ovl_cons (old, NULL_TREE);
4021 old = ovl_cons (decl, old);
4022 }
4023 else
4024 /* orig_name is not ambiguous. */
4025 old = decl;
4026
4027 if (doing_global)
4028 set_namespace_binding (orig_name, current_namespace, old);
4029 else
4030 IDENTIFIER_LOCAL_VALUE (orig_name) = old;
4031
4032 return decl;
4033 }
4034 \f
4035 /* Generate an implicit declaration for identifier FUNCTIONID
4036 as a function of type int (). Print a warning if appropriate. */
4037
4038 tree
4039 implicitly_declare (functionid)
4040 tree functionid;
4041 {
4042 register tree decl;
4043 int temp = allocation_temporary_p ();
4044
4045 push_obstacks_nochange ();
4046
4047 /* Save the decl permanently so we can warn if definition follows.
4048 In ANSI C, warn_implicit is usually false, so the saves little space.
4049 But in C++, it's usually true, hence the extra code. */
4050 if (temp && (! warn_implicit || toplevel_bindings_p ()))
4051 end_temporary_allocation ();
4052
4053 /* We used to reuse an old implicit decl here,
4054 but this loses with inline functions because it can clobber
4055 the saved decl chains. */
4056 decl = build_lang_decl (FUNCTION_DECL, functionid, default_function_type);
4057
4058 DECL_EXTERNAL (decl) = 1;
4059 TREE_PUBLIC (decl) = 1;
4060
4061 /* ANSI standard says implicit declarations are in the innermost block.
4062 So we record the decl in the standard fashion. */
4063 pushdecl (decl);
4064 rest_of_decl_compilation (decl, NULL_PTR, 0, 0);
4065
4066 if (warn_implicit
4067 /* Only one warning per identifier. */
4068 && IDENTIFIER_IMPLICIT_DECL (functionid) == NULL_TREE)
4069 {
4070 cp_pedwarn ("implicit declaration of function `%#D'", decl);
4071 }
4072
4073 SET_IDENTIFIER_IMPLICIT_DECL (functionid, decl);
4074
4075 pop_obstacks ();
4076
4077 return decl;
4078 }
4079
4080 /* Return zero if the declaration NEWDECL is valid
4081 when the declaration OLDDECL (assumed to be for the same name)
4082 has already been seen.
4083 Otherwise return an error message format string with a %s
4084 where the identifier should go. */
4085
4086 static char *
4087 redeclaration_error_message (newdecl, olddecl)
4088 tree newdecl, olddecl;
4089 {
4090 if (TREE_CODE (newdecl) == TYPE_DECL)
4091 {
4092 /* Because C++ can put things into name space for free,
4093 constructs like "typedef struct foo { ... } foo"
4094 would look like an erroneous redeclaration. */
4095 if (comptypes (TREE_TYPE (newdecl), TREE_TYPE (olddecl), 0))
4096 return 0;
4097 else
4098 return "redefinition of `%#D'";
4099 }
4100 else if (TREE_CODE (newdecl) == FUNCTION_DECL)
4101 {
4102 /* If this is a pure function, its olddecl will actually be
4103 the original initialization to `0' (which we force to call
4104 abort()). Don't complain about redefinition in this case. */
4105 if (DECL_LANG_SPECIFIC (olddecl) && DECL_ABSTRACT_VIRTUAL_P (olddecl))
4106 return 0;
4107
4108 /* If both functions come from different namespaces, this is not
4109 a redeclaration - this is a conflict with a used function. */
4110 if (DECL_NAMESPACE_SCOPE_P (olddecl)
4111 && DECL_CONTEXT (olddecl) != DECL_CONTEXT (newdecl))
4112 return "`%D' conflicts with used function";
4113
4114 /* We'll complain about linkage mismatches in
4115 warn_extern_redeclared_static. */
4116
4117 /* Defining the same name twice is no good. */
4118 if (DECL_INITIAL (olddecl) != NULL_TREE
4119 && DECL_INITIAL (newdecl) != NULL_TREE)
4120 {
4121 if (DECL_NAME (olddecl) == NULL_TREE)
4122 return "`%#D' not declared in class";
4123 else
4124 return "redefinition of `%#D'";
4125 }
4126 return 0;
4127 }
4128 else if (TREE_CODE (newdecl) == TEMPLATE_DECL)
4129 {
4130 if ((TREE_CODE (DECL_TEMPLATE_RESULT (newdecl)) == FUNCTION_DECL
4131 && DECL_INITIAL (DECL_TEMPLATE_RESULT (newdecl))
4132 && DECL_INITIAL (DECL_TEMPLATE_RESULT (olddecl)))
4133 || (TREE_CODE (DECL_TEMPLATE_RESULT (newdecl)) == TYPE_DECL
4134 && TYPE_SIZE (TREE_TYPE (newdecl))
4135 && TYPE_SIZE (TREE_TYPE (olddecl))))
4136 return "redefinition of `%#D'";
4137 return 0;
4138 }
4139 else if (toplevel_bindings_p ())
4140 {
4141 /* Objects declared at top level: */
4142 /* If at least one is a reference, it's ok. */
4143 if (DECL_EXTERNAL (newdecl) || DECL_EXTERNAL (olddecl))
4144 return 0;
4145 /* Reject two definitions. */
4146 return "redefinition of `%#D'";
4147 }
4148 else
4149 {
4150 /* Objects declared with block scope: */
4151 /* Reject two definitions, and reject a definition
4152 together with an external reference. */
4153 if (!(DECL_EXTERNAL (newdecl) && DECL_EXTERNAL (olddecl)))
4154 return "redeclaration of `%#D'";
4155 return 0;
4156 }
4157 }
4158 \f
4159 /* Get the LABEL_DECL corresponding to identifier ID as a label.
4160 Create one if none exists so far for the current function.
4161 This function is called for both label definitions and label references. */
4162
4163 tree
4164 lookup_label (id)
4165 tree id;
4166 {
4167 register tree decl = IDENTIFIER_LABEL_VALUE (id);
4168
4169 if (current_function_decl == NULL_TREE)
4170 {
4171 error ("label `%s' referenced outside of any function",
4172 IDENTIFIER_POINTER (id));
4173 return NULL_TREE;
4174 }
4175
4176 if ((decl == NULL_TREE
4177 || DECL_SOURCE_LINE (decl) == 0)
4178 && (named_label_uses == NULL
4179 || named_label_uses->names_in_scope != current_binding_level->names
4180 || named_label_uses->label_decl != decl))
4181 {
4182 struct named_label_list *new_ent;
4183 new_ent
4184 = (struct named_label_list*)oballoc (sizeof (struct named_label_list));
4185 new_ent->label_decl = decl;
4186 new_ent->names_in_scope = current_binding_level->names;
4187 new_ent->binding_level = current_binding_level;
4188 new_ent->lineno_o_goto = lineno;
4189 new_ent->filename_o_goto = input_filename;
4190 new_ent->next = named_label_uses;
4191 named_label_uses = new_ent;
4192 }
4193
4194 /* Use a label already defined or ref'd with this name. */
4195 if (decl != NULL_TREE)
4196 {
4197 /* But not if it is inherited and wasn't declared to be inheritable. */
4198 if (DECL_CONTEXT (decl) != current_function_decl
4199 && ! C_DECLARED_LABEL_FLAG (decl))
4200 return shadow_label (id);
4201 return decl;
4202 }
4203
4204 decl = build_decl (LABEL_DECL, id, void_type_node);
4205
4206 /* Make sure every label has an rtx. */
4207 label_rtx (decl);
4208
4209 /* A label not explicitly declared must be local to where it's ref'd. */
4210 DECL_CONTEXT (decl) = current_function_decl;
4211
4212 DECL_MODE (decl) = VOIDmode;
4213
4214 /* Say where one reference is to the label,
4215 for the sake of the error if it is not defined. */
4216 DECL_SOURCE_LINE (decl) = lineno;
4217 DECL_SOURCE_FILE (decl) = input_filename;
4218
4219 SET_IDENTIFIER_LABEL_VALUE (id, decl);
4220
4221 named_labels = tree_cons (NULL_TREE, decl, named_labels);
4222 named_label_uses->label_decl = decl;
4223
4224 return decl;
4225 }
4226
4227 /* Make a label named NAME in the current function,
4228 shadowing silently any that may be inherited from containing functions
4229 or containing scopes.
4230
4231 Note that valid use, if the label being shadowed
4232 comes from another scope in the same function,
4233 requires calling declare_nonlocal_label right away. */
4234
4235 tree
4236 shadow_label (name)
4237 tree name;
4238 {
4239 register tree decl = IDENTIFIER_LABEL_VALUE (name);
4240
4241 if (decl != NULL_TREE)
4242 {
4243 shadowed_labels = tree_cons (NULL_TREE, decl, shadowed_labels);
4244 SET_IDENTIFIER_LABEL_VALUE (name, NULL_TREE);
4245 }
4246
4247 return lookup_label (name);
4248 }
4249
4250 /* Define a label, specifying the location in the source file.
4251 Return the LABEL_DECL node for the label, if the definition is valid.
4252 Otherwise return 0. */
4253
4254 tree
4255 define_label (filename, line, name)
4256 char *filename;
4257 int line;
4258 tree name;
4259 {
4260 tree decl;
4261
4262 if (minimal_parse_mode)
4263 {
4264 push_obstacks (&permanent_obstack, &permanent_obstack);
4265 decl = build_decl (LABEL_DECL, name, void_type_node);
4266 pop_obstacks ();
4267 DECL_SOURCE_LINE (decl) = line;
4268 DECL_SOURCE_FILE (decl) = filename;
4269 add_tree (decl);
4270 return decl;
4271 }
4272
4273 decl = lookup_label (name);
4274
4275 /* After labels, make any new cleanups go into their
4276 own new (temporary) binding contour. */
4277 current_binding_level->more_cleanups_ok = 0;
4278
4279 /* If label with this name is known from an outer context, shadow it. */
4280 if (decl != NULL_TREE && DECL_CONTEXT (decl) != current_function_decl)
4281 {
4282 shadowed_labels = tree_cons (NULL_TREE, decl, shadowed_labels);
4283 SET_IDENTIFIER_LABEL_VALUE (name, NULL_TREE);
4284 decl = lookup_label (name);
4285 }
4286
4287 if (name == get_identifier ("wchar_t"))
4288 cp_pedwarn ("label named wchar_t");
4289
4290 if (DECL_INITIAL (decl) != NULL_TREE)
4291 {
4292 cp_error ("duplicate label `%D'", decl);
4293 return 0;
4294 }
4295 else
4296 {
4297 struct named_label_list *uses, *prev;
4298 int identified = 0;
4299
4300 /* Mark label as having been defined. */
4301 DECL_INITIAL (decl) = error_mark_node;
4302 /* Say where in the source. */
4303 DECL_SOURCE_FILE (decl) = filename;
4304 DECL_SOURCE_LINE (decl) = line;
4305
4306 prev = NULL;
4307 uses = named_label_uses;
4308 while (uses != NULL)
4309 if (uses->label_decl == decl)
4310 {
4311 struct binding_level *b = current_binding_level;
4312 while (b)
4313 {
4314 tree new_decls = b->names;
4315 tree old_decls = (b == uses->binding_level)
4316 ? uses->names_in_scope : NULL_TREE;
4317 while (new_decls != old_decls)
4318 {
4319 if (TREE_CODE (new_decls) == VAR_DECL
4320 /* Don't complain about crossing initialization
4321 of internal entities. They can't be accessed,
4322 and they should be cleaned up
4323 by the time we get to the label. */
4324 && ! DECL_ARTIFICIAL (new_decls)
4325 && ((DECL_INITIAL (new_decls) != NULL_TREE
4326 && DECL_INITIAL (new_decls) != error_mark_node)
4327 || TYPE_NEEDS_CONSTRUCTING (TREE_TYPE (new_decls))))
4328 {
4329 if (! identified)
4330 {
4331 cp_error ("jump to label `%D'", decl);
4332 error_with_file_and_line (uses->filename_o_goto,
4333 uses->lineno_o_goto,
4334 " from here");
4335 identified = 1;
4336 }
4337 cp_error_at (" crosses initialization of `%#D'",
4338 new_decls);
4339 }
4340 new_decls = TREE_CHAIN (new_decls);
4341 }
4342 if (b == uses->binding_level)
4343 break;
4344 b = b->level_chain;
4345 }
4346
4347 if (prev != NULL)
4348 prev->next = uses->next;
4349 else
4350 named_label_uses = uses->next;
4351
4352 uses = uses->next;
4353 }
4354 else
4355 {
4356 prev = uses;
4357 uses = uses->next;
4358 }
4359 current_function_return_value = NULL_TREE;
4360 return decl;
4361 }
4362 }
4363
4364 struct cp_switch
4365 {
4366 struct binding_level *level;
4367 struct cp_switch *next;
4368 };
4369
4370 static struct cp_switch *switch_stack;
4371
4372 void
4373 push_switch ()
4374 {
4375 struct cp_switch *p
4376 = (struct cp_switch *) oballoc (sizeof (struct cp_switch));
4377 p->level = current_binding_level;
4378 p->next = switch_stack;
4379 switch_stack = p;
4380 }
4381
4382 void
4383 pop_switch ()
4384 {
4385 switch_stack = switch_stack->next;
4386 }
4387
4388 /* Same, but for CASE labels. If DECL is NULL_TREE, it's the default. */
4389 /* XXX Note decl is never actually used. (bpk) */
4390
4391 void
4392 define_case_label (decl)
4393 tree decl;
4394 {
4395 tree cleanup = last_cleanup_this_contour ();
4396 struct binding_level *b = current_binding_level;
4397 int identified = 0;
4398
4399 if (cleanup)
4400 {
4401 static int explained = 0;
4402 cp_warning_at ("destructor needed for `%#D'", TREE_PURPOSE (cleanup));
4403 warning ("where case label appears here");
4404 if (!explained)
4405 {
4406 warning ("(enclose actions of previous case statements requiring");
4407 warning ("destructors in their own binding contours.)");
4408 explained = 1;
4409 }
4410 }
4411
4412 for (; b && b != switch_stack->level; b = b->level_chain)
4413 {
4414 tree new_decls = b->names;
4415 for (; new_decls; new_decls = TREE_CHAIN (new_decls))
4416 {
4417 if (TREE_CODE (new_decls) == VAR_DECL
4418 /* Don't complain about crossing initialization
4419 of internal entities. They can't be accessed,
4420 and they should be cleaned up
4421 by the time we get to the label. */
4422 && ! DECL_ARTIFICIAL (new_decls)
4423 && ((DECL_INITIAL (new_decls) != NULL_TREE
4424 && DECL_INITIAL (new_decls) != error_mark_node)
4425 || TYPE_NEEDS_CONSTRUCTING (TREE_TYPE (new_decls))))
4426 {
4427 if (! identified)
4428 error ("jump to case label");
4429 identified = 1;
4430 cp_error_at (" crosses initialization of `%#D'",
4431 new_decls);
4432 }
4433 }
4434 }
4435
4436 /* After labels, make any new cleanups go into their
4437 own new (temporary) binding contour. */
4438
4439 current_binding_level->more_cleanups_ok = 0;
4440 current_function_return_value = NULL_TREE;
4441 }
4442 \f
4443 /* Return the list of declarations of the current level.
4444 Note that this list is in reverse order unless/until
4445 you nreverse it; and when you do nreverse it, you must
4446 store the result back using `storedecls' or you will lose. */
4447
4448 tree
4449 getdecls ()
4450 {
4451 return current_binding_level->names;
4452 }
4453
4454 /* Return the list of type-tags (for structs, etc) of the current level. */
4455
4456 tree
4457 gettags ()
4458 {
4459 return current_binding_level->tags;
4460 }
4461
4462 /* Store the list of declarations of the current level.
4463 This is done for the parameter declarations of a function being defined,
4464 after they are modified in the light of any missing parameters. */
4465
4466 static void
4467 storedecls (decls)
4468 tree decls;
4469 {
4470 current_binding_level->names = decls;
4471 }
4472
4473 /* Similarly, store the list of tags of the current level. */
4474
4475 static void
4476 storetags (tags)
4477 tree tags;
4478 {
4479 current_binding_level->tags = tags;
4480 }
4481 \f
4482 /* Given NAME, an IDENTIFIER_NODE,
4483 return the structure (or union or enum) definition for that name.
4484 Searches binding levels from BINDING_LEVEL up to the global level.
4485 If THISLEVEL_ONLY is nonzero, searches only the specified context
4486 (but skips any tag-transparent contexts to find one that is
4487 meaningful for tags).
4488 FORM says which kind of type the caller wants;
4489 it is RECORD_TYPE or UNION_TYPE or ENUMERAL_TYPE.
4490 If the wrong kind of type is found, and it's not a template, an error is
4491 reported. */
4492
4493 static tree
4494 lookup_tag (form, name, binding_level, thislevel_only)
4495 enum tree_code form;
4496 tree name;
4497 struct binding_level *binding_level;
4498 int thislevel_only;
4499 {
4500 register struct binding_level *level;
4501 /* Non-zero if, we should look past a pseudo-global level, even if
4502 THISLEVEL_ONLY. */
4503 int allow_pseudo_global = 1;
4504
4505 for (level = binding_level; level; level = level->level_chain)
4506 {
4507 register tree tail;
4508 if (ANON_AGGRNAME_P (name))
4509 for (tail = level->tags; tail; tail = TREE_CHAIN (tail))
4510 {
4511 /* There's no need for error checking here, because
4512 anon names are unique throughout the compilation. */
4513 if (TYPE_IDENTIFIER (TREE_VALUE (tail)) == name)
4514 return TREE_VALUE (tail);
4515 }
4516 else if (level->namespace_p)
4517 /* Do namespace lookup. */
4518 for (tail = current_namespace; 1; tail = CP_DECL_CONTEXT (tail))
4519 {
4520 tree old = binding_for_name (name, tail);
4521
4522 /* If we just skipped past a pseudo global level, even
4523 though THISLEVEL_ONLY, and we find a template class
4524 declaration, then we use the _TYPE node for the
4525 template. See the example below. */
4526 if (thislevel_only && !allow_pseudo_global
4527 && old && BINDING_VALUE (old)
4528 && DECL_CLASS_TEMPLATE_P (BINDING_VALUE (old)))
4529 old = TREE_TYPE (BINDING_VALUE (old));
4530 else
4531 old = BINDING_TYPE (old);
4532
4533 /* If it has an original type, it is a typedef, and we
4534 should not return it. */
4535 if (old && DECL_ORIGINAL_TYPE (TYPE_NAME (old)))
4536 old = NULL_TREE;
4537 if (old && TREE_CODE (old) != form
4538 && !(form != ENUMERAL_TYPE && TREE_CODE (old) == TEMPLATE_DECL))
4539 {
4540 cp_error ("`%#D' redeclared as %C", old, form);
4541 return NULL_TREE;
4542 }
4543 if (old)
4544 return old;
4545 if (thislevel_only || tail == global_namespace)
4546 return NULL_TREE;
4547 }
4548 else
4549 for (tail = level->tags; tail; tail = TREE_CHAIN (tail))
4550 {
4551 if (TREE_PURPOSE (tail) == name)
4552 {
4553 enum tree_code code = TREE_CODE (TREE_VALUE (tail));
4554 /* Should tighten this up; it'll probably permit
4555 UNION_TYPE and a struct template, for example. */
4556 if (code != form
4557 && !(form != ENUMERAL_TYPE && code == TEMPLATE_DECL))
4558 {
4559 /* Definition isn't the kind we were looking for. */
4560 cp_error ("`%#D' redeclared as %C", TREE_VALUE (tail),
4561 form);
4562 return NULL_TREE;
4563 }
4564 return TREE_VALUE (tail);
4565 }
4566 }
4567 if (thislevel_only && ! level->tag_transparent)
4568 {
4569 if (level->pseudo_global && allow_pseudo_global)
4570 {
4571 /* We must deal with cases like this:
4572
4573 template <class T> struct S;
4574 template <class T> struct S {};
4575
4576 When looking up `S', for the second declaration, we
4577 would like to find the first declaration. But, we
4578 are in the pseudo-global level created for the
4579 template parameters, rather than the (surrounding)
4580 namespace level. Thus, we keep going one more level,
4581 even though THISLEVEL_ONLY is non-zero. */
4582 allow_pseudo_global = 0;
4583 continue;
4584 }
4585 else
4586 return NULL_TREE;
4587 }
4588 if (current_class_type && level->level_chain->namespace_p)
4589 {
4590 /* Try looking in this class's tags before heading into
4591 global binding level. */
4592 tree context = current_class_type;
4593 while (context)
4594 {
4595 switch (TREE_CODE_CLASS (TREE_CODE (context)))
4596 {
4597 tree these_tags;
4598 case 't':
4599 these_tags = CLASSTYPE_TAGS (context);
4600 if (ANON_AGGRNAME_P (name))
4601 while (these_tags)
4602 {
4603 if (TYPE_IDENTIFIER (TREE_VALUE (these_tags))
4604 == name)
4605 return TREE_VALUE (tail);
4606 these_tags = TREE_CHAIN (these_tags);
4607 }
4608 else
4609 while (these_tags)
4610 {
4611 if (TREE_PURPOSE (these_tags) == name)
4612 {
4613 if (TREE_CODE (TREE_VALUE (these_tags)) != form)
4614 {
4615 cp_error ("`%#D' redeclared as %C in class scope",
4616 TREE_VALUE (tail), form);
4617 return NULL_TREE;
4618 }
4619 return TREE_VALUE (tail);
4620 }
4621 these_tags = TREE_CHAIN (these_tags);
4622 }
4623 /* If this type is not yet complete, then don't
4624 look at its context. */
4625 if (TYPE_SIZE (context) == NULL_TREE)
4626 goto no_context;
4627 /* Go to next enclosing type, if any. */
4628 context = DECL_CONTEXT (TYPE_MAIN_DECL (context));
4629 break;
4630 case 'd':
4631 context = DECL_CONTEXT (context);
4632 break;
4633 default:
4634 my_friendly_abort (10);
4635 }
4636 continue;
4637 no_context:
4638 break;
4639 }
4640 }
4641 }
4642 return NULL_TREE;
4643 }
4644
4645 #if 0
4646 void
4647 set_current_level_tags_transparency (tags_transparent)
4648 int tags_transparent;
4649 {
4650 current_binding_level->tag_transparent = tags_transparent;
4651 }
4652 #endif
4653
4654 /* Given a type, find the tag that was defined for it and return the tag name.
4655 Otherwise return 0. However, the value can never be 0
4656 in the cases in which this is used.
4657
4658 C++: If NAME is non-zero, this is the new name to install. This is
4659 done when replacing anonymous tags with real tag names. */
4660
4661 static tree
4662 lookup_tag_reverse (type, name)
4663 tree type;
4664 tree name;
4665 {
4666 register struct binding_level *level;
4667
4668 for (level = current_binding_level; level; level = level->level_chain)
4669 {
4670 register tree tail;
4671 for (tail = level->tags; tail; tail = TREE_CHAIN (tail))
4672 {
4673 if (TREE_VALUE (tail) == type)
4674 {
4675 if (name)
4676 TREE_PURPOSE (tail) = name;
4677 return TREE_PURPOSE (tail);
4678 }
4679 }
4680 }
4681 return NULL_TREE;
4682 }
4683 \f
4684 /* Lookup TYPE in CONTEXT (a chain of nested types or a FUNCTION_DECL).
4685 Return the type value, or NULL_TREE if not found. */
4686
4687 static tree
4688 lookup_nested_type (type, context)
4689 tree type;
4690 tree context;
4691 {
4692 if (context == NULL_TREE)
4693 return NULL_TREE;
4694 while (context)
4695 {
4696 switch (TREE_CODE (context))
4697 {
4698 case TYPE_DECL:
4699 {
4700 tree ctype = TREE_TYPE (context);
4701 tree match = value_member (type, CLASSTYPE_TAGS (ctype));
4702 if (match)
4703 return TREE_VALUE (match);
4704 context = DECL_CONTEXT (context);
4705
4706 /* When we have a nested class whose member functions have
4707 local types (e.g., a set of enums), we'll arrive here
4708 with the DECL_CONTEXT as the actual RECORD_TYPE node for
4709 the enclosing class. Instead, we want to make sure we
4710 come back in here with the TYPE_DECL, not the RECORD_TYPE. */
4711 if (context && TREE_CODE (context) == RECORD_TYPE)
4712 context = TREE_CHAIN (context);
4713 }
4714 break;
4715 case FUNCTION_DECL:
4716 if (TYPE_NAME (type) && TYPE_IDENTIFIER (type))
4717 return lookup_name (TYPE_IDENTIFIER (type), 1);
4718 return NULL_TREE;
4719 default:
4720 my_friendly_abort (12);
4721 }
4722 }
4723 return NULL_TREE;
4724 }
4725
4726 /* Look up NAME in the NAMESPACE. */
4727
4728 tree
4729 lookup_namespace_name (namespace, name)
4730 tree namespace, name;
4731 {
4732 struct tree_binding _b;
4733 tree val;
4734
4735 my_friendly_assert (TREE_CODE (namespace) == NAMESPACE_DECL, 370);
4736 my_friendly_assert (TREE_CODE (name) == IDENTIFIER_NODE, 373);
4737
4738 val = binding_init (&_b);
4739 if (!qualified_lookup_using_namespace (name, namespace, val, 0))
4740 return error_mark_node;
4741
4742 if (BINDING_VALUE (val))
4743 {
4744 val = BINDING_VALUE (val);
4745
4746 /* If we have a single function from a using decl, pull it out. */
4747 if (TREE_CODE (val) == OVERLOAD && ! really_overloaded_fn (val))
4748 val = OVL_FUNCTION (val);
4749 return val;
4750 }
4751
4752 cp_error ("`%D' undeclared in namespace `%D'", name, namespace);
4753 return error_mark_node;
4754 }
4755
4756 tree
4757 make_typename_type (context, name)
4758 tree context, name;
4759 {
4760 tree t, d;
4761 tree fullname;
4762
4763 if (TREE_CODE_CLASS (TREE_CODE (name)) == 't')
4764 name = TYPE_IDENTIFIER (name);
4765 else if (TREE_CODE (name) == TYPE_DECL)
4766 name = DECL_NAME (name);
4767
4768 fullname = name;
4769
4770 if (TREE_CODE (name) == TEMPLATE_ID_EXPR)
4771 {
4772 name = TREE_OPERAND (name, 0);
4773 if (TREE_CODE (name) == TEMPLATE_DECL)
4774 name = TREE_OPERAND (fullname, 0) = DECL_NAME (name);
4775 }
4776 if (TREE_CODE (name) != IDENTIFIER_NODE)
4777 my_friendly_abort (2000);
4778
4779 if (! uses_template_parms (context)
4780 || currently_open_class (context))
4781 {
4782 if (TREE_CODE (fullname) == TEMPLATE_ID_EXPR)
4783 {
4784 if (IS_AGGR_TYPE (context))
4785 t = lookup_field (context, name, 0, 0);
4786 else
4787 t = NULL_TREE;
4788
4789 if (t == NULL_TREE || TREE_CODE (t) != TEMPLATE_DECL
4790 || TREE_CODE (DECL_RESULT (t)) != TYPE_DECL)
4791 {
4792 cp_error ("no class template named `%#T' in `%#T'",
4793 name, context);
4794 return error_mark_node;
4795 }
4796
4797 return lookup_template_class (t, TREE_OPERAND (fullname, 1),
4798 NULL_TREE, context,
4799 /*entering_scope=*/0);
4800 }
4801 else
4802 {
4803 if (IS_AGGR_TYPE (context))
4804 t = lookup_field (context, name, 0, 1);
4805 else
4806 t = NULL_TREE;
4807
4808 if (t == NULL_TREE)
4809 {
4810 cp_error ("no type named `%#T' in `%#T'", name, context);
4811 return error_mark_node;
4812 }
4813
4814 return TREE_TYPE (t);
4815 }
4816 }
4817
4818 if (processing_template_decl)
4819 push_obstacks (&permanent_obstack, &permanent_obstack);
4820 t = make_lang_type (TYPENAME_TYPE);
4821 TYPENAME_TYPE_FULLNAME (t) = fullname;
4822 d = build_decl (TYPE_DECL, name, t);
4823 if (processing_template_decl)
4824 pop_obstacks ();
4825
4826 TYPE_CONTEXT (t) = FROB_CONTEXT (context);
4827 TYPE_NAME (TREE_TYPE (d)) = d;
4828 TYPE_STUB_DECL (TREE_TYPE (d)) = d;
4829 DECL_CONTEXT (d) = FROB_CONTEXT (context);
4830 CLASSTYPE_GOT_SEMICOLON (t) = 1;
4831
4832 return t;
4833 }
4834
4835 /* Select the right _DECL from multiple choices. */
4836
4837 static tree
4838 select_decl (binding, flags)
4839 tree binding;
4840 int flags;
4841 {
4842 tree val;
4843 val = BINDING_VALUE (binding);
4844 if (LOOKUP_NAMESPACES_ONLY (flags))
4845 {
4846 /* We are not interested in types. */
4847 if (val && TREE_CODE (val) == NAMESPACE_DECL)
4848 return val;
4849 return NULL_TREE;
4850 }
4851
4852 /* If we could have a type and
4853 we have nothing or we need a type and have none. */
4854 if (BINDING_TYPE (binding)
4855 && (!val || ((flags & LOOKUP_PREFER_TYPES)
4856 && TREE_CODE (val) != TYPE_DECL)))
4857 val = TYPE_STUB_DECL (BINDING_TYPE (binding));
4858 /* Don't return non-types if we really prefer types. */
4859 else if (val && LOOKUP_TYPES_ONLY (flags) && TREE_CODE (val) != TYPE_DECL
4860 && (!looking_for_template || TREE_CODE (val) != TEMPLATE_DECL))
4861 val = NULL_TREE;
4862
4863 return val;
4864 }
4865
4866 /* Unscoped lookup of a global, iterate over namespaces, considering
4867 using namespace statements. */
4868
4869 static tree
4870 unqualified_namespace_lookup (name, flags)
4871 tree name;
4872 int flags;
4873 {
4874 struct tree_binding _binding;
4875 tree b = binding_init (&_binding);
4876 tree initial = current_decl_namespace();
4877 tree scope = initial;
4878 tree siter;
4879 struct binding_level *level;
4880 tree val = NULL_TREE;
4881
4882 while (!val)
4883 {
4884 val = binding_for_name (name, scope);
4885
4886 /* Initialize binding for this context. */
4887 BINDING_VALUE (b) = BINDING_VALUE (val);
4888 BINDING_TYPE (b) = BINDING_TYPE (val);
4889
4890 /* Add all _DECLs seen through local using-directives. */
4891 for (level = current_binding_level;
4892 !level->namespace_p;
4893 level = level->level_chain)
4894 if (!lookup_using_namespace (name, b, level->using_directives,
4895 scope, flags))
4896 /* Give up because of error. */
4897 return NULL_TREE;
4898
4899 /* Add all _DECLs seen through global using-directives. */
4900 /* XXX local and global using lists should work equally. */
4901 siter = initial;
4902 while (1)
4903 {
4904 if (!lookup_using_namespace (name, b, DECL_NAMESPACE_USING (siter),
4905 scope, flags))
4906 /* Give up because of error. */
4907 return NULL_TREE;
4908 if (siter == scope) break;
4909 siter = CP_DECL_CONTEXT (siter);
4910 }
4911
4912 val = select_decl (b, flags);
4913 if (scope == global_namespace)
4914 break;
4915 scope = CP_DECL_CONTEXT (scope);
4916 }
4917 return val;
4918 }
4919
4920 /* Combine prefer_type and namespaces_only into flags. */
4921
4922 static int
4923 lookup_flags (prefer_type, namespaces_only)
4924 int prefer_type, namespaces_only;
4925 {
4926 if (namespaces_only)
4927 return LOOKUP_PREFER_NAMESPACES;
4928 if (prefer_type > 1)
4929 return LOOKUP_PREFER_TYPES;
4930 if (prefer_type > 0)
4931 return LOOKUP_PREFER_BOTH;
4932 return 0;
4933 }
4934
4935 /* Given a lookup that returned VAL, use FLAGS to decide if we want to
4936 ignore it or not. Subroutine of lookup_name_real. */
4937
4938 static tree
4939 qualify_lookup (val, flags)
4940 tree val;
4941 int flags;
4942 {
4943 if (val == NULL_TREE)
4944 return val;
4945 if ((flags & LOOKUP_PREFER_NAMESPACES) && TREE_CODE (val) == NAMESPACE_DECL)
4946 return val;
4947 if ((flags & LOOKUP_PREFER_TYPES)
4948 && (TREE_CODE (val) == TYPE_DECL
4949 || ((flags & LOOKUP_TEMPLATES_EXPECTED)
4950 && DECL_CLASS_TEMPLATE_P (val))))
4951 return val;
4952 if (flags & (LOOKUP_PREFER_NAMESPACES | LOOKUP_PREFER_TYPES))
4953 return NULL_TREE;
4954 return val;
4955 }
4956
4957 /* Look up NAME in the current binding level and its superiors in the
4958 namespace of variables, functions and typedefs. Return a ..._DECL
4959 node of some kind representing its definition if there is only one
4960 such declaration, or return a TREE_LIST with all the overloaded
4961 definitions if there are many, or return 0 if it is undefined.
4962
4963 If PREFER_TYPE is > 0, we prefer TYPE_DECLs or namespaces.
4964 If PREFER_TYPE is > 1, we reject non-type decls (e.g. namespaces).
4965 If PREFER_TYPE is -2, we're being called from yylex(). (UGLY)
4966 Otherwise we prefer non-TYPE_DECLs.
4967
4968 If NONCLASS is non-zero, we don't look for the NAME in class scope,
4969 using IDENTIFIER_CLASS_VALUE. */
4970
4971 static tree
4972 lookup_name_real (name, prefer_type, nonclass, namespaces_only)
4973 tree name;
4974 int prefer_type, nonclass, namespaces_only;
4975 {
4976 register tree val;
4977 int yylex = 0;
4978 tree from_obj = NULL_TREE;
4979 tree locval, classval;
4980 int flags;
4981
4982 /* Hack: copy flag set by parser, if set. */
4983 if (only_namespace_names)
4984 namespaces_only = 1;
4985
4986 if (prefer_type == -2)
4987 {
4988 extern int looking_for_typename;
4989 tree type = NULL_TREE;
4990
4991 yylex = 1;
4992 prefer_type = looking_for_typename;
4993
4994 flags = lookup_flags (prefer_type, namespaces_only);
4995 /* During parsing, we need to complain. */
4996 flags |= LOOKUP_COMPLAIN;
4997 /* If the next thing is '<', class templates are types. */
4998 if (looking_for_template)
4999 flags |= LOOKUP_TEMPLATES_EXPECTED;
5000
5001 /* std:: becomes :: for now. */
5002 if (got_scope == std_node)
5003 got_scope = void_type_node;
5004
5005 if (got_scope)
5006 type = got_scope;
5007 else if (got_object != error_mark_node)
5008 type = got_object;
5009
5010 if (type)
5011 {
5012 if (type == error_mark_node)
5013 return error_mark_node;
5014 if (TREE_CODE (type) == TYPENAME_TYPE && TREE_TYPE (type))
5015 type = TREE_TYPE (type);
5016
5017 if (TYPE_P (type))
5018 type = complete_type (type);
5019
5020 if (TREE_CODE (type) == VOID_TYPE)
5021 type = global_namespace;
5022 if (TREE_CODE (type) == NAMESPACE_DECL)
5023 {
5024 struct tree_binding b;
5025 val = binding_init (&b);
5026 if (!qualified_lookup_using_namespace (name, type, val, flags))
5027 return NULL_TREE;
5028 val = select_decl (val, flags);
5029 }
5030 else if (! IS_AGGR_TYPE (type)
5031 || TREE_CODE (type) == TEMPLATE_TYPE_PARM
5032 || TREE_CODE (type) == TEMPLATE_TEMPLATE_PARM
5033 || TREE_CODE (type) == TYPENAME_TYPE)
5034 /* Someone else will give an error about this if needed. */
5035 val = NULL_TREE;
5036 else if (TYPE_BEING_DEFINED (type))
5037 {
5038 val = IDENTIFIER_CLASS_VALUE (name);
5039 if (val && DECL_CONTEXT (val) != type)
5040 {
5041 struct binding_level *b = class_binding_level;
5042 for (val = NULL_TREE; b; b = b->level_chain)
5043 {
5044 tree t = purpose_member (name, b->class_shadowed);
5045 if (t && TREE_VALUE (t)
5046 && DECL_CONTEXT (TREE_VALUE (t)) == type)
5047 {
5048 val = TREE_VALUE (t);
5049 break;
5050 }
5051 }
5052 }
5053 if (val == NULL_TREE)
5054 val = lookup_field (type, name, 0, 1);
5055 }
5056 else if (type == current_class_type)
5057 val = IDENTIFIER_CLASS_VALUE (name);
5058 else
5059 val = lookup_member (type, name, 0, prefer_type);
5060 }
5061 else
5062 val = NULL_TREE;
5063
5064 if (got_scope)
5065 goto done;
5066 else if (got_object && val)
5067 from_obj = val;
5068 }
5069 else
5070 flags = lookup_flags (prefer_type, namespaces_only);
5071
5072 locval = classval = NULL_TREE;
5073
5074 if (! namespace_bindings_p ())
5075 locval = qualify_lookup (IDENTIFIER_LOCAL_VALUE (name), flags);
5076
5077 /* In C++ class fields are between local and global scope,
5078 just before the global scope. */
5079 if (current_class_type && ! nonclass)
5080 {
5081 classval = IDENTIFIER_CLASS_VALUE (name);
5082 if (classval == NULL_TREE && TYPE_BEING_DEFINED (current_class_type))
5083 /* Try to find values from base classes if we are presently
5084 defining a type. We are presently only interested in
5085 TYPE_DECLs. */
5086 classval = lookup_field (current_class_type, name, 0, 1);
5087
5088 /* Add implicit 'typename' to types from template bases. lookup_field
5089 will do this for us. If classval is actually from an enclosing
5090 scope, lookup_nested_field will get it for us. */
5091 else if (processing_template_decl
5092 && classval && TREE_CODE (classval) == TYPE_DECL
5093 && ! currently_open_class (DECL_CONTEXT (classval))
5094 && uses_template_parms (current_class_type)
5095 && ! DECL_ARTIFICIAL (classval))
5096 classval = lookup_field (current_class_type, name, 0, 1);
5097
5098 /* yylex() calls this with -2, since we should never start digging for
5099 the nested name at the point where we haven't even, for example,
5100 created the COMPONENT_REF or anything like that. */
5101 if (classval == NULL_TREE)
5102 classval = lookup_nested_field (name, ! yylex);
5103
5104 classval = qualify_lookup (classval, flags);
5105 }
5106
5107 if (locval && classval)
5108 {
5109 if (current_scope () == current_function_decl
5110 && ! hack_decl_function_context (current_function_decl))
5111 /* Not in a nested function. */
5112 val = locval;
5113 else
5114 {
5115 /* This is incredibly horrible. The whole concept of
5116 IDENTIFIER_LOCAL_VALUE / IDENTIFIER_CLASS_VALUE /
5117 IDENTIFIER_GLOBAL_VALUE needs to be scrapped for local
5118 classes. */
5119 tree lctx = hack_decl_function_context (locval);
5120 tree cctx = hack_decl_function_context (classval);
5121
5122 if (lctx == current_scope ())
5123 val = locval;
5124 else if (lctx == cctx)
5125 val = classval;
5126 else
5127 /* I don't know which is right; let's just guess for now. */
5128 val = locval;
5129 }
5130 }
5131 else if (locval)
5132 val = locval;
5133 else if (classval)
5134 val = classval;
5135 else
5136 val = unqualified_namespace_lookup (name, flags);
5137
5138 if (classval && TREE_CODE (val) == TYPE_DECL
5139 && TREE_CODE (TREE_TYPE (val)) == TYPENAME_TYPE
5140 && TREE_TYPE (TREE_TYPE (val)))
5141 {
5142 tree nsval = unqualified_namespace_lookup (name, flags);
5143
5144 if (val && nsval && TREE_CODE (nsval) == TYPE_DECL)
5145 {
5146 static int explained;
5147 cp_warning ("namespace-scope type `%#D'", nsval);
5148 cp_warning
5149 (" is used instead of `%D' from dependent base class", val);
5150 if (! explained)
5151 {
5152 explained = 1;
5153 cp_warning (" (use `typename %D' if that's what you meant)",
5154 val);
5155 }
5156 val = nsval;
5157 }
5158 }
5159
5160 done:
5161 if (val)
5162 {
5163 /* This should only warn about types used in qualified-ids. */
5164 if (from_obj && from_obj != val)
5165 {
5166 if (looking_for_typename && TREE_CODE (from_obj) == TYPE_DECL
5167 && TREE_CODE (val) == TYPE_DECL
5168 && TREE_TYPE (from_obj) != TREE_TYPE (val))
5169 {
5170 cp_pedwarn ("lookup of `%D' in the scope of `%#T' (`%#T')",
5171 name, got_object, TREE_TYPE (from_obj));
5172 cp_pedwarn (" does not match lookup in the current scope (`%#T')",
5173 TREE_TYPE (val));
5174 }
5175
5176 /* We don't change val to from_obj if got_object depends on
5177 template parms because that breaks implicit typename for
5178 destructor calls. */
5179 if (! uses_template_parms (got_object))
5180 val = from_obj;
5181 }
5182
5183 if ((TREE_CODE (val) == TEMPLATE_DECL && looking_for_template)
5184 || TREE_CODE (val) == TYPE_DECL || prefer_type <= 0)
5185 ;
5186 /* Caller wants a class-or-namespace-name. */
5187 else if (prefer_type == 1 && TREE_CODE (val) == NAMESPACE_DECL)
5188 ;
5189 else if (IDENTIFIER_HAS_TYPE_VALUE (name))
5190 val = TYPE_MAIN_DECL (IDENTIFIER_TYPE_VALUE (name));
5191 else if (TREE_TYPE (val) == error_mark_node)
5192 val = error_mark_node;
5193
5194 /* If we have a single function from a using decl, pull it out. */
5195 if (TREE_CODE (val) == OVERLOAD && ! really_overloaded_fn (val))
5196 val = OVL_FUNCTION (val);
5197 }
5198 else if (from_obj)
5199 val = from_obj;
5200
5201 return val;
5202 }
5203
5204 tree
5205 lookup_name_nonclass (name)
5206 tree name;
5207 {
5208 return lookup_name_real (name, 0, 1, 0);
5209 }
5210
5211 tree
5212 lookup_function_nonclass (name, args)
5213 tree name;
5214 tree args;
5215 {
5216 return lookup_arg_dependent (name, lookup_name_nonclass (name), args);
5217 }
5218
5219 tree
5220 lookup_name_namespace_only (name)
5221 tree name;
5222 {
5223 /* type-or-namespace, nonclass, namespace_only */
5224 return lookup_name_real (name, 1, 1, 1);
5225 }
5226
5227 tree
5228 lookup_name (name, prefer_type)
5229 tree name;
5230 int prefer_type;
5231 {
5232 return lookup_name_real (name, prefer_type, 0, 0);
5233 }
5234
5235 /* Similar to `lookup_name' but look only at current binding level. */
5236
5237 tree
5238 lookup_name_current_level (name)
5239 tree name;
5240 {
5241 register tree t = NULL_TREE;
5242
5243 if (current_binding_level->namespace_p)
5244 {
5245 t = IDENTIFIER_NAMESPACE_VALUE (name);
5246
5247 /* extern "C" function() */
5248 if (t != NULL_TREE && TREE_CODE (t) == TREE_LIST)
5249 t = TREE_VALUE (t);
5250 }
5251 else if (IDENTIFIER_LOCAL_VALUE (name) != NULL_TREE)
5252 {
5253 struct binding_level *b = current_binding_level;
5254 while (1)
5255 {
5256 if (purpose_member (name, b->shadowed))
5257 return IDENTIFIER_LOCAL_VALUE (name);
5258 if (b->keep == 2)
5259 b = b->level_chain;
5260 else
5261 break;
5262 }
5263 }
5264
5265 return t;
5266 }
5267
5268 /* Like lookup_name_current_level, but for types. */
5269
5270 tree
5271 lookup_type_current_level (name)
5272 tree name;
5273 {
5274 register tree t = NULL_TREE;
5275
5276 my_friendly_assert (! current_binding_level->namespace_p, 980716);
5277
5278 if (REAL_IDENTIFIER_TYPE_VALUE (name) != NULL_TREE
5279 && REAL_IDENTIFIER_TYPE_VALUE (name) != global_type_node)
5280 {
5281 struct binding_level *b = current_binding_level;
5282 while (1)
5283 {
5284 if (purpose_member (name, b->type_shadowed))
5285 return REAL_IDENTIFIER_TYPE_VALUE (name);
5286 if (b->keep == 2)
5287 b = b->level_chain;
5288 else
5289 break;
5290 }
5291 }
5292
5293 return t;
5294 }
5295
5296 void
5297 begin_only_namespace_names ()
5298 {
5299 only_namespace_names = 1;
5300 }
5301
5302 void
5303 end_only_namespace_names ()
5304 {
5305 only_namespace_names = 0;
5306 }
5307 \f
5308 /* Arrange for the user to get a source line number, even when the
5309 compiler is going down in flames, so that she at least has a
5310 chance of working around problems in the compiler. We used to
5311 call error(), but that let the segmentation fault continue
5312 through; now, it's much more passive by asking them to send the
5313 maintainers mail about the problem. */
5314
5315 static void
5316 signal_catch (sig)
5317 int sig ATTRIBUTE_UNUSED;
5318 {
5319 signal (SIGSEGV, SIG_DFL);
5320 #ifdef SIGIOT
5321 signal (SIGIOT, SIG_DFL);
5322 #endif
5323 #ifdef SIGILL
5324 signal (SIGILL, SIG_DFL);
5325 #endif
5326 #ifdef SIGABRT
5327 signal (SIGABRT, SIG_DFL);
5328 #endif
5329 #ifdef SIGBUS
5330 signal (SIGBUS, SIG_DFL);
5331 #endif
5332 my_friendly_abort (0);
5333 }
5334
5335 #if 0
5336 /* Unused -- brendan 970107 */
5337 /* Array for holding types considered "built-in". These types
5338 are output in the module in which `main' is defined. */
5339 static tree *builtin_type_tdescs_arr;
5340 static int builtin_type_tdescs_len, builtin_type_tdescs_max;
5341 #endif
5342
5343 /* Push the declarations of builtin types into the namespace.
5344 RID_INDEX, if < RID_MAX is the index of the builtin type
5345 in the array RID_POINTERS. NAME is the name used when looking
5346 up the builtin type. TYPE is the _TYPE node for the builtin type. */
5347
5348 static void
5349 record_builtin_type (rid_index, name, type)
5350 enum rid rid_index;
5351 char *name;
5352 tree type;
5353 {
5354 tree rname = NULL_TREE, tname = NULL_TREE;
5355 tree tdecl = NULL_TREE;
5356
5357 if ((int) rid_index < (int) RID_MAX)
5358 rname = ridpointers[(int) rid_index];
5359 if (name)
5360 tname = get_identifier (name);
5361
5362 TYPE_BUILT_IN (type) = 1;
5363
5364 if (tname)
5365 {
5366 tdecl = pushdecl (build_decl (TYPE_DECL, tname, type));
5367 set_identifier_type_value (tname, NULL_TREE);
5368 if ((int) rid_index < (int) RID_MAX)
5369 /* Built-in types live in the global namespace. */
5370 SET_IDENTIFIER_GLOBAL_VALUE (tname, tdecl);
5371 }
5372 if (rname != NULL_TREE)
5373 {
5374 if (tname != NULL_TREE)
5375 {
5376 set_identifier_type_value (rname, NULL_TREE);
5377 SET_IDENTIFIER_GLOBAL_VALUE (rname, tdecl);
5378 }
5379 else
5380 {
5381 tdecl = pushdecl (build_decl (TYPE_DECL, rname, type));
5382 set_identifier_type_value (rname, NULL_TREE);
5383 }
5384 }
5385 }
5386
5387 /* Record one of the standard Java types.
5388 * Declare it as having the given NAME.
5389 * If SIZE > 0, it is the size of one of the integral types;
5390 * otherwise it is the negative of the size of one of the other types. */
5391
5392 static tree
5393 record_builtin_java_type (name, size)
5394 char *name;
5395 int size;
5396 {
5397 tree type, decl;
5398 if (size > 0)
5399 type = make_signed_type (size);
5400 else if (size > -32)
5401 { /* "__java_char" or ""__java_boolean". */
5402 type = make_unsigned_type (-size);
5403 /*if (size == -1) TREE_SET_CODE (type, BOOLEAN_TYPE);*/
5404 }
5405 else
5406 { /* "__java_float" or ""__java_double". */
5407 type = make_node (REAL_TYPE);
5408 TYPE_PRECISION (type) = - size;
5409 layout_type (type);
5410 }
5411 record_builtin_type (RID_MAX, name, type);
5412 decl = TYPE_NAME (type);
5413 DECL_IGNORED_P (decl) = 1;
5414 TYPE_FOR_JAVA (type) = 1;
5415 return type;
5416 }
5417
5418 /* Push a type into the namespace so that the back-ends ignore it. */
5419
5420 static void
5421 record_unknown_type (type, name)
5422 tree type;
5423 char *name;
5424 {
5425 tree decl = pushdecl (build_decl (TYPE_DECL, get_identifier (name), type));
5426 /* Make sure the "unknown type" typedecl gets ignored for debug info. */
5427 DECL_IGNORED_P (decl) = 1;
5428 TYPE_DECL_SUPPRESS_DEBUG (decl) = 1;
5429 TYPE_SIZE (type) = TYPE_SIZE (void_type_node);
5430 TYPE_ALIGN (type) = 1;
5431 TYPE_MODE (type) = TYPE_MODE (void_type_node);
5432 }
5433
5434 /* Push overloaded decl, in global scope, with one argument so it
5435 can be used as a callback from define_function. */
5436
5437 static void
5438 push_overloaded_decl_1 (x)
5439 tree x;
5440 {
5441 push_overloaded_decl (x, 0);
5442 }
5443
5444 #ifdef __GNUC__
5445 __inline
5446 #endif
5447 tree
5448 auto_function (name, type, code)
5449 tree name, type;
5450 enum built_in_function code;
5451 {
5452 return define_function
5453 (IDENTIFIER_POINTER (name), type, code, push_overloaded_decl_1,
5454 IDENTIFIER_POINTER (build_decl_overload (name, TYPE_ARG_TYPES (type),
5455 0)));
5456 }
5457
5458 /* Create the predefined scalar types of C,
5459 and some nodes representing standard constants (0, 1, (void *)0).
5460 Initialize the global binding level.
5461 Make definitions for built-in primitive functions. */
5462
5463 void
5464 init_decl_processing ()
5465 {
5466 register tree endlink, int_endlink, double_endlink, unsigned_endlink;
5467 tree fields[20];
5468 /* Data type of memcpy. */
5469 tree memcpy_ftype, strlen_ftype;
5470 int wchar_type_size;
5471 tree temp;
5472 tree array_domain_type;
5473 extern int flag_strict_prototype;
5474 tree vb_off_identifier = NULL_TREE;
5475 /* Function type `char *(char *, char *)' and similar ones */
5476 tree string_ftype_ptr_ptr, int_ftype_string_string;
5477 tree sizetype_endlink;
5478 tree ptr_ftype, ptr_ftype_unsigned, ptr_ftype_sizetype;
5479 tree void_ftype, void_ftype_int, void_ftype_ptr, ptr_ftype_void;
5480
5481 /* Have to make these distinct before we try using them. */
5482 lang_name_cplusplus = get_identifier ("C++");
5483 lang_name_c = get_identifier ("C");
5484 lang_name_java = get_identifier ("Java");
5485
5486 /* Enter the global namespace. */
5487 my_friendly_assert (global_namespace == NULL_TREE, 375);
5488 my_friendly_assert (current_lang_name == NULL_TREE, 375);
5489 current_lang_name = lang_name_cplusplus;
5490 push_namespace (get_identifier ("::"));
5491 global_namespace = current_namespace;
5492 current_lang_name = NULL_TREE;
5493
5494 if (flag_strict_prototype == 2)
5495 {
5496 if (pedantic)
5497 strict_prototypes_lang_c = strict_prototypes_lang_cplusplus;
5498 }
5499 else
5500 strict_prototypes_lang_c = flag_strict_prototype;
5501
5502 /* Initially, C. */
5503 current_lang_name = lang_name_c;
5504
5505 current_function_decl = NULL_TREE;
5506 named_labels = NULL_TREE;
5507 named_label_uses = NULL;
5508 current_binding_level = NULL_BINDING_LEVEL;
5509 free_binding_level = NULL_BINDING_LEVEL;
5510
5511 #ifndef __CYGWIN32__
5512 /* Because most segmentation signals can be traced back into user
5513 code, catch them and at least give the user a chance of working
5514 around compiler bugs. */
5515 signal (SIGSEGV, signal_catch);
5516
5517 /* We will also catch aborts in the back-end through signal_catch and
5518 give the user a chance to see where the error might be, and to defeat
5519 aborts in the back-end when there have been errors previously in their
5520 code. */
5521 #ifdef SIGIOT
5522 signal (SIGIOT, signal_catch);
5523 #endif
5524 #ifdef SIGILL
5525 signal (SIGILL, signal_catch);
5526 #endif
5527 #ifdef SIGABRT
5528 signal (SIGABRT, signal_catch);
5529 #endif
5530 #ifdef SIGBUS
5531 signal (SIGBUS, signal_catch);
5532 #endif
5533 #else /* ndef __CYGWIN32__ */
5534 /* Cygwin32 cannot handle catching signals other than
5535 SIGABRT yet. We hope this will cease to be the case soon. */
5536 #ifdef SIGABRT
5537 signal (SIGABRT, signal_catch);
5538 #endif
5539 #endif /* ndef __CYGWIN32__ */
5540
5541 gcc_obstack_init (&decl_obstack);
5542
5543 /* Must lay these out before anything else gets laid out. */
5544 error_mark_node = make_node (ERROR_MARK);
5545 TREE_PERMANENT (error_mark_node) = 1;
5546 TREE_TYPE (error_mark_node) = error_mark_node;
5547 error_mark_list = build_tree_list (error_mark_node, error_mark_node);
5548 TREE_TYPE (error_mark_list) = error_mark_node;
5549
5550 /* Make the binding_level structure for global names. */
5551 pushlevel (0);
5552 global_binding_level = current_binding_level;
5553 /* The global level is the namespace level of ::. */
5554 NAMESPACE_LEVEL (global_namespace) = global_binding_level;
5555 declare_namespace_level ();
5556
5557 this_identifier = get_identifier (THIS_NAME);
5558 in_charge_identifier = get_identifier (IN_CHARGE_NAME);
5559 ctor_identifier = get_identifier (CTOR_NAME);
5560 dtor_identifier = get_identifier (DTOR_NAME);
5561 pfn_identifier = get_identifier (VTABLE_PFN_NAME);
5562 index_identifier = get_identifier (VTABLE_INDEX_NAME);
5563 delta_identifier = get_identifier (VTABLE_DELTA_NAME);
5564 delta2_identifier = get_identifier (VTABLE_DELTA2_NAME);
5565 pfn_or_delta2_identifier = get_identifier ("__pfn_or_delta2");
5566 if (flag_handle_signatures)
5567 {
5568 tag_identifier = get_identifier (SIGTABLE_TAG_NAME);
5569 vb_off_identifier = get_identifier (SIGTABLE_VB_OFF_NAME);
5570 vt_off_identifier = get_identifier (SIGTABLE_VT_OFF_NAME);
5571 }
5572
5573 /* Define `int' and `char' first so that dbx will output them first. */
5574
5575 integer_type_node = make_signed_type (INT_TYPE_SIZE);
5576 record_builtin_type (RID_INT, NULL_PTR, integer_type_node);
5577
5578 /* Define `char', which is like either `signed char' or `unsigned char'
5579 but not the same as either. */
5580
5581 char_type_node
5582 = (flag_signed_char
5583 ? make_signed_type (CHAR_TYPE_SIZE)
5584 : make_unsigned_type (CHAR_TYPE_SIZE));
5585 record_builtin_type (RID_CHAR, "char", char_type_node);
5586
5587 long_integer_type_node = make_signed_type (LONG_TYPE_SIZE);
5588 record_builtin_type (RID_LONG, "long int", long_integer_type_node);
5589
5590 unsigned_type_node = make_unsigned_type (INT_TYPE_SIZE);
5591 record_builtin_type (RID_UNSIGNED, "unsigned int", unsigned_type_node);
5592
5593 long_unsigned_type_node = make_unsigned_type (LONG_TYPE_SIZE);
5594 record_builtin_type (RID_MAX, "long unsigned int", long_unsigned_type_node);
5595 record_builtin_type (RID_MAX, "unsigned long", long_unsigned_type_node);
5596
5597 long_long_integer_type_node = make_signed_type (LONG_LONG_TYPE_SIZE);
5598 record_builtin_type (RID_MAX, "long long int", long_long_integer_type_node);
5599
5600 long_long_unsigned_type_node = make_unsigned_type (LONG_LONG_TYPE_SIZE);
5601 record_builtin_type (RID_MAX, "long long unsigned int",
5602 long_long_unsigned_type_node);
5603 record_builtin_type (RID_MAX, "long long unsigned",
5604 long_long_unsigned_type_node);
5605
5606 short_integer_type_node = make_signed_type (SHORT_TYPE_SIZE);
5607 record_builtin_type (RID_SHORT, "short int", short_integer_type_node);
5608 short_unsigned_type_node = make_unsigned_type (SHORT_TYPE_SIZE);
5609 record_builtin_type (RID_MAX, "short unsigned int", short_unsigned_type_node);
5610 record_builtin_type (RID_MAX, "unsigned short", short_unsigned_type_node);
5611
5612 /* `unsigned long' is the standard type for sizeof.
5613 Note that stddef.h uses `unsigned long',
5614 and this must agree, even if long and int are the same size. */
5615 set_sizetype
5616 (TREE_TYPE (IDENTIFIER_GLOBAL_VALUE (get_identifier (SIZE_TYPE))));
5617
5618 ptrdiff_type_node
5619 = TREE_TYPE (IDENTIFIER_GLOBAL_VALUE (get_identifier (PTRDIFF_TYPE)));
5620
5621 /* Define both `signed char' and `unsigned char'. */
5622 signed_char_type_node = make_signed_type (CHAR_TYPE_SIZE);
5623 record_builtin_type (RID_MAX, "signed char", signed_char_type_node);
5624 unsigned_char_type_node = make_unsigned_type (CHAR_TYPE_SIZE);
5625 record_builtin_type (RID_MAX, "unsigned char", unsigned_char_type_node);
5626
5627 /* These are types that type_for_size and type_for_mode use. */
5628 intQI_type_node = make_signed_type (GET_MODE_BITSIZE (QImode));
5629 pushdecl (build_decl (TYPE_DECL, NULL_TREE, intQI_type_node));
5630 intHI_type_node = make_signed_type (GET_MODE_BITSIZE (HImode));
5631 pushdecl (build_decl (TYPE_DECL, NULL_TREE, intHI_type_node));
5632 intSI_type_node = make_signed_type (GET_MODE_BITSIZE (SImode));
5633 pushdecl (build_decl (TYPE_DECL, NULL_TREE, intSI_type_node));
5634 intDI_type_node = make_signed_type (GET_MODE_BITSIZE (DImode));
5635 pushdecl (build_decl (TYPE_DECL, NULL_TREE, intDI_type_node));
5636 intTI_type_node = make_signed_type (GET_MODE_BITSIZE (TImode));
5637 pushdecl (build_decl (TYPE_DECL, NULL_TREE, intTI_type_node));
5638 unsigned_intQI_type_node = make_unsigned_type (GET_MODE_BITSIZE (QImode));
5639 pushdecl (build_decl (TYPE_DECL, NULL_TREE, unsigned_intQI_type_node));
5640 unsigned_intHI_type_node = make_unsigned_type (GET_MODE_BITSIZE (HImode));
5641 pushdecl (build_decl (TYPE_DECL, NULL_TREE, unsigned_intHI_type_node));
5642 unsigned_intSI_type_node = make_unsigned_type (GET_MODE_BITSIZE (SImode));
5643 pushdecl (build_decl (TYPE_DECL, NULL_TREE, unsigned_intSI_type_node));
5644 unsigned_intDI_type_node = make_unsigned_type (GET_MODE_BITSIZE (DImode));
5645 pushdecl (build_decl (TYPE_DECL, NULL_TREE, unsigned_intDI_type_node));
5646 unsigned_intTI_type_node = make_unsigned_type (GET_MODE_BITSIZE (TImode));
5647 pushdecl (build_decl (TYPE_DECL, NULL_TREE, unsigned_intTI_type_node));
5648
5649 float_type_node = make_node (REAL_TYPE);
5650 TYPE_PRECISION (float_type_node) = FLOAT_TYPE_SIZE;
5651 record_builtin_type (RID_FLOAT, NULL_PTR, float_type_node);
5652 layout_type (float_type_node);
5653
5654 double_type_node = make_node (REAL_TYPE);
5655 if (flag_short_double)
5656 TYPE_PRECISION (double_type_node) = FLOAT_TYPE_SIZE;
5657 else
5658 TYPE_PRECISION (double_type_node) = DOUBLE_TYPE_SIZE;
5659 record_builtin_type (RID_DOUBLE, NULL_PTR, double_type_node);
5660 layout_type (double_type_node);
5661
5662 long_double_type_node = make_node (REAL_TYPE);
5663 TYPE_PRECISION (long_double_type_node) = LONG_DOUBLE_TYPE_SIZE;
5664 record_builtin_type (RID_MAX, "long double", long_double_type_node);
5665 layout_type (long_double_type_node);
5666
5667 complex_integer_type_node = make_node (COMPLEX_TYPE);
5668 pushdecl (build_decl (TYPE_DECL, get_identifier ("complex int"),
5669 complex_integer_type_node));
5670 TREE_TYPE (complex_integer_type_node) = integer_type_node;
5671 layout_type (complex_integer_type_node);
5672
5673 complex_float_type_node = make_node (COMPLEX_TYPE);
5674 pushdecl (build_decl (TYPE_DECL, get_identifier ("complex float"),
5675 complex_float_type_node));
5676 TREE_TYPE (complex_float_type_node) = float_type_node;
5677 layout_type (complex_float_type_node);
5678
5679 complex_double_type_node = make_node (COMPLEX_TYPE);
5680 pushdecl (build_decl (TYPE_DECL, get_identifier ("complex double"),
5681 complex_double_type_node));
5682 TREE_TYPE (complex_double_type_node) = double_type_node;
5683 layout_type (complex_double_type_node);
5684
5685 complex_long_double_type_node = make_node (COMPLEX_TYPE);
5686 pushdecl (build_decl (TYPE_DECL, get_identifier ("complex long double"),
5687 complex_long_double_type_node));
5688 TREE_TYPE (complex_long_double_type_node) = long_double_type_node;
5689 layout_type (complex_long_double_type_node);
5690
5691 java_byte_type_node = record_builtin_java_type ("__java_byte", 8);
5692 java_short_type_node = record_builtin_java_type ("__java_short", 16);
5693 java_int_type_node = record_builtin_java_type ("__java_int", 32);
5694 java_long_type_node = record_builtin_java_type ("__java_long", 64);
5695 java_float_type_node = record_builtin_java_type ("__java_float", -32);
5696 java_double_type_node = record_builtin_java_type ("__java_double", -64);
5697 java_char_type_node = record_builtin_java_type ("__java_char", -16);
5698 java_boolean_type_node = record_builtin_java_type ("__java_boolean", -1);
5699
5700 integer_zero_node = build_int_2 (0, 0);
5701 TREE_TYPE (integer_zero_node) = integer_type_node;
5702 integer_one_node = build_int_2 (1, 0);
5703 TREE_TYPE (integer_one_node) = integer_type_node;
5704 integer_two_node = build_int_2 (2, 0);
5705 TREE_TYPE (integer_two_node) = integer_type_node;
5706 integer_three_node = build_int_2 (3, 0);
5707 TREE_TYPE (integer_three_node) = integer_type_node;
5708
5709 boolean_type_node = make_unsigned_type (BOOL_TYPE_SIZE);
5710 TREE_SET_CODE (boolean_type_node, BOOLEAN_TYPE);
5711 TYPE_MAX_VALUE (boolean_type_node) = build_int_2 (1, 0);
5712 TREE_TYPE (TYPE_MAX_VALUE (boolean_type_node)) = boolean_type_node;
5713 TYPE_PRECISION (boolean_type_node) = 1;
5714 record_builtin_type (RID_BOOL, "bool", boolean_type_node);
5715 boolean_false_node = build_int_2 (0, 0);
5716 TREE_TYPE (boolean_false_node) = boolean_type_node;
5717 boolean_true_node = build_int_2 (1, 0);
5718 TREE_TYPE (boolean_true_node) = boolean_type_node;
5719
5720 /* These are needed by stor-layout.c. */
5721 size_zero_node = size_int (0);
5722 size_one_node = size_int (1);
5723
5724 signed_size_zero_node = build_int_2 (0, 0);
5725 TREE_TYPE (signed_size_zero_node) = make_signed_type (TYPE_PRECISION (sizetype));
5726
5727 void_type_node = make_node (VOID_TYPE);
5728 record_builtin_type (RID_VOID, NULL_PTR, void_type_node);
5729 layout_type (void_type_node); /* Uses integer_zero_node. */
5730 void_list_node = build_tree_list (NULL_TREE, void_type_node);
5731 TREE_PARMLIST (void_list_node) = 1;
5732
5733 null_pointer_node = build_int_2 (0, 0);
5734 TREE_TYPE (null_pointer_node) = build_pointer_type (void_type_node);
5735 layout_type (TREE_TYPE (null_pointer_node));
5736
5737 /* Used for expressions that do nothing, but are not errors. */
5738 void_zero_node = build_int_2 (0, 0);
5739 TREE_TYPE (void_zero_node) = void_type_node;
5740
5741 string_type_node = build_pointer_type (char_type_node);
5742 const_string_type_node
5743 = build_pointer_type (build_type_variant (char_type_node, 1, 0));
5744 #if 0
5745 record_builtin_type (RID_MAX, NULL_PTR, string_type_node);
5746 #endif
5747
5748 /* Make a type to be the domain of a few array types
5749 whose domains don't really matter.
5750 200 is small enough that it always fits in size_t
5751 and large enough that it can hold most function names for the
5752 initializations of __FUNCTION__ and __PRETTY_FUNCTION__. */
5753 array_domain_type = build_index_type (build_int_2 (200, 0));
5754
5755 /* Make a type for arrays of characters.
5756 With luck nothing will ever really depend on the length of this
5757 array type. */
5758 char_array_type_node
5759 = build_array_type (char_type_node, array_domain_type);
5760 /* Likewise for arrays of ints. */
5761 int_array_type_node
5762 = build_array_type (integer_type_node, array_domain_type);
5763
5764 /* This is just some anonymous class type. Nobody should ever
5765 need to look inside this envelope. */
5766 class_star_type_node = build_pointer_type (make_lang_type (RECORD_TYPE));
5767
5768 default_function_type
5769 = build_function_type (integer_type_node, NULL_TREE);
5770
5771 ptr_type_node = build_pointer_type (void_type_node);
5772 const_ptr_type_node
5773 = build_pointer_type (build_type_variant (void_type_node, 1, 0));
5774 #if 0
5775 record_builtin_type (RID_MAX, NULL_PTR, ptr_type_node);
5776 #endif
5777 endlink = void_list_node;
5778 int_endlink = tree_cons (NULL_TREE, integer_type_node, endlink);
5779 double_endlink = tree_cons (NULL_TREE, double_type_node, endlink);
5780 unsigned_endlink = tree_cons (NULL_TREE, unsigned_type_node, endlink);
5781
5782 ptr_ftype = build_function_type (ptr_type_node, NULL_TREE);
5783 ptr_ftype_unsigned = build_function_type (ptr_type_node, unsigned_endlink);
5784 sizetype_endlink = tree_cons (NULL_TREE, sizetype, endlink);
5785 /* We realloc here because sizetype could be int or unsigned. S'ok. */
5786 ptr_ftype_sizetype = build_function_type (ptr_type_node, sizetype_endlink);
5787
5788 void_ftype = build_function_type (void_type_node, endlink);
5789 void_ftype_int = build_function_type (void_type_node, int_endlink);
5790 void_ftype_ptr
5791 = build_function_type (void_type_node,
5792 tree_cons (NULL_TREE, ptr_type_node, endlink));
5793 void_ftype_ptr
5794 = build_exception_variant (void_ftype_ptr,
5795 tree_cons (NULL_TREE, NULL_TREE, NULL_TREE));
5796
5797 float_ftype_float
5798 = build_function_type (float_type_node,
5799 tree_cons (NULL_TREE, float_type_node, endlink));
5800
5801 double_ftype_double
5802 = build_function_type (double_type_node, double_endlink);
5803
5804 ldouble_ftype_ldouble
5805 = build_function_type (long_double_type_node,
5806 tree_cons (NULL_TREE, long_double_type_node,
5807 endlink));
5808
5809 double_ftype_double_double
5810 = build_function_type (double_type_node,
5811 tree_cons (NULL_TREE, double_type_node,
5812 double_endlink));
5813
5814 int_ftype_int
5815 = build_function_type (integer_type_node, int_endlink);
5816
5817 long_ftype_long
5818 = build_function_type (long_integer_type_node,
5819 tree_cons (NULL_TREE, long_integer_type_node,
5820 endlink));
5821
5822 int_ftype_cptr_cptr_sizet
5823 = build_function_type (integer_type_node,
5824 tree_cons (NULL_TREE, const_ptr_type_node,
5825 tree_cons (NULL_TREE, const_ptr_type_node,
5826 tree_cons (NULL_TREE,
5827 sizetype,
5828 endlink))));
5829
5830 string_ftype_ptr_ptr /* strcpy prototype */
5831 = build_function_type (string_type_node,
5832 tree_cons (NULL_TREE, string_type_node,
5833 tree_cons (NULL_TREE,
5834 const_string_type_node,
5835 endlink)));
5836
5837 int_ftype_string_string /* strcmp prototype */
5838 = build_function_type (integer_type_node,
5839 tree_cons (NULL_TREE, const_string_type_node,
5840 tree_cons (NULL_TREE,
5841 const_string_type_node,
5842 endlink)));
5843
5844 strlen_ftype /* strlen prototype */
5845 = build_function_type (sizetype,
5846 tree_cons (NULL_TREE, const_string_type_node,
5847 endlink));
5848
5849 memcpy_ftype /* memcpy prototype */
5850 = build_function_type (ptr_type_node,
5851 tree_cons (NULL_TREE, ptr_type_node,
5852 tree_cons (NULL_TREE, const_ptr_type_node,
5853 sizetype_endlink)));
5854
5855 if (flag_huge_objects)
5856 delta_type_node = long_integer_type_node;
5857 else
5858 delta_type_node = short_integer_type_node;
5859
5860 builtin_function ("__builtin_constant_p", default_function_type,
5861 BUILT_IN_CONSTANT_P, NULL_PTR);
5862
5863 builtin_return_address_fndecl
5864 = builtin_function ("__builtin_return_address", ptr_ftype_unsigned,
5865 BUILT_IN_RETURN_ADDRESS, NULL_PTR);
5866
5867 builtin_function ("__builtin_frame_address", ptr_ftype_unsigned,
5868 BUILT_IN_FRAME_ADDRESS, NULL_PTR);
5869
5870 ptr_ftype_void = build_function_type (ptr_type_node, endlink);
5871 builtin_function ("__builtin_fp", ptr_ftype_void, BUILT_IN_FP, NULL_PTR);
5872 builtin_function ("__builtin_sp", ptr_ftype_void, BUILT_IN_SP, NULL_PTR);
5873
5874 builtin_function ("__builtin_alloca", ptr_ftype_sizetype,
5875 BUILT_IN_ALLOCA, "alloca");
5876 builtin_function ("__builtin_ffs", int_ftype_int, BUILT_IN_FFS, NULL_PTR);
5877 /* Define alloca, ffs as builtins.
5878 Declare _exit just to mark it as volatile. */
5879 if (! flag_no_builtin && !flag_no_nonansi_builtin)
5880 {
5881 temp = builtin_function ("alloca", ptr_ftype_sizetype,
5882 BUILT_IN_ALLOCA, NULL_PTR);
5883 /* Suppress error if redefined as a non-function. */
5884 DECL_BUILT_IN_NONANSI (temp) = 1;
5885 temp = builtin_function ("ffs", int_ftype_int, BUILT_IN_FFS, NULL_PTR);
5886 /* Suppress error if redefined as a non-function. */
5887 DECL_BUILT_IN_NONANSI (temp) = 1;
5888 temp = builtin_function ("_exit", void_ftype_int,
5889 NOT_BUILT_IN, NULL_PTR);
5890 TREE_THIS_VOLATILE (temp) = 1;
5891 TREE_SIDE_EFFECTS (temp) = 1;
5892 /* Suppress error if redefined as a non-function. */
5893 DECL_BUILT_IN_NONANSI (temp) = 1;
5894 }
5895
5896 builtin_function ("__builtin_abs", int_ftype_int, BUILT_IN_ABS, NULL_PTR);
5897 builtin_function ("__builtin_fabsf", float_ftype_float, BUILT_IN_FABS,
5898 NULL_PTR);
5899 builtin_function ("__builtin_fabs", double_ftype_double, BUILT_IN_FABS,
5900 NULL_PTR);
5901 builtin_function ("__builtin_fabsl", ldouble_ftype_ldouble, BUILT_IN_FABS,
5902 NULL_PTR);
5903 builtin_function ("__builtin_labs", long_ftype_long,
5904 BUILT_IN_LABS, NULL_PTR);
5905 builtin_function ("__builtin_saveregs", ptr_ftype,
5906 BUILT_IN_SAVEREGS, NULL_PTR);
5907 builtin_function ("__builtin_classify_type", default_function_type,
5908 BUILT_IN_CLASSIFY_TYPE, NULL_PTR);
5909 builtin_function ("__builtin_next_arg", ptr_ftype,
5910 BUILT_IN_NEXT_ARG, NULL_PTR);
5911 builtin_function ("__builtin_args_info", int_ftype_int,
5912 BUILT_IN_ARGS_INFO, NULL_PTR);
5913 builtin_function ("__builtin_setjmp",
5914 build_function_type (integer_type_node,
5915 tree_cons (NULL_TREE, ptr_type_node,
5916 endlink)),
5917 BUILT_IN_SETJMP, NULL_PTR);
5918 builtin_function ("__builtin_longjmp",
5919 build_function_type (integer_type_node,
5920 tree_cons (NULL_TREE, ptr_type_node,
5921 tree_cons (NULL_TREE,
5922 integer_type_node,
5923 endlink))),
5924 BUILT_IN_LONGJMP, NULL_PTR);
5925
5926 /* Untyped call and return. */
5927 builtin_function ("__builtin_apply_args", ptr_ftype,
5928 BUILT_IN_APPLY_ARGS, NULL_PTR);
5929
5930 temp = tree_cons (NULL_TREE,
5931 build_pointer_type (build_function_type (void_type_node,
5932 NULL_TREE)),
5933 tree_cons (NULL_TREE, ptr_ftype_sizetype, NULL_TREE));
5934 builtin_function ("__builtin_apply",
5935 build_function_type (ptr_type_node, temp),
5936 BUILT_IN_APPLY, NULL_PTR);
5937 builtin_function ("__builtin_return", void_ftype_ptr,
5938 BUILT_IN_RETURN, NULL_PTR);
5939
5940 /* Currently under experimentation. */
5941 builtin_function ("__builtin_memcpy", memcpy_ftype,
5942 BUILT_IN_MEMCPY, "memcpy");
5943 builtin_function ("__builtin_memcmp", int_ftype_cptr_cptr_sizet,
5944 BUILT_IN_MEMCMP, "memcmp");
5945 builtin_function ("__builtin_strcmp", int_ftype_string_string,
5946 BUILT_IN_STRCMP, "strcmp");
5947 builtin_function ("__builtin_strcpy", string_ftype_ptr_ptr,
5948 BUILT_IN_STRCPY, "strcpy");
5949 builtin_function ("__builtin_strlen", strlen_ftype,
5950 BUILT_IN_STRLEN, "strlen");
5951 builtin_function ("__builtin_sqrtf", float_ftype_float,
5952 BUILT_IN_FSQRT, "sqrtf");
5953 builtin_function ("__builtin_fsqrt", double_ftype_double,
5954 BUILT_IN_FSQRT, NULL_PTR);
5955 builtin_function ("__builtin_sqrtl", ldouble_ftype_ldouble,
5956 BUILT_IN_FSQRT, "sqrtl");
5957 builtin_function ("__builtin_sinf", float_ftype_float,
5958 BUILT_IN_SIN, "sinf");
5959 builtin_function ("__builtin_sin", double_ftype_double,
5960 BUILT_IN_SIN, "sin");
5961 builtin_function ("__builtin_sinl", ldouble_ftype_ldouble,
5962 BUILT_IN_SIN, "sinl");
5963 builtin_function ("__builtin_cosf", float_ftype_float,
5964 BUILT_IN_COS, "cosf");
5965 builtin_function ("__builtin_cos", double_ftype_double,
5966 BUILT_IN_COS, "cos");
5967 builtin_function ("__builtin_cosl", ldouble_ftype_ldouble,
5968 BUILT_IN_COS, "cosl");
5969
5970 if (!flag_no_builtin)
5971 {
5972 builtin_function ("abs", int_ftype_int, BUILT_IN_ABS, NULL_PTR);
5973 builtin_function ("fabs", double_ftype_double, BUILT_IN_FABS, NULL_PTR);
5974 builtin_function ("labs", long_ftype_long, BUILT_IN_LABS, NULL_PTR);
5975 builtin_function ("fabsf", float_ftype_float, BUILT_IN_FABS, NULL_PTR);
5976 builtin_function ("fabsl", ldouble_ftype_ldouble, BUILT_IN_FABS,
5977 NULL_PTR);
5978 builtin_function ("memcpy", memcpy_ftype, BUILT_IN_MEMCPY, NULL_PTR);
5979 builtin_function ("memcmp", int_ftype_cptr_cptr_sizet, BUILT_IN_MEMCMP,
5980 NULL_PTR);
5981 builtin_function ("strcmp", int_ftype_string_string, BUILT_IN_STRCMP,
5982 NULL_PTR);
5983 builtin_function ("strcpy", string_ftype_ptr_ptr, BUILT_IN_STRCPY,
5984 NULL_PTR);
5985 builtin_function ("strlen", strlen_ftype, BUILT_IN_STRLEN, NULL_PTR);
5986 builtin_function ("sqrtf", float_ftype_float, BUILT_IN_FSQRT, NULL_PTR);
5987 builtin_function ("sqrt", double_ftype_double, BUILT_IN_FSQRT, NULL_PTR);
5988 builtin_function ("sqrtl", ldouble_ftype_ldouble, BUILT_IN_FSQRT,
5989 NULL_PTR);
5990 builtin_function ("sinf", float_ftype_float, BUILT_IN_SIN, NULL_PTR);
5991 builtin_function ("sin", double_ftype_double, BUILT_IN_SIN, NULL_PTR);
5992 builtin_function ("sinl", ldouble_ftype_ldouble, BUILT_IN_SIN, NULL_PTR);
5993 builtin_function ("cosf", float_ftype_float, BUILT_IN_COS, NULL_PTR);
5994 builtin_function ("cos", double_ftype_double, BUILT_IN_COS, NULL_PTR);
5995 builtin_function ("cosl", ldouble_ftype_ldouble, BUILT_IN_COS, NULL_PTR);
5996
5997 /* Declare these functions volatile
5998 to avoid spurious "control drops through" warnings. */
5999 temp = builtin_function ("abort", void_ftype,
6000 NOT_BUILT_IN, NULL_PTR);
6001 TREE_THIS_VOLATILE (temp) = 1;
6002 TREE_SIDE_EFFECTS (temp) = 1;
6003 /* Well, these are actually ANSI, but we can't set DECL_BUILT_IN on
6004 them... */
6005 DECL_BUILT_IN_NONANSI (temp) = 1;
6006 temp = builtin_function ("exit", void_ftype_int,
6007 NOT_BUILT_IN, NULL_PTR);
6008 TREE_THIS_VOLATILE (temp) = 1;
6009 TREE_SIDE_EFFECTS (temp) = 1;
6010 DECL_BUILT_IN_NONANSI (temp) = 1;
6011 }
6012
6013 #if 0
6014 /* Support for these has not been written in either expand_builtin
6015 or build_function_call. */
6016 builtin_function ("__builtin_div", default_ftype, BUILT_IN_DIV, NULL_PTR);
6017 builtin_function ("__builtin_ldiv", default_ftype, BUILT_IN_LDIV, NULL_PTR);
6018 builtin_function ("__builtin_ffloor", double_ftype_double, BUILT_IN_FFLOOR,
6019 NULL_PTR);
6020 builtin_function ("__builtin_fceil", double_ftype_double, BUILT_IN_FCEIL,
6021 NULL_PTR);
6022 builtin_function ("__builtin_fmod", double_ftype_double_double,
6023 BUILT_IN_FMOD, NULL_PTR);
6024 builtin_function ("__builtin_frem", double_ftype_double_double,
6025 BUILT_IN_FREM, NULL_PTR);
6026 builtin_function ("__builtin_memset", ptr_ftype_ptr_int_int,
6027 BUILT_IN_MEMSET, NULL_PTR);
6028 builtin_function ("__builtin_getexp", double_ftype_double, BUILT_IN_GETEXP,
6029 NULL_PTR);
6030 builtin_function ("__builtin_getman", double_ftype_double, BUILT_IN_GETMAN,
6031 NULL_PTR);
6032 #endif
6033
6034 /* C++ extensions */
6035
6036 unknown_type_node = make_node (UNKNOWN_TYPE);
6037 record_unknown_type (unknown_type_node, "unknown type");
6038
6039 /* Indirecting an UNKNOWN_TYPE node yields an UNKNOWN_TYPE node. */
6040 TREE_TYPE (unknown_type_node) = unknown_type_node;
6041
6042 TREE_TYPE (null_node) = type_for_size (POINTER_SIZE, 0);
6043
6044 /* Looking up TYPE_POINTER_TO and TYPE_REFERENCE_TO yield the same
6045 result. */
6046 TYPE_POINTER_TO (unknown_type_node) = unknown_type_node;
6047 TYPE_REFERENCE_TO (unknown_type_node) = unknown_type_node;
6048
6049 /* This is for handling opaque types in signatures. */
6050 opaque_type_node = copy_node (ptr_type_node);
6051 TYPE_MAIN_VARIANT (opaque_type_node) = opaque_type_node;
6052 record_builtin_type (RID_MAX, 0, opaque_type_node);
6053
6054 /* This is special for C++ so functions can be overloaded. */
6055 wchar_type_node
6056 = TREE_TYPE (IDENTIFIER_GLOBAL_VALUE (get_identifier (WCHAR_TYPE)));
6057 wchar_type_size = TYPE_PRECISION (wchar_type_node);
6058 signed_wchar_type_node = make_signed_type (wchar_type_size);
6059 unsigned_wchar_type_node = make_unsigned_type (wchar_type_size);
6060 wchar_type_node
6061 = TREE_UNSIGNED (wchar_type_node)
6062 ? unsigned_wchar_type_node
6063 : signed_wchar_type_node;
6064 record_builtin_type (RID_WCHAR, "__wchar_t", wchar_type_node);
6065
6066 /* Artificial declaration of wchar_t -- can be bashed */
6067 wchar_decl_node = build_decl (TYPE_DECL, get_identifier ("wchar_t"),
6068 wchar_type_node);
6069 pushdecl (wchar_decl_node);
6070
6071 /* This is for wide string constants. */
6072 wchar_array_type_node
6073 = build_array_type (wchar_type_node, array_domain_type);
6074
6075 if (flag_vtable_thunks)
6076 {
6077 /* Make sure we get a unique function type, so we can give
6078 its pointer type a name. (This wins for gdb.) */
6079 tree vfunc_type = make_node (FUNCTION_TYPE);
6080 TREE_TYPE (vfunc_type) = integer_type_node;
6081 TYPE_ARG_TYPES (vfunc_type) = NULL_TREE;
6082 layout_type (vfunc_type);
6083
6084 vtable_entry_type = build_pointer_type (vfunc_type);
6085 }
6086 else
6087 {
6088 vtable_entry_type = make_lang_type (RECORD_TYPE);
6089 fields[0] = build_lang_field_decl (FIELD_DECL, delta_identifier,
6090 delta_type_node);
6091 fields[1] = build_lang_field_decl (FIELD_DECL, index_identifier,
6092 delta_type_node);
6093 fields[2] = build_lang_field_decl (FIELD_DECL, pfn_identifier,
6094 ptr_type_node);
6095 finish_builtin_type (vtable_entry_type, VTBL_PTR_TYPE, fields, 2,
6096 double_type_node);
6097
6098 /* Make this part of an invisible union. */
6099 fields[3] = copy_node (fields[2]);
6100 TREE_TYPE (fields[3]) = delta_type_node;
6101 DECL_NAME (fields[3]) = delta2_identifier;
6102 DECL_MODE (fields[3]) = TYPE_MODE (delta_type_node);
6103 DECL_SIZE (fields[3]) = TYPE_SIZE (delta_type_node);
6104 TREE_UNSIGNED (fields[3]) = 0;
6105 TREE_CHAIN (fields[2]) = fields[3];
6106 vtable_entry_type = build_type_variant (vtable_entry_type, 1, 0);
6107 }
6108 record_builtin_type (RID_MAX, VTBL_PTR_TYPE, vtable_entry_type);
6109
6110 vtbl_type_node
6111 = build_array_type (vtable_entry_type, NULL_TREE);
6112 layout_type (vtbl_type_node);
6113 vtbl_type_node = cp_build_type_variant (vtbl_type_node, 1, 0);
6114 record_builtin_type (RID_MAX, NULL_PTR, vtbl_type_node);
6115
6116 /* Simplify life by making a "sigtable_entry_type". Give its
6117 fields names so that the debugger can use them. */
6118
6119 if (flag_handle_signatures)
6120 {
6121 sigtable_entry_type = make_lang_type (RECORD_TYPE);
6122 fields[0] = build_lang_field_decl (FIELD_DECL, tag_identifier,
6123 delta_type_node);
6124 fields[1] = build_lang_field_decl (FIELD_DECL, vb_off_identifier,
6125 delta_type_node);
6126 fields[2] = build_lang_field_decl (FIELD_DECL, delta_identifier,
6127 delta_type_node);
6128 fields[3] = build_lang_field_decl (FIELD_DECL, index_identifier,
6129 delta_type_node);
6130 fields[4] = build_lang_field_decl (FIELD_DECL, pfn_identifier,
6131 ptr_type_node);
6132
6133 /* Set the alignment to the max of the alignment of ptr_type_node and
6134 delta_type_node. Double alignment wastes a word on the Sparc. */
6135 finish_builtin_type (sigtable_entry_type, SIGTABLE_PTR_TYPE, fields, 4,
6136 (TYPE_ALIGN (ptr_type_node) > TYPE_ALIGN (delta_type_node))
6137 ? ptr_type_node
6138 : delta_type_node);
6139
6140 /* Make this part of an invisible union. */
6141 fields[5] = copy_node (fields[4]);
6142 TREE_TYPE (fields[5]) = delta_type_node;
6143 DECL_NAME (fields[5]) = vt_off_identifier;
6144 DECL_MODE (fields[5]) = TYPE_MODE (delta_type_node);
6145 DECL_SIZE (fields[5]) = TYPE_SIZE (delta_type_node);
6146 TREE_UNSIGNED (fields[5]) = 0;
6147 TREE_CHAIN (fields[4]) = fields[5];
6148
6149 sigtable_entry_type = build_type_variant (sigtable_entry_type, 1, 0);
6150 record_builtin_type (RID_MAX, SIGTABLE_PTR_TYPE, sigtable_entry_type);
6151 }
6152
6153 std_node = build_decl (NAMESPACE_DECL,
6154 get_identifier (flag_honor_std ? "fake std":"std"),
6155 void_type_node);
6156 pushdecl (std_node);
6157
6158 global_type_node = make_node (LANG_TYPE);
6159 record_unknown_type (global_type_node, "global type");
6160
6161 /* Now, C++. */
6162 current_lang_name = lang_name_cplusplus;
6163
6164 {
6165 tree bad_alloc_type_node, newtype, deltype;
6166 if (flag_honor_std)
6167 push_namespace (get_identifier ("std"));
6168 bad_alloc_type_node = xref_tag
6169 (class_type_node, get_identifier ("bad_alloc"), 1);
6170 if (flag_honor_std)
6171 pop_namespace ();
6172 newtype = build_exception_variant
6173 (ptr_ftype_sizetype, build_tree_list (NULL_TREE, bad_alloc_type_node));
6174 deltype = build_exception_variant
6175 (void_ftype_ptr, build_tree_list (NULL_TREE, NULL_TREE));
6176 auto_function (ansi_opname[(int) NEW_EXPR], newtype, NOT_BUILT_IN);
6177 auto_function (ansi_opname[(int) VEC_NEW_EXPR], newtype, NOT_BUILT_IN);
6178 auto_function (ansi_opname[(int) DELETE_EXPR], deltype, NOT_BUILT_IN);
6179 auto_function (ansi_opname[(int) VEC_DELETE_EXPR], deltype, NOT_BUILT_IN);
6180 }
6181
6182 abort_fndecl
6183 = define_function ("__pure_virtual", void_ftype,
6184 NOT_BUILT_IN, 0, 0);
6185
6186 /* Perform other language dependent initializations. */
6187 init_class_processing ();
6188 init_init_processing ();
6189 init_search_processing ();
6190 if (flag_rtti)
6191 init_rtti_processing ();
6192
6193 if (flag_exceptions)
6194 init_exception_processing ();
6195 if (flag_no_inline)
6196 {
6197 flag_inline_functions = 0;
6198 }
6199
6200 if (! supports_one_only ())
6201 flag_weak = 0;
6202
6203 /* Create the global bindings for __FUNCTION__ and __PRETTY_FUNCTION__. */
6204 declare_function_name ();
6205
6206 /* Prepare to check format strings against argument lists. */
6207 init_function_format_info ();
6208
6209 /* Show we use EH for cleanups. */
6210 using_eh_for_cleanups ();
6211
6212 print_error_function = lang_print_error_function;
6213 lang_get_alias_set = &c_get_alias_set;
6214
6215 /* Maintain consistency. Perhaps we should just complain if they
6216 say -fwritable-strings? */
6217 if (flag_writable_strings)
6218 flag_const_strings = 0;
6219 }
6220
6221 /* Function to print any language-specific context for an error message. */
6222
6223 static void
6224 lang_print_error_function (file)
6225 char *file;
6226 {
6227 default_print_error_function (file);
6228 maybe_print_template_context ();
6229 }
6230
6231 /* Make a definition for a builtin function named NAME and whose data type
6232 is TYPE. TYPE should be a function type with argument types.
6233 FUNCTION_CODE tells later passes how to compile calls to this function.
6234 See tree.h for its possible values.
6235
6236 If LIBRARY_NAME is nonzero, use that for DECL_ASSEMBLER_NAME,
6237 the name to be called if we can't opencode the function. */
6238
6239 tree
6240 define_function (name, type, function_code, pfn, library_name)
6241 char *name;
6242 tree type;
6243 enum built_in_function function_code;
6244 void (*pfn) PROTO((tree));
6245 char *library_name;
6246 {
6247 tree decl = build_lang_decl (FUNCTION_DECL, get_identifier (name), type);
6248 DECL_EXTERNAL (decl) = 1;
6249 TREE_PUBLIC (decl) = 1;
6250 DECL_ARTIFICIAL (decl) = 1;
6251
6252 my_friendly_assert (DECL_CONTEXT (decl) == NULL_TREE, 392);
6253 DECL_CONTEXT (decl) = FROB_CONTEXT (current_namespace);
6254
6255 /* Since `pushdecl' relies on DECL_ASSEMBLER_NAME instead of DECL_NAME,
6256 we cannot change DECL_ASSEMBLER_NAME until we have installed this
6257 function in the namespace. */
6258 if (pfn) (*pfn) (decl);
6259 if (library_name)
6260 DECL_ASSEMBLER_NAME (decl) = get_identifier (library_name);
6261 make_function_rtl (decl);
6262 if (function_code != NOT_BUILT_IN)
6263 {
6264 DECL_BUILT_IN (decl) = 1;
6265 DECL_FUNCTION_CODE (decl) = function_code;
6266 }
6267 return decl;
6268 }
6269 \f
6270 /* Called when a declaration is seen that contains no names to declare.
6271 If its type is a reference to a structure, union or enum inherited
6272 from a containing scope, shadow that tag name for the current scope
6273 with a forward reference.
6274 If its type defines a new named structure or union
6275 or defines an enum, it is valid but we need not do anything here.
6276 Otherwise, it is an error.
6277
6278 C++: may have to grok the declspecs to learn about static,
6279 complain for anonymous unions. */
6280
6281 void
6282 shadow_tag (declspecs)
6283 tree declspecs;
6284 {
6285 int found_tag = 0;
6286 tree ob_modifier = NULL_TREE;
6287 register tree link;
6288 register enum tree_code code, ok_code = ERROR_MARK;
6289 register tree t = NULL_TREE;
6290
6291 for (link = declspecs; link; link = TREE_CHAIN (link))
6292 {
6293 register tree value = TREE_VALUE (link);
6294
6295 code = TREE_CODE (value);
6296 if (IS_AGGR_TYPE_CODE (code) || code == ENUMERAL_TYPE)
6297 {
6298 my_friendly_assert (TYPE_MAIN_DECL (value) != NULL_TREE, 261);
6299
6300 maybe_process_partial_specialization (value);
6301
6302 t = value;
6303 ok_code = code;
6304 found_tag++;
6305 }
6306 else if (value == ridpointers[(int) RID_STATIC]
6307 || value == ridpointers[(int) RID_EXTERN]
6308 || value == ridpointers[(int) RID_AUTO]
6309 || value == ridpointers[(int) RID_REGISTER]
6310 || value == ridpointers[(int) RID_INLINE]
6311 || value == ridpointers[(int) RID_VIRTUAL]
6312 || value == ridpointers[(int) RID_EXPLICIT])
6313 ob_modifier = value;
6314 }
6315
6316 /* This is where the variables in an anonymous union are
6317 declared. An anonymous union declaration looks like:
6318 union { ... } ;
6319 because there is no declarator after the union, the parser
6320 sends that declaration here. */
6321 if (ok_code == UNION_TYPE
6322 && t != NULL_TREE
6323 && ((TREE_CODE (TYPE_NAME (t)) == IDENTIFIER_NODE
6324 && ANON_AGGRNAME_P (TYPE_NAME (t)))
6325 || (TREE_CODE (TYPE_NAME (t)) == TYPE_DECL
6326 && ANON_AGGRNAME_P (TYPE_IDENTIFIER (t)))))
6327 {
6328 /* See also grok_x_components. */
6329 tree *q;
6330
6331 /* Wipe out memory of synthesized methods */
6332 TYPE_HAS_CONSTRUCTOR (t) = 0;
6333 TYPE_HAS_DEFAULT_CONSTRUCTOR (t) = 0;
6334 TYPE_HAS_INIT_REF (t) = 0;
6335 TYPE_HAS_CONST_INIT_REF (t) = 0;
6336 TYPE_HAS_ASSIGN_REF (t) = 0;
6337 TYPE_HAS_ASSIGNMENT (t) = 0;
6338 TYPE_HAS_CONST_ASSIGN_REF (t) = 0;
6339
6340 q = &TYPE_METHODS (t);
6341 while (*q)
6342 {
6343 if (DECL_ARTIFICIAL (*q))
6344 *q = TREE_CHAIN (*q);
6345 else
6346 q = &TREE_CHAIN (*q);
6347 }
6348
6349 /* ANSI C++ June 5 1992 WP 9.5.3. Anonymous unions may not have
6350 function members. */
6351 if (TYPE_METHODS (t))
6352 error ("an anonymous union cannot have function members");
6353
6354 if (TYPE_FIELDS (t))
6355 {
6356 tree decl = grokdeclarator (NULL_TREE, declspecs, NORMAL, 0,
6357 NULL_TREE);
6358 finish_anon_union (decl);
6359 }
6360 }
6361 else
6362 {
6363 /* Anonymous unions are objects, that's why we only check for
6364 inappropriate specifiers in this branch. */
6365
6366 if (ob_modifier)
6367 {
6368 if (ob_modifier == ridpointers[(int) RID_INLINE]
6369 || ob_modifier == ridpointers[(int) RID_VIRTUAL])
6370 cp_error ("`%D' can only be specified for functions", ob_modifier);
6371 else if (ob_modifier == ridpointers[(int) RID_EXPLICIT])
6372 cp_error ("`%D' can only be specified for constructors",
6373 ob_modifier);
6374 else
6375 cp_error ("`%D' can only be specified for objects and functions",
6376 ob_modifier);
6377 }
6378
6379 if (found_tag == 0)
6380 cp_error ("abstract declarator used as declaration");
6381 else if (found_tag > 1)
6382 pedwarn ("multiple types in one declaration");
6383 }
6384 }
6385 \f
6386 /* Decode a "typename", such as "int **", returning a ..._TYPE node. */
6387
6388 tree
6389 groktypename (typename)
6390 tree typename;
6391 {
6392 if (TREE_CODE (typename) != TREE_LIST)
6393 return typename;
6394 return grokdeclarator (TREE_VALUE (typename),
6395 TREE_PURPOSE (typename),
6396 TYPENAME, 0, NULL_TREE);
6397 }
6398
6399 /* Decode a declarator in an ordinary declaration or data definition.
6400 This is called as soon as the type information and variable name
6401 have been parsed, before parsing the initializer if any.
6402 Here we create the ..._DECL node, fill in its type,
6403 and put it on the list of decls for the current context.
6404 The ..._DECL node is returned as the value.
6405
6406 Exception: for arrays where the length is not specified,
6407 the type is left null, to be filled in by `cp_finish_decl'.
6408
6409 Function definitions do not come here; they go to start_function
6410 instead. However, external and forward declarations of functions
6411 do go through here. Structure field declarations are done by
6412 grokfield and not through here. */
6413
6414 /* Set this to zero to debug not using the temporary obstack
6415 to parse initializers. */
6416 int debug_temp_inits = 1;
6417
6418 tree
6419 start_decl (declarator, declspecs, initialized, attributes, prefix_attributes)
6420 tree declarator, declspecs;
6421 int initialized;
6422 tree attributes, prefix_attributes;
6423 {
6424 register tree decl;
6425 register tree type, tem;
6426 tree context;
6427 extern int have_extern_spec;
6428 extern int used_extern_spec;
6429
6430 #if 0
6431 /* See code below that used this. */
6432 int init_written = initialized;
6433 #endif
6434
6435 /* This should only be done once on the top most decl. */
6436 if (have_extern_spec && !used_extern_spec)
6437 {
6438 declspecs = decl_tree_cons (NULL_TREE, get_identifier ("extern"),
6439 declspecs);
6440 used_extern_spec = 1;
6441 }
6442
6443 decl = grokdeclarator (declarator, declspecs, NORMAL, initialized,
6444 NULL_TREE);
6445 if (decl == NULL_TREE || TREE_CODE (decl) == VOID_TYPE)
6446 return NULL_TREE;
6447
6448 type = TREE_TYPE (decl);
6449
6450 /* Don't lose if destructors must be executed at file-level. */
6451 if (! processing_template_decl && TREE_STATIC (decl)
6452 && TYPE_NEEDS_DESTRUCTOR (complete_type (type))
6453 && !TREE_PERMANENT (decl))
6454 {
6455 push_obstacks (&permanent_obstack, &permanent_obstack);
6456 decl = copy_node (decl);
6457 if (TREE_CODE (type) == ARRAY_TYPE)
6458 {
6459 tree itype = TYPE_DOMAIN (type);
6460 if (itype && ! TREE_PERMANENT (itype))
6461 {
6462 itype = build_index_type (copy_to_permanent (TYPE_MAX_VALUE (itype)));
6463 type = build_cplus_array_type (TREE_TYPE (type), itype);
6464 TREE_TYPE (decl) = type;
6465 }
6466 }
6467 pop_obstacks ();
6468 }
6469
6470 context
6471 = (TREE_CODE (decl) == FUNCTION_DECL && DECL_VIRTUAL_P (decl))
6472 ? DECL_CLASS_CONTEXT (decl)
6473 : DECL_CONTEXT (decl);
6474
6475 if (initialized && context && TREE_CODE (context) == NAMESPACE_DECL
6476 && context != current_namespace && TREE_CODE (decl) == VAR_DECL)
6477 {
6478 /* When parsing the initializer, lookup should use the object's
6479 namespace. */
6480 push_decl_namespace (context);
6481 }
6482
6483 /* We are only interested in class contexts, later. */
6484 if (context && TREE_CODE (context) == NAMESPACE_DECL)
6485 context = NULL_TREE;
6486
6487 if (initialized)
6488 /* Is it valid for this decl to have an initializer at all?
6489 If not, set INITIALIZED to zero, which will indirectly
6490 tell `cp_finish_decl' to ignore the initializer once it is parsed. */
6491 switch (TREE_CODE (decl))
6492 {
6493 case TYPE_DECL:
6494 /* typedef foo = bar means give foo the same type as bar.
6495 We haven't parsed bar yet, so `cp_finish_decl' will fix that up.
6496 Any other case of an initialization in a TYPE_DECL is an error. */
6497 if (pedantic || list_length (declspecs) > 1)
6498 {
6499 cp_error ("typedef `%D' is initialized", decl);
6500 initialized = 0;
6501 }
6502 break;
6503
6504 case FUNCTION_DECL:
6505 cp_error ("function `%#D' is initialized like a variable", decl);
6506 initialized = 0;
6507 break;
6508
6509 default:
6510 if (! processing_template_decl)
6511 {
6512 if (type != error_mark_node)
6513 {
6514 if (TYPE_SIZE (type) != NULL_TREE
6515 && ! TREE_CONSTANT (TYPE_SIZE (type)))
6516 {
6517 cp_error
6518 ("variable-sized object `%D' may not be initialized",
6519 decl);
6520 initialized = 0;
6521 }
6522
6523 if (TREE_CODE (type) == ARRAY_TYPE
6524 && TYPE_SIZE (complete_type (TREE_TYPE (type))) == NULL_TREE)
6525 {
6526 cp_error
6527 ("elements of array `%#D' have incomplete type", decl);
6528 initialized = 0;
6529 }
6530 }
6531 }
6532 }
6533
6534 if (initialized)
6535 {
6536 if (! toplevel_bindings_p ()
6537 && DECL_EXTERNAL (decl))
6538 cp_warning ("declaration of `%#D' has `extern' and is initialized",
6539 decl);
6540 DECL_EXTERNAL (decl) = 0;
6541 if (toplevel_bindings_p ())
6542 TREE_STATIC (decl) = 1;
6543
6544 /* Tell `pushdecl' this is an initialized decl
6545 even though we don't yet have the initializer expression.
6546 Also tell `cp_finish_decl' it may store the real initializer. */
6547 DECL_INITIAL (decl) = error_mark_node;
6548 }
6549
6550 if (context && TYPE_SIZE (complete_type (context)) != NULL_TREE)
6551 {
6552 if (TREE_CODE (decl) == VAR_DECL)
6553 {
6554 tree field = lookup_field (context, DECL_NAME (decl), 0, 0);
6555 if (field == NULL_TREE || TREE_CODE (field) != VAR_DECL)
6556 cp_error ("`%#D' is not a static member of `%#T'", decl, context);
6557 else
6558 {
6559 if (DECL_CONTEXT (field) != context)
6560 {
6561 cp_pedwarn ("ANSI C++ does not permit `%T::%D' to be defined as `%T::%D'",
6562 DECL_CONTEXT (field), DECL_NAME (decl),
6563 context, DECL_NAME (decl));
6564 DECL_CONTEXT (decl) = DECL_CONTEXT (field);
6565 }
6566 /* Static data member are tricky; an in-class initialization
6567 still doesn't provide a definition, so the in-class
6568 declaration will have DECL_EXTERNAL set, but will have an
6569 initialization. Thus, duplicate_decls won't warn
6570 about this situation, and so we check here. */
6571 if (DECL_INITIAL (decl) && DECL_INITIAL (field))
6572 cp_error ("duplicate initialization of %D", decl);
6573 if (duplicate_decls (decl, field))
6574 decl = field;
6575 }
6576 }
6577 else
6578 {
6579 tree field = check_classfn (context, decl);
6580 if (field && duplicate_decls (decl, field))
6581 decl = field;
6582 }
6583
6584 /* cp_finish_decl sets DECL_EXTERNAL if DECL_IN_AGGR_P is set. */
6585 DECL_IN_AGGR_P (decl) = 0;
6586 if ((DECL_LANG_SPECIFIC (decl) && DECL_USE_TEMPLATE (decl))
6587 || CLASSTYPE_USE_TEMPLATE (context))
6588 SET_DECL_TEMPLATE_SPECIALIZATION (decl);
6589
6590 if (DECL_EXTERNAL (decl) && ! DECL_TEMPLATE_SPECIALIZATION (decl))
6591 cp_pedwarn ("declaration of `%#D' outside of class is not definition",
6592 decl);
6593
6594 pushclass (context, 2);
6595 }
6596
6597 /* Set attributes here so if duplicate decl, will have proper attributes. */
6598 cplus_decl_attributes (decl, attributes, prefix_attributes);
6599
6600 /* Add this decl to the current binding level, but not if it
6601 comes from another scope, e.g. a static member variable.
6602 TEM may equal DECL or it may be a previous decl of the same name. */
6603
6604 if ((TREE_CODE (decl) != PARM_DECL && DECL_CONTEXT (decl) != NULL_TREE
6605 /* Definitions of namespace members outside their namespace are
6606 possible. */
6607 && TREE_CODE (DECL_CONTEXT (decl)) != NAMESPACE_DECL)
6608 || (TREE_CODE (decl) == TEMPLATE_DECL && !namespace_bindings_p ())
6609 || TREE_CODE (type) == LANG_TYPE
6610 /* The declaration of template specializations does not affect
6611 the functions available for overload resolution, so we do not
6612 call pushdecl. */
6613 || (TREE_CODE (decl) == FUNCTION_DECL
6614 && DECL_TEMPLATE_SPECIALIZATION (decl)))
6615 tem = decl;
6616 else
6617 tem = pushdecl (decl);
6618
6619 if (processing_template_decl)
6620 {
6621 if (! current_function_decl)
6622 tem = push_template_decl (tem);
6623 else if (minimal_parse_mode)
6624 DECL_VINDEX (tem)
6625 = build_min_nt (DECL_STMT, copy_to_permanent (declarator),
6626 copy_to_permanent (declspecs),
6627 NULL_TREE);
6628 }
6629
6630
6631 #if ! defined (ASM_OUTPUT_BSS) && ! defined (ASM_OUTPUT_ALIGNED_BSS)
6632 /* Tell the back-end to use or not use .common as appropriate. If we say
6633 -fconserve-space, we want this to save .data space, at the expense of
6634 wrong semantics. If we say -fno-conserve-space, we want this to
6635 produce errors about redefs; to do this we force variables into the
6636 data segment. */
6637 DECL_COMMON (tem) = flag_conserve_space || ! TREE_PUBLIC (tem);
6638 #endif
6639
6640 if (! processing_template_decl)
6641 start_decl_1 (tem);
6642
6643 /* Corresponding pop_obstacks is done in `cp_finish_decl'. */
6644 push_obstacks_nochange ();
6645
6646 #if 0
6647 /* We have no way of knowing whether the initializer will need to be
6648 evaluated at run-time or not until we've parsed it, so let's just put
6649 it in the permanent obstack. (jason) */
6650 if (init_written
6651 && ! (TREE_CODE (tem) == PARM_DECL
6652 || (TREE_READONLY (tem)
6653 && (TREE_CODE (tem) == VAR_DECL
6654 || TREE_CODE (tem) == FIELD_DECL))))
6655 {
6656 /* When parsing and digesting the initializer,
6657 use temporary storage. Do this even if we will ignore the value. */
6658 if (toplevel_bindings_p () && debug_temp_inits)
6659 {
6660 if (processing_template_decl
6661 || TYPE_NEEDS_CONSTRUCTING (type)
6662 || TREE_CODE (type) == REFERENCE_TYPE)
6663 /* In this case, the initializer must lay down in permanent
6664 storage, since it will be saved until `finish_file' is run. */
6665 ;
6666 else
6667 temporary_allocation ();
6668 }
6669 }
6670 #endif
6671
6672 return tem;
6673 }
6674
6675 void
6676 start_decl_1 (decl)
6677 tree decl;
6678 {
6679 tree type = TREE_TYPE (decl);
6680 int initialized = (DECL_INITIAL (decl) != NULL_TREE);
6681
6682 /* If this type of object needs a cleanup, and control may
6683 jump past it, make a new binding level so that it is cleaned
6684 up only when it is initialized first. */
6685 if (TYPE_NEEDS_DESTRUCTOR (type)
6686 && current_binding_level->more_cleanups_ok == 0)
6687 pushlevel_temporary (1);
6688
6689 if (initialized)
6690 /* Is it valid for this decl to have an initializer at all?
6691 If not, set INITIALIZED to zero, which will indirectly
6692 tell `cp_finish_decl' to ignore the initializer once it is parsed. */
6693 {
6694 /* Don't allow initializations for incomplete types except for
6695 arrays which might be completed by the initialization. */
6696 if (type == error_mark_node)
6697 ; /* Don't complain again. */
6698 else if (TYPE_SIZE (complete_type (type)) != NULL_TREE)
6699 ; /* A complete type is ok. */
6700 else if (TREE_CODE (type) != ARRAY_TYPE)
6701 {
6702 cp_error ("variable `%#D' has initializer but incomplete type",
6703 decl);
6704 initialized = 0;
6705 type = TREE_TYPE (decl) = error_mark_node;
6706 }
6707 else if (TYPE_SIZE (complete_type (TREE_TYPE (type))) == NULL_TREE)
6708 {
6709 if (DECL_LANG_SPECIFIC (decl) && DECL_TEMPLATE_INFO (decl))
6710 cp_error ("elements of array `%#D' have incomplete type", decl);
6711 /* else we already gave an error in start_decl. */
6712 initialized = 0;
6713 }
6714 }
6715
6716 if (!initialized
6717 && TREE_CODE (decl) != TYPE_DECL
6718 && TREE_CODE (decl) != TEMPLATE_DECL
6719 && IS_AGGR_TYPE (type) && ! DECL_EXTERNAL (decl))
6720 {
6721 if ((! processing_template_decl || ! uses_template_parms (type))
6722 && TYPE_SIZE (complete_type (type)) == NULL_TREE)
6723 {
6724 cp_error ("aggregate `%#D' has incomplete type and cannot be initialized",
6725 decl);
6726 /* Change the type so that assemble_variable will give
6727 DECL an rtl we can live with: (mem (const_int 0)). */
6728 type = TREE_TYPE (decl) = error_mark_node;
6729 }
6730 else
6731 {
6732 /* If any base type in the hierarchy of TYPE needs a constructor,
6733 then we set initialized to 1. This way any nodes which are
6734 created for the purposes of initializing this aggregate
6735 will live as long as it does. This is necessary for global
6736 aggregates which do not have their initializers processed until
6737 the end of the file. */
6738 initialized = TYPE_NEEDS_CONSTRUCTING (type);
6739 }
6740 }
6741
6742 #if 0
6743 /* We don't do this yet for GNU C++. */
6744 /* For a local variable, define the RTL now. */
6745 if (! toplevel_bindings_p ()
6746 /* But not if this is a duplicate decl
6747 and we preserved the rtl from the previous one
6748 (which may or may not happen). */
6749 && DECL_RTL (tem) == NULL_RTX)
6750 {
6751 if (TYPE_SIZE (TREE_TYPE (tem)) != NULL_TREE)
6752 expand_decl (tem);
6753 else if (TREE_CODE (TREE_TYPE (tem)) == ARRAY_TYPE
6754 && DECL_INITIAL (tem) != NULL_TREE)
6755 expand_decl (tem);
6756 }
6757 #endif
6758
6759 if (! initialized)
6760 DECL_INITIAL (decl) = NULL_TREE;
6761 }
6762
6763 /* Handle initialization of references.
6764 These three arguments are from `cp_finish_decl', and have the
6765 same meaning here that they do there.
6766
6767 Quotes on semantics can be found in ARM 8.4.3. */
6768
6769 static void
6770 grok_reference_init (decl, type, init)
6771 tree decl, type, init;
6772 {
6773 tree tmp;
6774
6775 if (init == NULL_TREE)
6776 {
6777 if ((DECL_LANG_SPECIFIC (decl) == 0
6778 || DECL_IN_AGGR_P (decl) == 0)
6779 && ! DECL_THIS_EXTERN (decl))
6780 {
6781 cp_error ("`%D' declared as reference but not initialized", decl);
6782 if (TREE_CODE (decl) == VAR_DECL)
6783 SET_DECL_REFERENCE_SLOT (decl, error_mark_node);
6784 }
6785 return;
6786 }
6787
6788 if (init == error_mark_node)
6789 return;
6790
6791 if (TREE_CODE (type) == REFERENCE_TYPE
6792 && TREE_CODE (init) == CONSTRUCTOR)
6793 {
6794 cp_error ("ANSI C++ forbids use of initializer list to initialize reference `%D'", decl);
6795 return;
6796 }
6797
6798 if (TREE_TYPE (init) && TREE_CODE (TREE_TYPE (init)) == UNKNOWN_TYPE)
6799 /* decay_conversion is probably wrong for references to functions. */
6800 init = decay_conversion (instantiate_type (TREE_TYPE (type), init, 1));
6801
6802 if (TREE_CODE (init) == TREE_LIST)
6803 init = build_compound_expr (init);
6804
6805 if (TREE_CODE (TREE_TYPE (init)) == REFERENCE_TYPE)
6806 init = convert_from_reference (init);
6807
6808 if (TREE_CODE (TREE_TYPE (type)) != ARRAY_TYPE
6809 && TREE_CODE (TREE_TYPE (init)) == ARRAY_TYPE)
6810 {
6811 /* Note: default conversion is only called in very special cases. */
6812 init = default_conversion (init);
6813 }
6814
6815 tmp = convert_to_reference
6816 (type, init, CONV_IMPLICIT,
6817 LOOKUP_SPECULATIVELY|LOOKUP_NORMAL|DIRECT_BIND, decl);
6818
6819 if (tmp == error_mark_node)
6820 goto fail;
6821 else if (tmp != NULL_TREE)
6822 {
6823 init = tmp;
6824 DECL_INITIAL (decl) = save_expr (init);
6825 }
6826 else
6827 {
6828 cp_error ("cannot initialize `%T' from `%T'", type, TREE_TYPE (init));
6829 goto fail;
6830 }
6831
6832 /* ?? Can this be optimized in some cases to
6833 hand back the DECL_INITIAL slot?? */
6834 if (TYPE_SIZE (TREE_TYPE (type)))
6835 {
6836 init = convert_from_reference (decl);
6837 if (TREE_PERMANENT (decl))
6838 init = copy_to_permanent (init);
6839 SET_DECL_REFERENCE_SLOT (decl, init);
6840 }
6841
6842 if (TREE_STATIC (decl) && ! TREE_CONSTANT (DECL_INITIAL (decl)))
6843 {
6844 expand_static_init (decl, DECL_INITIAL (decl));
6845 DECL_INITIAL (decl) = NULL_TREE;
6846 }
6847 return;
6848
6849 fail:
6850 if (TREE_CODE (decl) == VAR_DECL)
6851 SET_DECL_REFERENCE_SLOT (decl, error_mark_node);
6852 return;
6853 }
6854
6855 /* Fill in DECL_INITIAL with some magical value to prevent expand_decl from
6856 mucking with forces it does not comprehend (i.e. initialization with a
6857 constructor). If we are at global scope and won't go into COMMON, fill
6858 it in with a dummy CONSTRUCTOR to force the variable into .data;
6859 otherwise we can use error_mark_node. */
6860
6861 static tree
6862 obscure_complex_init (decl, init)
6863 tree decl, init;
6864 {
6865 if (! flag_no_inline && TREE_STATIC (decl))
6866 {
6867 if (extract_init (decl, init))
6868 return NULL_TREE;
6869 }
6870
6871 #if ! defined (ASM_OUTPUT_BSS) && ! defined (ASM_OUTPUT_ALIGNED_BSS)
6872 if (toplevel_bindings_p () && ! DECL_COMMON (decl))
6873 DECL_INITIAL (decl) = build (CONSTRUCTOR, TREE_TYPE (decl), NULL_TREE,
6874 NULL_TREE);
6875 else
6876 #endif
6877 DECL_INITIAL (decl) = error_mark_node;
6878
6879 return init;
6880 }
6881
6882 /* Finish processing of a declaration;
6883 install its line number and initial value.
6884 If the length of an array type is not known before,
6885 it must be determined now, from the initial value, or it is an error.
6886
6887 Call `pop_obstacks' iff NEED_POP is nonzero.
6888
6889 For C++, `cp_finish_decl' must be fairly evasive: it must keep initializers
6890 for aggregates that have constructors alive on the permanent obstack,
6891 so that the global initializing functions can be written at the end.
6892
6893 INIT0 holds the value of an initializer that should be allowed to escape
6894 the normal rules.
6895
6896 FLAGS is LOOKUP_ONLYCONVERTING is the = init syntax was used, else 0
6897 if the (init) syntax was used.
6898
6899 For functions that take default parameters, DECL points to its
6900 "maximal" instantiation. `cp_finish_decl' must then also declared its
6901 subsequently lower and lower forms of instantiation, checking for
6902 ambiguity as it goes. This can be sped up later. */
6903
6904 void
6905 cp_finish_decl (decl, init, asmspec_tree, need_pop, flags)
6906 tree decl, init;
6907 tree asmspec_tree;
6908 int need_pop;
6909 int flags;
6910 {
6911 register tree type;
6912 tree cleanup = NULL_TREE, ttype = NULL_TREE;
6913 int was_incomplete;
6914 int temporary = allocation_temporary_p ();
6915 char *asmspec = NULL;
6916 int was_readonly = 0;
6917 int already_used = 0;
6918
6919 /* If this is 0, then we did not change obstacks. */
6920 if (! decl)
6921 {
6922 if (init)
6923 error ("assignment (not initialization) in declaration");
6924 return;
6925 }
6926
6927 /* If a name was specified, get the string. */
6928 if (asmspec_tree)
6929 asmspec = TREE_STRING_POINTER (asmspec_tree);
6930
6931 if (init && TREE_CODE (init) == NAMESPACE_DECL)
6932 {
6933 cp_error ("Cannot initialize `%D' to namespace `%D'",
6934 decl, init);
6935 init = NULL_TREE;
6936 }
6937
6938 if (TREE_CODE (decl) == VAR_DECL
6939 && DECL_CONTEXT (decl)
6940 && TREE_CODE (DECL_CONTEXT (decl)) == NAMESPACE_DECL
6941 && DECL_CONTEXT (decl) != current_namespace
6942 && init)
6943 {
6944 /* Leave the namespace of the object. */
6945 pop_decl_namespace ();
6946 }
6947
6948 /* If the type of the thing we are declaring either has
6949 a constructor, or has a virtual function table pointer,
6950 AND its initialization was accepted by `start_decl',
6951 then we stayed on the permanent obstack through the
6952 declaration, otherwise, changed obstacks as GCC would. */
6953
6954 type = TREE_TYPE (decl);
6955
6956 if (type == error_mark_node)
6957 {
6958 if (toplevel_bindings_p () && temporary)
6959 end_temporary_allocation ();
6960
6961 return;
6962 }
6963
6964 if (processing_template_decl)
6965 {
6966 if (init && DECL_INITIAL (decl))
6967 DECL_INITIAL (decl) = init;
6968 if (minimal_parse_mode && ! DECL_ARTIFICIAL (decl))
6969 {
6970 tree stmt = DECL_VINDEX (decl);
6971 /* If the decl is declaring a member of a local class (in a
6972 template function), the DECL_VINDEX will either be NULL,
6973 or it will be an actual virtual function index, not a
6974 DECL_STMT. */
6975 if (stmt != NULL_TREE && TREE_CODE (stmt) == DECL_STMT)
6976 {
6977 DECL_VINDEX (decl) = NULL_TREE;
6978 TREE_OPERAND (stmt, 2) = copy_to_permanent (init);
6979 add_tree (stmt);
6980 }
6981 }
6982
6983 goto finish_end0;
6984 }
6985 /* Take care of TYPE_DECLs up front. */
6986 if (TREE_CODE (decl) == TYPE_DECL)
6987 {
6988 if (init && DECL_INITIAL (decl))
6989 {
6990 /* typedef foo = bar; store the type of bar as the type of foo. */
6991 TREE_TYPE (decl) = type = TREE_TYPE (init);
6992 DECL_INITIAL (decl) = init = NULL_TREE;
6993 }
6994 if (type != error_mark_node
6995 && IS_AGGR_TYPE (type) && DECL_NAME (decl))
6996 {
6997 if (TREE_TYPE (DECL_NAME (decl)) && TREE_TYPE (decl) != type)
6998 cp_warning ("shadowing previous type declaration of `%#D'", decl);
6999 set_identifier_type_value (DECL_NAME (decl), type);
7000 CLASSTYPE_GOT_SEMICOLON (type) = 1;
7001 }
7002 GNU_xref_decl (current_function_decl, decl);
7003
7004 /* If we have installed this as the canonical typedef for this
7005 type, and that type has not been defined yet, delay emitting
7006 the debug information for it, as we will emit it later. */
7007 if (TYPE_MAIN_DECL (TREE_TYPE (decl)) == decl
7008 && TYPE_SIZE (TREE_TYPE (decl)) == NULL_TREE)
7009 TYPE_DECL_SUPPRESS_DEBUG (decl) = 1;
7010
7011 rest_of_decl_compilation (decl, NULL_PTR,
7012 DECL_CONTEXT (decl) == NULL_TREE, at_eof);
7013 goto finish_end;
7014 }
7015 if (TREE_CODE (decl) != FUNCTION_DECL)
7016 {
7017 ttype = target_type (type);
7018 }
7019
7020 if (! DECL_EXTERNAL (decl) && TREE_READONLY (decl)
7021 && TYPE_NEEDS_CONSTRUCTING (type))
7022 {
7023
7024 /* Currently, GNU C++ puts constants in text space, making them
7025 impossible to initialize. In the future, one would hope for
7026 an operating system which understood the difference between
7027 initialization and the running of a program. */
7028 was_readonly = 1;
7029 TREE_READONLY (decl) = 0;
7030 }
7031
7032 if (TREE_CODE (decl) == FIELD_DECL)
7033 {
7034 if (init && init != error_mark_node)
7035 my_friendly_assert (TREE_PERMANENT (init), 147);
7036
7037 if (asmspec)
7038 {
7039 /* This must override the asm specifier which was placed
7040 by grokclassfn. Lay this out fresh. */
7041 DECL_RTL (TREE_TYPE (decl)) = NULL_RTX;
7042 DECL_ASSEMBLER_NAME (decl) = get_identifier (asmspec);
7043 make_decl_rtl (decl, asmspec, 0);
7044 }
7045 }
7046 /* If `start_decl' didn't like having an initialization, ignore it now. */
7047 else if (init != NULL_TREE && DECL_INITIAL (decl) == NULL_TREE)
7048 init = NULL_TREE;
7049 else if (DECL_EXTERNAL (decl))
7050 ;
7051 else if (TREE_CODE (type) == REFERENCE_TYPE
7052 || (TYPE_LANG_SPECIFIC (type) && IS_SIGNATURE_REFERENCE (type)))
7053 {
7054 if (TREE_STATIC (decl))
7055 make_decl_rtl (decl, NULL_PTR,
7056 toplevel_bindings_p ()
7057 || pseudo_global_level_p ());
7058 grok_reference_init (decl, type, init);
7059 init = NULL_TREE;
7060 }
7061
7062 GNU_xref_decl (current_function_decl, decl);
7063
7064 if (TREE_CODE (decl) == FIELD_DECL)
7065 ;
7066 else if (TREE_CODE (decl) == CONST_DECL)
7067 {
7068 my_friendly_assert (TREE_CODE (decl) != REFERENCE_TYPE, 148);
7069
7070 DECL_INITIAL (decl) = init;
7071
7072 /* This will keep us from needing to worry about our obstacks. */
7073 my_friendly_assert (init != NULL_TREE, 149);
7074 init = NULL_TREE;
7075 }
7076 else if (init)
7077 {
7078 if (TYPE_HAS_CONSTRUCTOR (type) || TYPE_NEEDS_CONSTRUCTING (type))
7079 {
7080 if (TREE_CODE (type) == ARRAY_TYPE)
7081 init = digest_init (type, init, (tree *) 0);
7082 else if (TREE_CODE (init) == CONSTRUCTOR)
7083 {
7084 if (TYPE_NON_AGGREGATE_CLASS (type))
7085 {
7086 cp_error ("`%D' must be initialized by constructor, not by `{...}'",
7087 decl);
7088 init = error_mark_node;
7089 }
7090 else
7091 goto dont_use_constructor;
7092 }
7093 }
7094 else
7095 {
7096 dont_use_constructor:
7097 if (TREE_CODE (init) != TREE_VEC)
7098 init = store_init_value (decl, init);
7099 }
7100
7101 if (init)
7102 /* We must hide the initializer so that expand_decl
7103 won't try to do something it does not understand. */
7104 init = obscure_complex_init (decl, init);
7105 }
7106 else if (DECL_EXTERNAL (decl))
7107 ;
7108 else if (TREE_CODE_CLASS (TREE_CODE (type)) == 't'
7109 && (IS_AGGR_TYPE (type) || TYPE_NEEDS_CONSTRUCTING (type)))
7110 {
7111 tree ctype = type;
7112 while (TREE_CODE (ctype) == ARRAY_TYPE)
7113 ctype = TREE_TYPE (ctype);
7114 if (! TYPE_NEEDS_CONSTRUCTING (ctype))
7115 {
7116 if (CLASSTYPE_READONLY_FIELDS_NEED_INIT (ctype))
7117 cp_error ("structure `%D' with uninitialized const members", decl);
7118 if (CLASSTYPE_REF_FIELDS_NEED_INIT (ctype))
7119 cp_error ("structure `%D' with uninitialized reference members",
7120 decl);
7121 }
7122
7123 if (TREE_CODE (decl) == VAR_DECL
7124 && !DECL_INITIAL (decl)
7125 && !TYPE_NEEDS_CONSTRUCTING (type)
7126 && (TYPE_READONLY (type) || TREE_READONLY (decl)))
7127 cp_error ("uninitialized const `%D'", decl);
7128
7129 if (TYPE_SIZE (type) != NULL_TREE
7130 && TYPE_NEEDS_CONSTRUCTING (type))
7131 init = obscure_complex_init (decl, NULL_TREE);
7132 }
7133 else if (TREE_CODE (decl) == VAR_DECL
7134 && TREE_CODE (type) != REFERENCE_TYPE
7135 && (TYPE_READONLY (type) || TREE_READONLY (decl)))
7136 {
7137 /* ``Unless explicitly declared extern, a const object does not have
7138 external linkage and must be initialized. ($8.4; $12.1)'' ARM 7.1.6
7139 However, if it's `const int foo = 1; const int foo;', don't complain
7140 about the second decl, since it does have an initializer before.
7141 We deliberately don't complain about arrays, because they're
7142 supposed to be initialized by a constructor. */
7143 if (! DECL_INITIAL (decl)
7144 && TREE_CODE (type) != ARRAY_TYPE
7145 && (!pedantic || !current_class_type))
7146 cp_error ("uninitialized const `%#D'", decl);
7147 }
7148
7149 /* For top-level declaration, the initial value was read in
7150 the temporary obstack. MAXINDEX, rtl, etc. to be made below
7151 must go in the permanent obstack; but don't discard the
7152 temporary data yet. */
7153
7154 if (toplevel_bindings_p () && temporary)
7155 end_temporary_allocation ();
7156
7157 /* Deduce size of array from initialization, if not already known. */
7158
7159 if (TREE_CODE (type) == ARRAY_TYPE
7160 && TYPE_DOMAIN (type) == NULL_TREE
7161 && TREE_CODE (decl) != TYPE_DECL)
7162 {
7163 int do_default
7164 = (TREE_STATIC (decl)
7165 /* Even if pedantic, an external linkage array
7166 may have incomplete type at first. */
7167 ? pedantic && ! DECL_EXTERNAL (decl)
7168 : !DECL_EXTERNAL (decl));
7169 tree initializer = init ? init : DECL_INITIAL (decl);
7170 int failure = complete_array_type (type, initializer, do_default);
7171
7172 if (failure == 1)
7173 cp_error ("initializer fails to determine size of `%D'", decl);
7174
7175 if (failure == 2)
7176 {
7177 if (do_default)
7178 cp_error ("array size missing in `%D'", decl);
7179 /* If a `static' var's size isn't known, make it extern as
7180 well as static, so it does not get allocated. If it's not
7181 `static', then don't mark it extern; finish_incomplete_decl
7182 will give it a default size and it will get allocated. */
7183 else if (!pedantic && TREE_STATIC (decl) && !TREE_PUBLIC (decl))
7184 DECL_EXTERNAL (decl) = 1;
7185 }
7186
7187 if (pedantic && TYPE_DOMAIN (type) != NULL_TREE
7188 && tree_int_cst_lt (TYPE_MAX_VALUE (TYPE_DOMAIN (type)),
7189 integer_zero_node))
7190 cp_error ("zero-size array `%D'", decl);
7191
7192 layout_decl (decl, 0);
7193 }
7194
7195 if (TREE_CODE (decl) == VAR_DECL)
7196 {
7197 if (DECL_SIZE (decl) == NULL_TREE
7198 && TYPE_SIZE (complete_type (TREE_TYPE (decl))) != NULL_TREE)
7199 layout_decl (decl, 0);
7200
7201 if (TREE_STATIC (decl) && DECL_SIZE (decl) == NULL_TREE)
7202 {
7203 /* A static variable with an incomplete type:
7204 that is an error if it is initialized.
7205 Otherwise, let it through, but if it is not `extern'
7206 then it may cause an error message later. */
7207 if (DECL_INITIAL (decl) != NULL_TREE)
7208 cp_error ("storage size of `%D' isn't known", decl);
7209 init = NULL_TREE;
7210 }
7211 else if (!DECL_EXTERNAL (decl) && DECL_SIZE (decl) == NULL_TREE)
7212 {
7213 /* An automatic variable with an incomplete type: that is an error.
7214 Don't talk about array types here, since we took care of that
7215 message in grokdeclarator. */
7216 cp_error ("storage size of `%D' isn't known", decl);
7217 TREE_TYPE (decl) = error_mark_node;
7218 }
7219 else if (!DECL_EXTERNAL (decl) && IS_AGGR_TYPE (ttype))
7220 /* Let debugger know it should output info for this type. */
7221 note_debug_info_needed (ttype);
7222
7223 if (TREE_STATIC (decl) && DECL_CLASS_SCOPE_P (decl))
7224 note_debug_info_needed (DECL_CONTEXT (decl));
7225
7226 if ((DECL_EXTERNAL (decl) || TREE_STATIC (decl))
7227 && DECL_SIZE (decl) != NULL_TREE
7228 && ! TREE_CONSTANT (DECL_SIZE (decl)))
7229 {
7230 if (TREE_CODE (DECL_SIZE (decl)) == INTEGER_CST)
7231 constant_expression_warning (DECL_SIZE (decl));
7232 else
7233 cp_error ("storage size of `%D' isn't constant", decl);
7234 }
7235
7236 if (! DECL_EXTERNAL (decl) && TYPE_NEEDS_DESTRUCTOR (type)
7237 /* Cleanups for static variables are handled by `finish_file'. */
7238 && ! TREE_STATIC (decl))
7239 {
7240 int yes = suspend_momentary ();
7241 cleanup = maybe_build_cleanup (decl);
7242 resume_momentary (yes);
7243 }
7244 }
7245 /* PARM_DECLs get cleanups, too. */
7246 else if (TREE_CODE (decl) == PARM_DECL && TYPE_NEEDS_DESTRUCTOR (type))
7247 {
7248 if (temporary)
7249 end_temporary_allocation ();
7250 cleanup = maybe_build_cleanup (decl);
7251 if (temporary)
7252 resume_temporary_allocation ();
7253 }
7254
7255 /* Output the assembler code and/or RTL code for variables and functions,
7256 unless the type is an undefined structure or union.
7257 If not, it will get done when the type is completed. */
7258
7259 was_incomplete = (DECL_SIZE (decl) == NULL_TREE);
7260
7261 if (TREE_CODE (decl) == VAR_DECL || TREE_CODE (decl) == FUNCTION_DECL
7262 || TREE_CODE (decl) == RESULT_DECL)
7263 {
7264 /* ??? FIXME: What about nested classes? */
7265 int toplev = toplevel_bindings_p () || pseudo_global_level_p ();
7266 int was_temp
7267 = (TREE_STATIC (decl) && TYPE_NEEDS_DESTRUCTOR (type)
7268 && allocation_temporary_p ());
7269
7270 if (was_temp)
7271 end_temporary_allocation ();
7272
7273 /* Extern inline function static data has external linkage.
7274 Instead of trying to deal with that, we disable inlining of
7275 such functions. The ASM_WRITTEN check is to avoid hitting this
7276 for __FUNCTION__. */
7277 if (TREE_CODE (decl) == VAR_DECL
7278 && TREE_STATIC (decl)
7279 && ! TREE_ASM_WRITTEN (decl)
7280 && current_function_decl
7281 && DECL_CONTEXT (decl) == current_function_decl
7282 && DECL_THIS_INLINE (current_function_decl)
7283 && TREE_PUBLIC (current_function_decl))
7284 {
7285 current_function_cannot_inline
7286 = "function with static variable cannot be inline";
7287 }
7288
7289 else if (TREE_CODE (decl) == VAR_DECL
7290 && DECL_LANG_SPECIFIC (decl)
7291 && DECL_COMDAT (decl))
7292 {
7293 /* Dynamically initialized vars go into common. */
7294 if (DECL_INITIAL (decl) == NULL_TREE
7295 || DECL_INITIAL (decl) == error_mark_node)
7296 DECL_COMMON (decl) = 1;
7297 else if (EMPTY_CONSTRUCTOR_P (DECL_INITIAL (decl)))
7298 {
7299 DECL_COMMON (decl) = 1;
7300 DECL_INITIAL (decl) = error_mark_node;
7301 }
7302 else
7303 {
7304 /* Statically initialized vars are weak or comdat, if
7305 supported. */
7306 if (flag_weak)
7307 make_decl_one_only (decl);
7308 else
7309 {
7310 /* We can't do anything useful; leave vars for explicit
7311 instantiation. */
7312 DECL_EXTERNAL (decl) = 1;
7313 DECL_NOT_REALLY_EXTERN (decl) = 0;
7314 }
7315 }
7316 }
7317
7318 if (TREE_CODE (decl) == VAR_DECL && DECL_VIRTUAL_P (decl))
7319 make_decl_rtl (decl, NULL_PTR, toplev);
7320 else if (TREE_CODE (decl) == VAR_DECL
7321 && TREE_READONLY (decl)
7322 && DECL_INITIAL (decl) != NULL_TREE
7323 && DECL_INITIAL (decl) != error_mark_node
7324 && ! EMPTY_CONSTRUCTOR_P (DECL_INITIAL (decl)))
7325 {
7326 DECL_INITIAL (decl) = save_expr (DECL_INITIAL (decl));
7327
7328 if (asmspec)
7329 DECL_ASSEMBLER_NAME (decl) = get_identifier (asmspec);
7330
7331 if (! toplev
7332 && TREE_STATIC (decl)
7333 && ! TREE_SIDE_EFFECTS (decl)
7334 && ! TREE_PUBLIC (decl)
7335 && ! DECL_EXTERNAL (decl)
7336 && ! TYPE_NEEDS_DESTRUCTOR (type)
7337 && DECL_MODE (decl) != BLKmode)
7338 {
7339 /* If this variable is really a constant, then fill its DECL_RTL
7340 slot with something which won't take up storage.
7341 If something later should take its address, we can always give
7342 it legitimate RTL at that time. */
7343 DECL_RTL (decl) = gen_reg_rtx (DECL_MODE (decl));
7344 store_expr (DECL_INITIAL (decl), DECL_RTL (decl), 0);
7345 TREE_ASM_WRITTEN (decl) = 1;
7346 }
7347 else if (toplev && ! TREE_PUBLIC (decl))
7348 {
7349 /* If this is a static const, change its apparent linkage
7350 if it belongs to a #pragma interface. */
7351 if (!interface_unknown)
7352 {
7353 TREE_PUBLIC (decl) = 1;
7354 DECL_EXTERNAL (decl) = interface_only;
7355 }
7356 make_decl_rtl (decl, asmspec, toplev);
7357 }
7358 else
7359 rest_of_decl_compilation (decl, asmspec, toplev, at_eof);
7360 }
7361 else if (TREE_CODE (decl) == VAR_DECL
7362 && DECL_LANG_SPECIFIC (decl)
7363 && DECL_IN_AGGR_P (decl))
7364 {
7365 if (TREE_STATIC (decl))
7366 {
7367 if (init == NULL_TREE
7368 #ifdef DEFAULT_STATIC_DEFS
7369 /* If this code is dead, then users must
7370 explicitly declare static member variables
7371 outside the class def'n as well. */
7372 && TYPE_NEEDS_CONSTRUCTING (type)
7373 #endif
7374 )
7375 {
7376 DECL_EXTERNAL (decl) = 1;
7377 make_decl_rtl (decl, asmspec, 1);
7378 }
7379 else
7380 rest_of_decl_compilation (decl, asmspec, toplev, at_eof);
7381 }
7382 else
7383 /* Just a constant field. Should not need any rtl. */
7384 goto finish_end0;
7385 }
7386 else
7387 rest_of_decl_compilation (decl, asmspec, toplev, at_eof);
7388
7389 if (was_temp)
7390 resume_temporary_allocation ();
7391
7392 if (type != error_mark_node
7393 && TYPE_LANG_SPECIFIC (type)
7394 && CLASSTYPE_ABSTRACT_VIRTUALS (type))
7395 abstract_virtuals_error (decl, type);
7396 else if ((TREE_CODE (type) == FUNCTION_TYPE
7397 || TREE_CODE (type) == METHOD_TYPE)
7398 && TYPE_LANG_SPECIFIC (TREE_TYPE (type))
7399 && CLASSTYPE_ABSTRACT_VIRTUALS (TREE_TYPE (type)))
7400 abstract_virtuals_error (decl, TREE_TYPE (type));
7401
7402 if (TYPE_LANG_SPECIFIC (type) && IS_SIGNATURE (type))
7403 signature_error (decl, type);
7404 else if ((TREE_CODE (type) == FUNCTION_TYPE
7405 || TREE_CODE (type) == METHOD_TYPE)
7406 && TYPE_LANG_SPECIFIC (TREE_TYPE (type))
7407 && IS_SIGNATURE (TREE_TYPE (type)))
7408 signature_error (decl, TREE_TYPE (type));
7409
7410 if (TREE_CODE (decl) == FUNCTION_DECL)
7411 ;
7412 else if (DECL_EXTERNAL (decl)
7413 && ! (DECL_LANG_SPECIFIC (decl)
7414 && DECL_NOT_REALLY_EXTERN (decl)))
7415 {
7416 if (init)
7417 DECL_INITIAL (decl) = init;
7418 }
7419 else if (TREE_STATIC (decl) && type != error_mark_node)
7420 {
7421 /* Cleanups for static variables are handled by `finish_file'. */
7422 if (TYPE_NEEDS_CONSTRUCTING (type) || init != NULL_TREE
7423 || TYPE_NEEDS_DESTRUCTOR (type))
7424 expand_static_init (decl, init);
7425 }
7426 else if (! toplev)
7427 {
7428 /* This is a declared decl which must live until the
7429 end of the binding contour. It may need a cleanup. */
7430
7431 /* Recompute the RTL of a local array now
7432 if it used to be an incomplete type. */
7433 if (was_incomplete && ! TREE_STATIC (decl))
7434 {
7435 /* If we used it already as memory, it must stay in memory. */
7436 TREE_ADDRESSABLE (decl) = TREE_USED (decl);
7437 /* If it's still incomplete now, no init will save it. */
7438 if (DECL_SIZE (decl) == NULL_TREE)
7439 DECL_INITIAL (decl) = NULL_TREE;
7440 expand_decl (decl);
7441 }
7442 else if (! TREE_ASM_WRITTEN (decl)
7443 && (TYPE_SIZE (type) != NULL_TREE
7444 || TREE_CODE (type) == ARRAY_TYPE))
7445 {
7446 /* Do this here, because we did not expand this decl's
7447 rtl in start_decl. */
7448 if (DECL_RTL (decl) == NULL_RTX)
7449 expand_decl (decl);
7450 else if (cleanup)
7451 {
7452 /* XXX: Why don't we use decl here? */
7453 /* Ans: Because it was already expanded? */
7454 if (! expand_decl_cleanup (NULL_TREE, cleanup))
7455 cp_error ("parser lost in parsing declaration of `%D'",
7456 decl);
7457 /* Cleanup used up here. */
7458 cleanup = NULL_TREE;
7459 }
7460 }
7461
7462 if (current_binding_level->is_for_scope)
7463 {
7464 struct binding_level *outer = current_binding_level->level_chain;
7465
7466 /* Check to see if the same name is already bound at
7467 the outer level, either because it was directly declared,
7468 or because a dead for-decl got preserved. In either case,
7469 the code would not have been valid under the ARM
7470 scope rules, so clear is_for_scope for the
7471 current_binding_level.
7472
7473 Otherwise, we need to preserve the temp slot for decl
7474 to last into the outer binding level. */
7475
7476 int handling_dead_for_vars = 0;
7477 tree link = outer->names;
7478 for (; ; link = TREE_CHAIN (link))
7479 {
7480 if (link == NULL && handling_dead_for_vars == 0)
7481 {
7482 link = outer->dead_vars_from_for;
7483 handling_dead_for_vars = 1;
7484 }
7485 if (link == NULL)
7486 {
7487 if (DECL_IN_MEMORY_P (decl))
7488 preserve_temp_slots (DECL_RTL (decl));
7489 break;
7490 }
7491 if (DECL_NAME (link) == DECL_NAME (decl))
7492 {
7493 if (handling_dead_for_vars)
7494 {
7495 tree shadowing
7496 = purpose_member (DECL_NAME (decl),
7497 current_binding_level->shadowed);
7498 if (shadowing && TREE_VALUE (shadowing) == link)
7499 TREE_VALUE (shadowing)
7500 = DECL_SHADOWED_FOR_VAR (link);
7501 }
7502 current_binding_level->is_for_scope = 0;
7503 break;
7504 }
7505 }
7506 }
7507
7508 expand_start_target_temps ();
7509
7510 if (DECL_SIZE (decl) && type != error_mark_node)
7511 {
7512 /* Compute and store the initial value. */
7513 expand_decl_init (decl);
7514 already_used = TREE_USED (decl) || TREE_USED (type);
7515
7516 if (init || TYPE_NEEDS_CONSTRUCTING (type))
7517 {
7518 emit_line_note (DECL_SOURCE_FILE (decl),
7519 DECL_SOURCE_LINE (decl));
7520 expand_aggr_init (decl, init, 0, flags);
7521 }
7522
7523 /* Set this to 0 so we can tell whether an aggregate which
7524 was initialized was ever used. Don't do this if it has a
7525 destructor, so we don't complain about the 'resource
7526 allocation is initialization' idiom. */
7527 /* Now set attribute((unused)) on types so decls of
7528 that type will be marked used. (see TREE_USED, above.)
7529 This avoids the warning problems this particular code
7530 tried to work around. */
7531
7532 if (TYPE_NEEDS_CONSTRUCTING (type)
7533 && ! already_used
7534 && cleanup == NULL_TREE
7535 && DECL_NAME (decl))
7536 TREE_USED (decl) = 0;
7537
7538 if (already_used)
7539 TREE_USED (decl) = 1;
7540 }
7541
7542 /* Cleanup any temporaries needed for the initial value. */
7543 expand_end_target_temps ();
7544
7545 if (DECL_SIZE (decl) && type != error_mark_node)
7546 {
7547 /* Store the cleanup, if there was one. */
7548 if (cleanup)
7549 {
7550 if (! expand_decl_cleanup (decl, cleanup))
7551 cp_error ("parser lost in parsing declaration of `%D'",
7552 decl);
7553 }
7554 }
7555 }
7556 finish_end0:
7557
7558 /* Undo call to `pushclass' that was done in `start_decl'
7559 due to initialization of qualified member variable.
7560 I.e., Foo::x = 10; */
7561 {
7562 tree context = DECL_REAL_CONTEXT (decl);
7563 if (context
7564 && TREE_CODE_CLASS (TREE_CODE (context)) == 't'
7565 && (TREE_CODE (decl) == VAR_DECL
7566 /* We also have a pushclass done that we need to undo here
7567 if we're at top level and declare a method. */
7568 || TREE_CODE (decl) == FUNCTION_DECL)
7569 /* If size hasn't been set, we're still defining it,
7570 and therefore inside the class body; don't pop
7571 the binding level.. */
7572 && TYPE_SIZE (context) != NULL_TREE
7573 && context == current_class_type)
7574 popclass (1);
7575 }
7576 }
7577
7578 finish_end:
7579
7580 /* If requested, warn about definitions of large data objects. */
7581
7582 if (warn_larger_than
7583 && ! processing_template_decl
7584 && (TREE_CODE (decl) == VAR_DECL || TREE_CODE (decl) == PARM_DECL)
7585 && !DECL_EXTERNAL (decl))
7586 {
7587 register tree decl_size = DECL_SIZE (decl);
7588
7589 if (decl_size && TREE_CODE (decl_size) == INTEGER_CST)
7590 {
7591 unsigned units = TREE_INT_CST_LOW (decl_size) / BITS_PER_UNIT;
7592
7593 if (units > larger_than_size)
7594 warning_with_decl (decl, "size of `%s' is %u bytes", units);
7595 }
7596 }
7597
7598 if (need_pop)
7599 {
7600 /* Resume permanent allocation, if not within a function. */
7601 /* The corresponding push_obstacks_nochange is in start_decl,
7602 start_method, groktypename, and in grokfield. */
7603 pop_obstacks ();
7604 }
7605
7606 if (was_readonly)
7607 TREE_READONLY (decl) = 1;
7608 }
7609
7610 /* This is here for a midend callback from c-common.c */
7611
7612 void
7613 finish_decl (decl, init, asmspec_tree)
7614 tree decl, init;
7615 tree asmspec_tree;
7616 {
7617 cp_finish_decl (decl, init, asmspec_tree, 1, 0);
7618 }
7619
7620 void
7621 expand_static_init (decl, init)
7622 tree decl;
7623 tree init;
7624 {
7625 tree oldstatic = value_member (decl, static_aggregates);
7626
7627 if (oldstatic)
7628 {
7629 if (TREE_PURPOSE (oldstatic) && init != NULL_TREE)
7630 cp_error ("multiple initializations given for `%D'", decl);
7631 }
7632 else if (! toplevel_bindings_p () && ! pseudo_global_level_p ())
7633 {
7634 /* Emit code to perform this initialization but once. */
7635 tree temp;
7636
7637 /* Remember this information until end of file. */
7638 push_obstacks (&permanent_obstack, &permanent_obstack);
7639
7640 /* Emit code to perform this initialization but once. */
7641 temp = get_temp_name (integer_type_node, 1);
7642 rest_of_decl_compilation (temp, NULL_PTR, 0, 0);
7643 expand_start_cond (build_binary_op (EQ_EXPR, temp,
7644 integer_zero_node, 1), 0);
7645 expand_start_target_temps ();
7646
7647 expand_assignment (temp, integer_one_node, 0, 0);
7648 if (TYPE_NEEDS_CONSTRUCTING (TREE_TYPE (decl))
7649 || (init && TREE_CODE (init) == TREE_LIST))
7650 {
7651 expand_aggr_init (decl, init, 0, 0);
7652 do_pending_stack_adjust ();
7653 }
7654 else if (init)
7655 expand_assignment (decl, init, 0, 0);
7656
7657 /* Cleanup any temporaries needed for the initial value. */
7658 expand_end_target_temps ();
7659
7660 if (TYPE_NEEDS_DESTRUCTOR (TREE_TYPE (decl)))
7661 {
7662 tree cleanup, fcall;
7663 static tree Atexit = 0;
7664 if (Atexit == 0)
7665 {
7666 tree atexit_fndecl, PFV, pfvlist;
7667 /* Remember this information until end of file. */
7668 push_obstacks (&permanent_obstack, &permanent_obstack);
7669 PFV = build_pointer_type (build_function_type
7670 (void_type_node, void_list_node));
7671
7672 pfvlist = tree_cons (NULL_TREE, PFV, void_list_node);
7673
7674 push_lang_context (lang_name_c);
7675 atexit_fndecl
7676 = builtin_function ("atexit",
7677 build_function_type (void_type_node,
7678 pfvlist),
7679 NOT_BUILT_IN, NULL_PTR);
7680 assemble_external (atexit_fndecl);
7681 Atexit = default_conversion (atexit_fndecl);
7682 pop_lang_context ();
7683 pop_obstacks ();
7684 }
7685
7686 cleanup = start_anon_func ();
7687 expand_expr_stmt (build_cleanup (decl));
7688 end_anon_func ();
7689 mark_addressable (cleanup);
7690 cleanup = build_unary_op (ADDR_EXPR, cleanup, 0);
7691 fcall = build_function_call (Atexit, expr_tree_cons (NULL_TREE, cleanup, NULL_TREE));
7692 expand_expr_stmt (fcall);
7693 }
7694
7695 expand_end_cond ();
7696 if (TYPE_NEEDS_DESTRUCTOR (TREE_TYPE (decl)))
7697 {
7698 static_aggregates = perm_tree_cons (temp, decl, static_aggregates);
7699 TREE_STATIC (static_aggregates) = 1;
7700 }
7701
7702 /* Resume old (possibly temporary) allocation. */
7703 pop_obstacks ();
7704 }
7705 else
7706 {
7707 /* This code takes into account memory allocation
7708 policy of `start_decl'. Namely, if TYPE_NEEDS_CONSTRUCTING
7709 does not hold for this object, then we must make permanent
7710 the storage currently in the temporary obstack. */
7711 if (! TYPE_NEEDS_CONSTRUCTING (TREE_TYPE (decl)))
7712 preserve_initializer ();
7713 static_aggregates = perm_tree_cons (init, decl, static_aggregates);
7714 }
7715 }
7716 \f
7717 /* Make TYPE a complete type based on INITIAL_VALUE.
7718 Return 0 if successful, 1 if INITIAL_VALUE can't be deciphered,
7719 2 if there was no information (in which case assume 1 if DO_DEFAULT). */
7720
7721 int
7722 complete_array_type (type, initial_value, do_default)
7723 tree type, initial_value;
7724 int do_default;
7725 {
7726 register tree maxindex = NULL_TREE;
7727 int value = 0;
7728
7729 if (initial_value)
7730 {
7731 /* Note MAXINDEX is really the maximum index,
7732 one less than the size. */
7733 if (TREE_CODE (initial_value) == STRING_CST)
7734 {
7735 int eltsize
7736 = int_size_in_bytes (TREE_TYPE (TREE_TYPE (initial_value)));
7737 maxindex = build_int_2 ((TREE_STRING_LENGTH (initial_value)
7738 / eltsize) - 1, 0);
7739 }
7740 else if (TREE_CODE (initial_value) == CONSTRUCTOR)
7741 {
7742 tree elts = CONSTRUCTOR_ELTS (initial_value);
7743 maxindex = size_binop (MINUS_EXPR, integer_zero_node, size_one_node);
7744 for (; elts; elts = TREE_CHAIN (elts))
7745 {
7746 if (TREE_PURPOSE (elts))
7747 maxindex = TREE_PURPOSE (elts);
7748 else
7749 maxindex = size_binop (PLUS_EXPR, maxindex, size_one_node);
7750 }
7751 maxindex = copy_node (maxindex);
7752 }
7753 else
7754 {
7755 /* Make an error message unless that happened already. */
7756 if (initial_value != error_mark_node)
7757 value = 1;
7758
7759 /* Prevent further error messages. */
7760 maxindex = build_int_2 (0, 0);
7761 }
7762 }
7763
7764 if (!maxindex)
7765 {
7766 if (do_default)
7767 maxindex = build_int_2 (0, 0);
7768 value = 2;
7769 }
7770
7771 if (maxindex)
7772 {
7773 tree itype;
7774
7775 TYPE_DOMAIN (type) = build_index_type (maxindex);
7776 if (! TREE_TYPE (maxindex))
7777 TREE_TYPE (maxindex) = TYPE_DOMAIN (type);
7778 if (initial_value)
7779 itype = TREE_TYPE (initial_value);
7780 else
7781 itype = NULL;
7782 if (itype && !TYPE_DOMAIN (itype))
7783 TYPE_DOMAIN (itype) = TYPE_DOMAIN (type);
7784 /* The type of the main variant should never be used for arrays
7785 of different sizes. It should only ever be completed with the
7786 size of the array. */
7787 if (! TYPE_DOMAIN (TYPE_MAIN_VARIANT (type)))
7788 TYPE_DOMAIN (TYPE_MAIN_VARIANT (type)) = TYPE_DOMAIN (type);
7789 }
7790
7791 /* Lay out the type now that we can get the real answer. */
7792
7793 layout_type (type);
7794
7795 return value;
7796 }
7797 \f
7798 /* Return zero if something is declared to be a member of type
7799 CTYPE when in the context of CUR_TYPE. STRING is the error
7800 message to print in that case. Otherwise, quietly return 1. */
7801
7802 static int
7803 member_function_or_else (ctype, cur_type, string)
7804 tree ctype, cur_type;
7805 char *string;
7806 {
7807 if (ctype && ctype != cur_type)
7808 {
7809 error (string, TYPE_NAME_STRING (ctype));
7810 return 0;
7811 }
7812 return 1;
7813 }
7814 \f
7815 /* Subroutine of `grokdeclarator'. */
7816
7817 /* Generate errors possibly applicable for a given set of specifiers.
7818 This is for ARM $7.1.2. */
7819
7820 static void
7821 bad_specifiers (object, type, virtualp, quals, inlinep, friendp, raises)
7822 tree object;
7823 char *type;
7824 int virtualp, quals, friendp, raises, inlinep;
7825 {
7826 if (virtualp)
7827 cp_error ("`%D' declared as a `virtual' %s", object, type);
7828 if (inlinep)
7829 cp_error ("`%D' declared as an `inline' %s", object, type);
7830 if (quals)
7831 cp_error ("`const' and `volatile' function specifiers on `%D' invalid in %s declaration",
7832 object, type);
7833 if (friendp)
7834 cp_error_at ("invalid friend declaration", object);
7835 if (raises)
7836 cp_error_at ("invalid exception specifications", object);
7837 }
7838
7839 /* CTYPE is class type, or null if non-class.
7840 TYPE is type this FUNCTION_DECL should have, either FUNCTION_TYPE
7841 or METHOD_TYPE.
7842 DECLARATOR is the function's name.
7843 VIRTUALP is truthvalue of whether the function is virtual or not.
7844 FLAGS are to be passed through to `grokclassfn'.
7845 QUALS are qualifiers indicating whether the function is `const'
7846 or `volatile'.
7847 RAISES is a list of exceptions that this function can raise.
7848 CHECK is 1 if we must find this method in CTYPE, 0 if we should
7849 not look, and -1 if we should not call `grokclassfn' at all. */
7850
7851 static tree
7852 grokfndecl (ctype, type, declarator, orig_declarator, virtualp, flags, quals,
7853 raises, attrlist, check, friendp, publicp, inlinep, funcdef_flag,
7854 template_count, in_namespace)
7855 tree ctype, type;
7856 tree declarator;
7857 tree orig_declarator;
7858 int virtualp;
7859 enum overload_flags flags;
7860 tree quals, raises, attrlist;
7861 int check, friendp, publicp, inlinep, funcdef_flag, template_count;
7862 tree in_namespace;
7863 {
7864 tree cname, decl;
7865 int staticp = ctype && TREE_CODE (type) == FUNCTION_TYPE;
7866 tree t;
7867
7868 if (ctype)
7869 cname = TREE_CODE (TYPE_NAME (ctype)) == TYPE_DECL
7870 ? TYPE_IDENTIFIER (ctype) : TYPE_NAME (ctype);
7871 else
7872 cname = NULL_TREE;
7873
7874 if (raises)
7875 {
7876 type = build_exception_variant (type, raises);
7877 }
7878
7879 decl = build_lang_decl (FUNCTION_DECL, declarator, type);
7880 /* Propagate volatile out from type to decl. */
7881 if (TYPE_VOLATILE (type))
7882 TREE_THIS_VOLATILE (decl) = 1;
7883
7884 /* This decl is not from the current namespace. */
7885 if (in_namespace)
7886 set_decl_namespace (decl, in_namespace);
7887
7888 /* Should probably propagate const out from type to decl I bet (mrs). */
7889 if (staticp)
7890 {
7891 DECL_STATIC_FUNCTION_P (decl) = 1;
7892 DECL_CONTEXT (decl) = ctype;
7893 }
7894
7895 if (ctype)
7896 DECL_CLASS_CONTEXT (decl) = ctype;
7897
7898 if (ctype == NULL_TREE && MAIN_NAME_P (declarator))
7899 {
7900 if (inlinep)
7901 error ("cannot declare `main' to be inline");
7902 else if (! publicp)
7903 error ("cannot declare `main' to be static");
7904 inlinep = 0;
7905 publicp = 1;
7906 }
7907
7908 /* Members of anonymous types have no linkage; make them internal. */
7909 if (ctype && ANON_AGGRNAME_P (TYPE_IDENTIFIER (ctype)))
7910 publicp = 0;
7911
7912 if (publicp)
7913 {
7914 /* [basic.link]: A name with no linkage (notably, the name of a class
7915 or enumeration declared in a local scope) shall not be used to
7916 declare an entity with linkage.
7917
7918 Only check this for public decls for now. */
7919 t = no_linkage_check (TREE_TYPE (decl));
7920 if (t)
7921 {
7922 if (ANON_AGGRNAME_P (TYPE_IDENTIFIER (t)))
7923 cp_pedwarn ("non-local function `%#D' uses anonymous type", decl);
7924 else
7925 cp_pedwarn ("non-local function `%#D' uses local type `%T'",
7926 decl, t);
7927 }
7928 }
7929
7930 TREE_PUBLIC (decl) = publicp;
7931 if (! publicp)
7932 {
7933 DECL_INTERFACE_KNOWN (decl) = 1;
7934 DECL_NOT_REALLY_EXTERN (decl) = 1;
7935 }
7936
7937 if (inlinep)
7938 DECL_THIS_INLINE (decl) = DECL_INLINE (decl) = 1;
7939
7940 DECL_EXTERNAL (decl) = 1;
7941 if (quals != NULL_TREE && TREE_CODE (type) == FUNCTION_TYPE)
7942 {
7943 cp_error ("%smember function `%D' cannot have `%T' method qualifier",
7944 (ctype ? "static " : "non-"), decl, TREE_VALUE (quals));
7945 quals = NULL_TREE;
7946 }
7947
7948 if (IDENTIFIER_OPNAME_P (DECL_NAME (decl)))
7949 grok_op_properties (decl, virtualp, check < 0);
7950
7951 if (ctype && hack_decl_function_context (decl))
7952 DECL_NO_STATIC_CHAIN (decl) = 1;
7953
7954 for (t = TYPE_ARG_TYPES (TREE_TYPE (decl)); t; t = TREE_CHAIN (t))
7955 if (TREE_PURPOSE (t)
7956 && TREE_CODE (TREE_PURPOSE (t)) == DEFAULT_ARG)
7957 {
7958 add_defarg_fn (decl);
7959 break;
7960 }
7961
7962 if (friendp
7963 && TREE_CODE (orig_declarator) == TEMPLATE_ID_EXPR)
7964 {
7965 if (funcdef_flag)
7966 cp_error
7967 ("defining explicit specialization `%D' in friend declaration",
7968 orig_declarator);
7969 else
7970 {
7971 /* A friend declaration of the form friend void f<>(). Record
7972 the information in the TEMPLATE_ID_EXPR. */
7973 SET_DECL_IMPLICIT_INSTANTIATION (decl);
7974 DECL_TEMPLATE_INFO (decl)
7975 = perm_tree_cons (TREE_OPERAND (orig_declarator, 0),
7976 TREE_OPERAND (orig_declarator, 1),
7977 NULL_TREE);
7978 }
7979 }
7980
7981 /* Caller will do the rest of this. */
7982 if (check < 0)
7983 return decl;
7984
7985 if (check && funcdef_flag)
7986 DECL_INITIAL (decl) = error_mark_node;
7987
7988 if (flags == NO_SPECIAL && ctype && constructor_name (cname) == declarator)
7989 {
7990 tree tmp;
7991 /* Just handle constructors here. We could do this
7992 inside the following if stmt, but I think
7993 that the code is more legible by breaking this
7994 case out. See comments below for what each of
7995 the following calls is supposed to do. */
7996 DECL_CONSTRUCTOR_P (decl) = 1;
7997
7998 grokclassfn (ctype, declarator, decl, flags, quals);
7999
8000 decl = check_explicit_specialization (orig_declarator, decl,
8001 template_count,
8002 2 * (funcdef_flag != 0) +
8003 4 * (friendp != 0));
8004
8005 if ((! TYPE_FOR_JAVA (ctype) || check_java_method (ctype, decl))
8006 && check)
8007 {
8008 tmp = check_classfn (ctype, decl);
8009
8010 if (tmp && TREE_CODE (tmp) == TEMPLATE_DECL)
8011 tmp = DECL_TEMPLATE_RESULT(tmp);
8012
8013 if (tmp && DECL_ARTIFICIAL (tmp))
8014 cp_error ("definition of implicitly-declared `%D'", tmp);
8015 if (tmp && duplicate_decls (decl, tmp))
8016 return tmp;
8017 }
8018 if (! grok_ctor_properties (ctype, decl))
8019 return NULL_TREE;
8020
8021 if (check == 0 && ! current_function_decl)
8022 {
8023 /* Assembler names live in the global namespace. */
8024 tmp = IDENTIFIER_GLOBAL_VALUE (DECL_ASSEMBLER_NAME (decl));
8025 if (tmp == NULL_TREE)
8026 SET_IDENTIFIER_GLOBAL_VALUE (DECL_ASSEMBLER_NAME (decl), decl);
8027 else if (TREE_CODE (tmp) != TREE_CODE (decl))
8028 cp_error ("inconsistent declarations for `%D'", decl);
8029 else
8030 {
8031 duplicate_decls (decl, tmp);
8032 decl = tmp;
8033 }
8034 make_decl_rtl (decl, NULL_PTR, 1);
8035 }
8036 }
8037 else
8038 {
8039 tree tmp;
8040
8041 /* Function gets the ugly name, field gets the nice one.
8042 This call may change the type of the function (because
8043 of default parameters)! */
8044 if (ctype != NULL_TREE)
8045 grokclassfn (ctype, cname, decl, flags, quals);
8046
8047 decl = check_explicit_specialization (orig_declarator, decl,
8048 template_count,
8049 2 * (funcdef_flag != 0) +
8050 4 * (friendp != 0));
8051 if (ctype != NULL_TREE
8052 && (! TYPE_FOR_JAVA (ctype) || check_java_method (ctype, decl))
8053 && check)
8054 {
8055 tmp = check_classfn (ctype, decl);
8056
8057 if (tmp && TREE_CODE (tmp) == TEMPLATE_DECL)
8058 tmp = DECL_TEMPLATE_RESULT (tmp);
8059
8060 if (tmp && DECL_STATIC_FUNCTION_P (tmp)
8061 && TREE_CODE (TREE_TYPE (decl)) == METHOD_TYPE)
8062 {
8063 /* Remove the `this' parm added by grokclassfn.
8064 XXX Isn't this done in start_function, too? */
8065 revert_static_member_fn (&decl, NULL, NULL);
8066 last_function_parms = TREE_CHAIN (last_function_parms);
8067 }
8068 if (tmp && DECL_ARTIFICIAL (tmp))
8069 cp_error ("definition of implicitly-declared `%D'", tmp);
8070 if (tmp)
8071 {
8072 if (!duplicate_decls (decl, tmp))
8073 my_friendly_abort (892);
8074 return tmp;
8075 }
8076 }
8077
8078 if (ctype == NULL_TREE || check)
8079 return decl;
8080
8081 /* Now install the declaration of this function so that others may
8082 find it (esp. its DECL_FRIENDLIST). Don't do this for local class
8083 methods, though. */
8084 if (! current_function_decl)
8085 {
8086 if (!DECL_TEMPLATE_SPECIALIZATION (decl))
8087 {
8088 /* We don't do this for specializations since the
8089 equivalent checks will be done later. Also, at this
8090 point the DECL_ASSEMBLER_NAME is not yet fully
8091 accurate. */
8092
8093 /* FIXME: this should only need to look at
8094 IDENTIFIER_GLOBAL_VALUE. */
8095 tmp = lookup_name (DECL_ASSEMBLER_NAME (decl), 0);
8096 if (tmp == NULL_TREE)
8097 SET_IDENTIFIER_GLOBAL_VALUE (DECL_ASSEMBLER_NAME (decl), decl);
8098 else if (TREE_CODE (tmp) != TREE_CODE (decl))
8099 cp_error ("inconsistent declarations for `%D'", decl);
8100 else
8101 {
8102 duplicate_decls (decl, tmp);
8103 decl = tmp;
8104 }
8105 }
8106
8107 if (attrlist)
8108 cplus_decl_attributes (decl, TREE_PURPOSE (attrlist),
8109 TREE_VALUE (attrlist));
8110 make_decl_rtl (decl, NULL_PTR, 1);
8111 }
8112 if (virtualp)
8113 {
8114 DECL_VIRTUAL_P (decl) = 1;
8115 if (DECL_VINDEX (decl) == NULL_TREE)
8116 DECL_VINDEX (decl) = error_mark_node;
8117 IDENTIFIER_VIRTUAL_P (DECL_NAME (decl)) = 1;
8118 }
8119 }
8120 return decl;
8121 }
8122
8123 static tree
8124 grokvardecl (type, declarator, specbits_in, initialized, constp, in_namespace)
8125 tree type;
8126 tree declarator;
8127 RID_BIT_TYPE *specbits_in;
8128 int initialized;
8129 int constp;
8130 tree in_namespace;
8131 {
8132 tree decl;
8133 RID_BIT_TYPE specbits;
8134
8135 specbits = *specbits_in;
8136
8137 if (TREE_CODE (type) == OFFSET_TYPE)
8138 {
8139 /* If you declare a static member so that it
8140 can be initialized, the code will reach here. */
8141 tree basetype = TYPE_OFFSET_BASETYPE (type);
8142 type = TREE_TYPE (type);
8143 decl = build_lang_field_decl (VAR_DECL, declarator, type);
8144 DECL_CONTEXT (decl) = basetype;
8145 DECL_CLASS_CONTEXT (decl) = basetype;
8146 DECL_ASSEMBLER_NAME (decl) = build_static_name (basetype, declarator);
8147 }
8148 else
8149 {
8150 tree context = in_namespace ? in_namespace : current_namespace;
8151 decl = build_decl (VAR_DECL, declarator, complete_type (type));
8152 if (context != global_namespace && namespace_bindings_p ()
8153 && current_lang_name != lang_name_c)
8154 DECL_ASSEMBLER_NAME (decl) = build_static_name (context,
8155 declarator);
8156 }
8157
8158 if (in_namespace)
8159 set_decl_namespace (decl, in_namespace);
8160
8161 if (RIDBIT_SETP (RID_EXTERN, specbits))
8162 {
8163 DECL_THIS_EXTERN (decl) = 1;
8164 DECL_EXTERNAL (decl) = !initialized;
8165 }
8166
8167 /* In class context, static means one per class,
8168 public access, and static storage. */
8169 if (DECL_CLASS_SCOPE_P (decl))
8170 {
8171 TREE_PUBLIC (decl) = 1;
8172 TREE_STATIC (decl) = 1;
8173 DECL_EXTERNAL (decl) = 0;
8174 }
8175 /* At top level, either `static' or no s.c. makes a definition
8176 (perhaps tentative), and absence of `static' makes it public. */
8177 else if (toplevel_bindings_p ())
8178 {
8179 TREE_PUBLIC (decl) = (RIDBIT_NOTSETP (RID_STATIC, specbits)
8180 && (DECL_THIS_EXTERN (decl) || ! constp));
8181 TREE_STATIC (decl) = ! DECL_EXTERNAL (decl);
8182 }
8183 /* Not at top level, only `static' makes a static definition. */
8184 else
8185 {
8186 TREE_STATIC (decl) = !! RIDBIT_SETP (RID_STATIC, specbits);
8187 TREE_PUBLIC (decl) = DECL_EXTERNAL (decl);
8188 }
8189
8190 if (TREE_PUBLIC (decl))
8191 {
8192 /* [basic.link]: A name with no linkage (notably, the name of a class
8193 or enumeration declared in a local scope) shall not be used to
8194 declare an entity with linkage.
8195
8196 Only check this for public decls for now. */
8197 tree t = no_linkage_check (TREE_TYPE (decl));
8198 if (t)
8199 {
8200 if (ANON_AGGRNAME_P (TYPE_IDENTIFIER (t)))
8201 /* Ignore for now; `enum { foo } e' is pretty common. */;
8202 else
8203 cp_pedwarn ("non-local variable `%#D' uses local type `%T'",
8204 decl, t);
8205 }
8206 }
8207
8208 return decl;
8209 }
8210
8211 /* Create a canonical pointer to member function type. */
8212
8213 tree
8214 build_ptrmemfunc_type (type)
8215 tree type;
8216 {
8217 tree fields[4];
8218 tree t;
8219 tree u;
8220
8221 /* If a canonical type already exists for this type, use it. We use
8222 this method instead of type_hash_canon, because it only does a
8223 simple equality check on the list of field members. */
8224
8225 if ((t = TYPE_GET_PTRMEMFUNC_TYPE (type)))
8226 return t;
8227
8228 push_obstacks (TYPE_OBSTACK (type), TYPE_OBSTACK (type));
8229
8230 u = make_lang_type (UNION_TYPE);
8231 IS_AGGR_TYPE (u) = 0;
8232 fields[0] = build_lang_field_decl (FIELD_DECL, pfn_identifier, type);
8233 fields[1] = build_lang_field_decl (FIELD_DECL, delta2_identifier,
8234 delta_type_node);
8235 finish_builtin_type (u, "__ptrmemfunc_type", fields, 1, ptr_type_node);
8236 TYPE_NAME (u) = NULL_TREE;
8237
8238 t = make_lang_type (RECORD_TYPE);
8239
8240 /* Let the front-end know this is a pointer to member function... */
8241 TYPE_PTRMEMFUNC_FLAG (t) = 1;
8242 /* ... and not really an aggregate. */
8243 IS_AGGR_TYPE (t) = 0;
8244
8245 fields[0] = build_lang_field_decl (FIELD_DECL, delta_identifier,
8246 delta_type_node);
8247 fields[1] = build_lang_field_decl (FIELD_DECL, index_identifier,
8248 delta_type_node);
8249 fields[2] = build_lang_field_decl (FIELD_DECL, pfn_or_delta2_identifier, u);
8250 finish_builtin_type (t, "__ptrmemfunc_type", fields, 2, ptr_type_node);
8251
8252 pop_obstacks ();
8253
8254 /* Zap out the name so that the back-end will give us the debugging
8255 information for this anonymous RECORD_TYPE. */
8256 TYPE_NAME (t) = NULL_TREE;
8257
8258 TYPE_SET_PTRMEMFUNC_TYPE (type, t);
8259
8260 /* Seems to be wanted. */
8261 CLASSTYPE_GOT_SEMICOLON (t) = 1;
8262 return t;
8263 }
8264
8265 /* Given declspecs and a declarator,
8266 determine the name and type of the object declared
8267 and construct a ..._DECL node for it.
8268 (In one case we can return a ..._TYPE node instead.
8269 For invalid input we sometimes return 0.)
8270
8271 DECLSPECS is a chain of tree_list nodes whose value fields
8272 are the storage classes and type specifiers.
8273
8274 DECL_CONTEXT says which syntactic context this declaration is in:
8275 NORMAL for most contexts. Make a VAR_DECL or FUNCTION_DECL or TYPE_DECL.
8276 FUNCDEF for a function definition. Like NORMAL but a few different
8277 error messages in each case. Return value may be zero meaning
8278 this definition is too screwy to try to parse.
8279 MEMFUNCDEF for a function definition. Like FUNCDEF but prepares to
8280 handle member functions (which have FIELD context).
8281 Return value may be zero meaning this definition is too screwy to
8282 try to parse.
8283 PARM for a parameter declaration (either within a function prototype
8284 or before a function body). Make a PARM_DECL, or return void_type_node.
8285 CATCHPARM for a parameter declaration before a catch clause.
8286 TYPENAME if for a typename (in a cast or sizeof).
8287 Don't make a DECL node; just return the ..._TYPE node.
8288 FIELD for a struct or union field; make a FIELD_DECL.
8289 BITFIELD for a field with specified width.
8290 INITIALIZED is 1 if the decl has an initializer.
8291
8292 In the TYPENAME case, DECLARATOR is really an absolute declarator.
8293 It may also be so in the PARM case, for a prototype where the
8294 argument type is specified but not the name.
8295
8296 This function is where the complicated C meanings of `static'
8297 and `extern' are interpreted.
8298
8299 For C++, if there is any monkey business to do, the function which
8300 calls this one must do it, i.e., prepending instance variables,
8301 renaming overloaded function names, etc.
8302
8303 Note that for this C++, it is an error to define a method within a class
8304 which does not belong to that class.
8305
8306 Except in the case where SCOPE_REFs are implicitly known (such as
8307 methods within a class being redundantly qualified),
8308 declarations which involve SCOPE_REFs are returned as SCOPE_REFs
8309 (class_name::decl_name). The caller must also deal with this.
8310
8311 If a constructor or destructor is seen, and the context is FIELD,
8312 then the type gains the attribute TREE_HAS_x. If such a declaration
8313 is erroneous, NULL_TREE is returned.
8314
8315 QUALS is used only for FUNCDEF and MEMFUNCDEF cases. For a member
8316 function, these are the qualifiers to give to the `this' pointer.
8317
8318 May return void_type_node if the declarator turned out to be a friend.
8319 See grokfield for details. */
8320
8321 enum return_types { return_normal, return_ctor, return_dtor, return_conversion };
8322
8323 tree
8324 grokdeclarator (declarator, declspecs, decl_context, initialized, attrlist)
8325 tree declspecs;
8326 tree declarator;
8327 enum decl_context decl_context;
8328 int initialized;
8329 tree attrlist;
8330 {
8331 RID_BIT_TYPE specbits;
8332 int nclasses = 0;
8333 tree spec;
8334 tree type = NULL_TREE;
8335 int longlong = 0;
8336 int constp;
8337 int volatilep;
8338 int virtualp, explicitp, friendp, inlinep, staticp;
8339 int explicit_int = 0;
8340 int explicit_char = 0;
8341 int defaulted_int = 0;
8342 int opaque_typedef = 0;
8343 tree typedef_decl = NULL_TREE;
8344 char *name;
8345 tree typedef_type = NULL_TREE;
8346 int funcdef_flag = 0;
8347 enum tree_code innermost_code = ERROR_MARK;
8348 int bitfield = 0;
8349 #if 0
8350 /* See the code below that used this. */
8351 tree decl_machine_attr = NULL_TREE;
8352 #endif
8353 /* Set this to error_mark_node for FIELD_DECLs we could not handle properly.
8354 All FIELD_DECLs we build here have `init' put into their DECL_INITIAL. */
8355 tree init = NULL_TREE;
8356
8357 /* Keep track of what sort of function is being processed
8358 so that we can warn about default return values, or explicit
8359 return values which do not match prescribed defaults. */
8360 enum return_types return_type = return_normal;
8361
8362 tree dname = NULL_TREE;
8363 tree ctype = current_class_type;
8364 tree ctor_return_type = NULL_TREE;
8365 enum overload_flags flags = NO_SPECIAL;
8366 tree quals = NULL_TREE;
8367 tree raises = NULL_TREE;
8368 int template_count = 0;
8369 tree in_namespace = NULL_TREE;
8370
8371 RIDBIT_RESET_ALL (specbits);
8372 if (decl_context == FUNCDEF)
8373 funcdef_flag = 1, decl_context = NORMAL;
8374 else if (decl_context == MEMFUNCDEF)
8375 funcdef_flag = -1, decl_context = FIELD;
8376 else if (decl_context == BITFIELD)
8377 bitfield = 1, decl_context = FIELD;
8378
8379 /* Look inside a declarator for the name being declared
8380 and get it as a string, for an error message. */
8381 {
8382 tree *next = &declarator;
8383 register tree decl;
8384 name = NULL;
8385
8386 while (next && *next)
8387 {
8388 decl = *next;
8389 switch (TREE_CODE (decl))
8390 {
8391 case COND_EXPR:
8392 ctype = NULL_TREE;
8393 next = &TREE_OPERAND (decl, 0);
8394 break;
8395
8396 case BIT_NOT_EXPR: /* For C++ destructors! */
8397 {
8398 tree name = TREE_OPERAND (decl, 0);
8399 tree rename = NULL_TREE;
8400
8401 my_friendly_assert (flags == NO_SPECIAL, 152);
8402 flags = DTOR_FLAG;
8403 return_type = return_dtor;
8404 if (TREE_CODE (name) == TYPE_DECL)
8405 TREE_OPERAND (decl, 0) = name = constructor_name (name);
8406 my_friendly_assert (TREE_CODE (name) == IDENTIFIER_NODE, 153);
8407 if (ctype == NULL_TREE)
8408 {
8409 if (current_class_type == NULL_TREE)
8410 {
8411 error ("destructors must be member functions");
8412 flags = NO_SPECIAL;
8413 }
8414 else
8415 {
8416 tree t = constructor_name (current_class_name);
8417 if (t != name)
8418 rename = t;
8419 }
8420 }
8421 else
8422 {
8423 tree t = constructor_name (ctype);
8424 if (t != name)
8425 rename = t;
8426 }
8427
8428 if (rename)
8429 {
8430 cp_error ("destructor `%T' must match class name `%T'",
8431 name, rename);
8432 TREE_OPERAND (decl, 0) = rename;
8433 }
8434 next = &name;
8435 }
8436 break;
8437
8438 case ADDR_EXPR: /* C++ reference declaration */
8439 /* Fall through. */
8440 case ARRAY_REF:
8441 case INDIRECT_REF:
8442 ctype = NULL_TREE;
8443 innermost_code = TREE_CODE (decl);
8444 next = &TREE_OPERAND (decl, 0);
8445 break;
8446
8447 case CALL_EXPR:
8448 if (parmlist_is_exprlist (TREE_OPERAND (decl, 1)))
8449 {
8450 /* This is actually a variable declaration using constructor
8451 syntax. We need to call start_decl and cp_finish_decl so we
8452 can get the variable initialized... */
8453
8454 *next = TREE_OPERAND (decl, 0);
8455 init = TREE_OPERAND (decl, 1);
8456
8457 decl = start_decl (declarator, declspecs, 1, NULL_TREE, NULL_TREE);
8458 /* Look for __unused__ attribute */
8459 if (TREE_USED (TREE_TYPE (decl)))
8460 TREE_USED (decl) = 1;
8461 finish_decl (decl, init, NULL_TREE);
8462 return 0;
8463 }
8464 innermost_code = TREE_CODE (decl);
8465 if (decl_context == FIELD && ctype == NULL_TREE)
8466 ctype = current_class_type;
8467 if (ctype
8468 && TREE_OPERAND (decl, 0)
8469 && (TREE_CODE (TREE_OPERAND (decl, 0)) == TYPE_DECL
8470 && ((DECL_NAME (TREE_OPERAND (decl, 0))
8471 == constructor_name_full (ctype))
8472 || (DECL_NAME (TREE_OPERAND (decl, 0))
8473 == constructor_name (ctype)))))
8474 TREE_OPERAND (decl, 0) = constructor_name (ctype);
8475 next = &TREE_OPERAND (decl, 0);
8476 decl = *next;
8477 if (ctype != NULL_TREE
8478 && decl != NULL_TREE && flags != DTOR_FLAG
8479 && decl == constructor_name (ctype))
8480 {
8481 return_type = return_ctor;
8482 ctor_return_type = ctype;
8483 }
8484 ctype = NULL_TREE;
8485 break;
8486
8487 case TEMPLATE_ID_EXPR:
8488 {
8489 tree fns = TREE_OPERAND (decl, 0);
8490
8491 if (TREE_CODE (fns) == LOOKUP_EXPR)
8492 fns = TREE_OPERAND (fns, 0);
8493
8494 if (TREE_CODE (fns) == IDENTIFIER_NODE)
8495 dname = fns;
8496 else if (is_overloaded_fn (fns))
8497 dname = DECL_NAME (get_first_fn (fns));
8498 else
8499 my_friendly_abort (0);
8500 }
8501 /* Fall through. */
8502
8503 case IDENTIFIER_NODE:
8504 if (TREE_CODE (decl) == IDENTIFIER_NODE)
8505 dname = decl;
8506
8507 next = 0;
8508
8509 if (is_rid (dname))
8510 {
8511 cp_error ("declarator-id missing; using reserved word `%D'",
8512 dname);
8513 name = IDENTIFIER_POINTER (dname);
8514 }
8515 if (! IDENTIFIER_OPNAME_P (dname)
8516 /* GNU/Linux headers use '__op'. Arrgh. */
8517 || (IDENTIFIER_TYPENAME_P (dname) && ! TREE_TYPE (dname)))
8518 name = IDENTIFIER_POINTER (dname);
8519 else
8520 {
8521 if (IDENTIFIER_TYPENAME_P (dname))
8522 {
8523 my_friendly_assert (flags == NO_SPECIAL, 154);
8524 flags = TYPENAME_FLAG;
8525 ctor_return_type = TREE_TYPE (dname);
8526 return_type = return_conversion;
8527 }
8528 name = operator_name_string (dname);
8529 }
8530 break;
8531
8532 /* C++ extension */
8533 case SCOPE_REF:
8534 {
8535 /* Perform error checking, and decide on a ctype. */
8536 tree cname = TREE_OPERAND (decl, 0);
8537 if (cname == NULL_TREE)
8538 ctype = NULL_TREE;
8539 else if (TREE_CODE (cname) == NAMESPACE_DECL)
8540 {
8541 ctype = NULL_TREE;
8542 in_namespace = TREE_OPERAND (decl, 0);
8543 TREE_OPERAND (decl, 0) = NULL_TREE;
8544 }
8545 else if (! is_aggr_type (cname, 1))
8546 TREE_OPERAND (decl, 0) = NULL_TREE;
8547 /* Must test TREE_OPERAND (decl, 1), in case user gives
8548 us `typedef (class::memfunc)(int); memfunc *memfuncptr;' */
8549 else if (TREE_OPERAND (decl, 1)
8550 && TREE_CODE (TREE_OPERAND (decl, 1)) == INDIRECT_REF)
8551 ctype = cname;
8552 else if (TREE_CODE (cname) == TEMPLATE_TYPE_PARM
8553 || TREE_CODE (cname) == TEMPLATE_TEMPLATE_PARM)
8554 {
8555 cp_error ("`%T::%D' is not a valid declarator", cname,
8556 TREE_OPERAND (decl, 1));
8557 cp_error (" perhaps you want `typename %T::%D' to make it a type",
8558 cname, TREE_OPERAND (decl, 1));
8559 return void_type_node;
8560 }
8561 else if (ctype == NULL_TREE)
8562 ctype = cname;
8563 else if (TREE_COMPLEXITY (decl) == current_class_depth)
8564 TREE_OPERAND (decl, 0) = ctype;
8565 else
8566 {
8567 if (! UNIQUELY_DERIVED_FROM_P (cname, ctype))
8568 {
8569 cp_error ("type `%T' is not derived from type `%T'",
8570 cname, ctype);
8571 TREE_OPERAND (decl, 0) = NULL_TREE;
8572 }
8573 else
8574 ctype = cname;
8575 }
8576
8577 if (ctype && TREE_CODE (TREE_OPERAND (decl, 1)) == TYPE_DECL
8578 && ((DECL_NAME (TREE_OPERAND (decl, 1))
8579 == constructor_name_full (ctype))
8580 || (DECL_NAME (TREE_OPERAND (decl, 1))
8581 == constructor_name (ctype))))
8582 TREE_OPERAND (decl, 1) = constructor_name (ctype);
8583 next = &TREE_OPERAND (decl, 1);
8584 decl = *next;
8585 if (ctype)
8586 {
8587 if (TREE_CODE (decl) == IDENTIFIER_NODE
8588 && constructor_name (ctype) == decl)
8589 {
8590 return_type = return_ctor;
8591 ctor_return_type = ctype;
8592 }
8593 else if (TREE_CODE (decl) == BIT_NOT_EXPR
8594 && TREE_CODE (TREE_OPERAND (decl, 0)) == IDENTIFIER_NODE
8595 && (constructor_name (ctype) == TREE_OPERAND (decl, 0)
8596 || constructor_name_full (ctype) == TREE_OPERAND (decl, 0)))
8597 {
8598 return_type = return_dtor;
8599 ctor_return_type = ctype;
8600 flags = DTOR_FLAG;
8601 TREE_OPERAND (decl, 0) = constructor_name (ctype);
8602 next = &TREE_OPERAND (decl, 0);
8603 }
8604 }
8605 }
8606 break;
8607
8608 case ERROR_MARK:
8609 next = 0;
8610 break;
8611
8612 case TYPE_DECL:
8613 /* Parse error puts this typespec where
8614 a declarator should go. */
8615 cp_error ("`%T' specified as declarator-id", DECL_NAME (decl));
8616 if (TREE_TYPE (decl) == current_class_type)
8617 cp_error (" perhaps you want `%T' for a constructor",
8618 current_class_name);
8619 dname = DECL_NAME (decl);
8620 name = IDENTIFIER_POINTER (dname);
8621
8622 /* Avoid giving two errors for this. */
8623 IDENTIFIER_CLASS_VALUE (dname) = NULL_TREE;
8624
8625 declspecs = temp_tree_cons (NULL_TREE, integer_type_node,
8626 declspecs);
8627 *next = dname;
8628 next = 0;
8629 break;
8630
8631 default:
8632 cp_compiler_error ("`%D' as declarator", decl);
8633 return 0; /* We used to do a 155 abort here. */
8634 }
8635 }
8636 if (name == NULL)
8637 name = "type name";
8638 }
8639
8640 /* A function definition's declarator must have the form of
8641 a function declarator. */
8642
8643 if (funcdef_flag && innermost_code != CALL_EXPR)
8644 return 0;
8645
8646 if (((dname && IDENTIFIER_OPNAME_P (dname)) || flags == TYPENAME_FLAG)
8647 && innermost_code != CALL_EXPR
8648 && ! (ctype && declspecs == NULL_TREE))
8649 {
8650 cp_error ("declaration of `%D' as non-function", dname);
8651 return void_type_node;
8652 }
8653
8654 /* Anything declared one level down from the top level
8655 must be one of the parameters of a function
8656 (because the body is at least two levels down). */
8657
8658 /* This heuristic cannot be applied to C++ nodes! Fixed, however,
8659 by not allowing C++ class definitions to specify their parameters
8660 with xdecls (must be spec.d in the parmlist).
8661
8662 Since we now wait to push a class scope until we are sure that
8663 we are in a legitimate method context, we must set oldcname
8664 explicitly (since current_class_name is not yet alive).
8665
8666 We also want to avoid calling this a PARM if it is in a namespace. */
8667
8668 if (decl_context == NORMAL && ! namespace_bindings_p ()
8669 && ! pseudo_global_level_p ())
8670 {
8671 struct binding_level *b = current_binding_level;
8672 current_binding_level = b->level_chain;
8673 if (current_binding_level != 0 && toplevel_bindings_p ())
8674 decl_context = PARM;
8675 current_binding_level = b;
8676 }
8677
8678 /* Look through the decl specs and record which ones appear.
8679 Some typespecs are defined as built-in typenames.
8680 Others, the ones that are modifiers of other types,
8681 are represented by bits in SPECBITS: set the bits for
8682 the modifiers that appear. Storage class keywords are also in SPECBITS.
8683
8684 If there is a typedef name or a type, store the type in TYPE.
8685 This includes builtin typedefs such as `int'.
8686
8687 Set EXPLICIT_INT if the type is `int' or `char' and did not
8688 come from a user typedef.
8689
8690 Set LONGLONG if `long' is mentioned twice.
8691
8692 For C++, constructors and destructors have their own fast treatment. */
8693
8694 for (spec = declspecs; spec; spec = TREE_CHAIN (spec))
8695 {
8696 register int i;
8697 register tree id;
8698
8699 /* Certain parse errors slip through. For example,
8700 `int class;' is not caught by the parser. Try
8701 weakly to recover here. */
8702 if (TREE_CODE (spec) != TREE_LIST)
8703 return 0;
8704
8705 id = TREE_VALUE (spec);
8706
8707 if (TREE_CODE (id) == IDENTIFIER_NODE)
8708 {
8709 if (id == ridpointers[(int) RID_INT]
8710 || id == ridpointers[(int) RID_CHAR]
8711 || id == ridpointers[(int) RID_BOOL]
8712 || id == ridpointers[(int) RID_WCHAR])
8713 {
8714 if (type)
8715 {
8716 if (id == ridpointers[(int) RID_BOOL])
8717 error ("`bool' is now a keyword");
8718 else
8719 cp_error ("extraneous `%T' ignored", id);
8720 }
8721 else
8722 {
8723 if (id == ridpointers[(int) RID_INT])
8724 explicit_int = 1;
8725 else if (id == ridpointers[(int) RID_CHAR])
8726 explicit_char = 1;
8727 type = TREE_TYPE (IDENTIFIER_GLOBAL_VALUE (id));
8728 }
8729 goto found;
8730 }
8731 /* C++ aggregate types. */
8732 if (IDENTIFIER_HAS_TYPE_VALUE (id))
8733 {
8734 if (type)
8735 cp_error ("multiple declarations `%T' and `%T'", type, id);
8736 else
8737 type = IDENTIFIER_TYPE_VALUE (id);
8738 goto found;
8739 }
8740
8741 for (i = (int) RID_FIRST_MODIFIER; i <= (int) RID_LAST_MODIFIER; i++)
8742 {
8743 if (ridpointers[i] == id)
8744 {
8745 if (i == (int) RID_LONG && RIDBIT_SETP (i, specbits))
8746 {
8747 if (pedantic && ! in_system_header && warn_long_long)
8748 pedwarn ("ANSI C++ does not support `long long'");
8749 if (longlong)
8750 error ("`long long long' is too long for GCC");
8751 else
8752 longlong = 1;
8753 }
8754 else if (RIDBIT_SETP (i, specbits))
8755 pedwarn ("duplicate `%s'", IDENTIFIER_POINTER (id));
8756 RIDBIT_SET (i, specbits);
8757 goto found;
8758 }
8759 }
8760 }
8761 /* C++ aggregate types. */
8762 else if (TREE_CODE (id) == TYPE_DECL || TREE_CODE (id) == TEMPLATE_DECL)
8763 {
8764 if (type)
8765 cp_error ("multiple declarations `%T' and `%T'", type,
8766 TREE_TYPE (id));
8767 else
8768 {
8769 type = TREE_TYPE (id);
8770 TREE_VALUE (spec) = type;
8771 }
8772 goto found;
8773 }
8774 if (type)
8775 error ("two or more data types in declaration of `%s'", name);
8776 else if (TREE_CODE (id) == IDENTIFIER_NODE)
8777 {
8778 register tree t = lookup_name (id, 1);
8779 if (!t || TREE_CODE (t) != TYPE_DECL)
8780 error ("`%s' fails to be a typedef or built in type",
8781 IDENTIFIER_POINTER (id));
8782 else
8783 {
8784 type = TREE_TYPE (t);
8785 #if 0
8786 /* See the code below that used this. */
8787 decl_machine_attr = DECL_MACHINE_ATTRIBUTES (id);
8788 #endif
8789 typedef_decl = t;
8790 }
8791 }
8792 else if (id != error_mark_node)
8793 /* Can't change CLASS nodes into RECORD nodes here! */
8794 type = id;
8795
8796 found: ;
8797 }
8798
8799 typedef_type = type;
8800
8801 /* No type at all: default to `int', and set DEFAULTED_INT
8802 because it was not a user-defined typedef.
8803 Except when we have a `typedef' inside a signature, in
8804 which case the type defaults to `unknown type' and is
8805 instantiated when assigning to a signature pointer or ref. */
8806
8807 if (type == NULL_TREE
8808 && (RIDBIT_SETP (RID_SIGNED, specbits)
8809 || RIDBIT_SETP (RID_UNSIGNED, specbits)
8810 || RIDBIT_SETP (RID_LONG, specbits)
8811 || RIDBIT_SETP (RID_SHORT, specbits)))
8812 {
8813 /* These imply 'int'. */
8814 type = integer_type_node;
8815 defaulted_int = 1;
8816 }
8817
8818 if (type == NULL_TREE)
8819 {
8820 explicit_int = -1;
8821 if (return_type == return_dtor)
8822 type = void_type_node;
8823 else if (return_type == return_ctor)
8824 type = build_pointer_type (ctor_return_type);
8825 else if (return_type == return_conversion)
8826 type = ctor_return_type;
8827 else if (current_class_type
8828 && IS_SIGNATURE (current_class_type)
8829 && RIDBIT_SETP (RID_TYPEDEF, specbits)
8830 && (decl_context == FIELD || decl_context == NORMAL))
8831 {
8832 explicit_int = 0;
8833 opaque_typedef = 1;
8834 type = copy_node (opaque_type_node);
8835 }
8836 else
8837 {
8838 if (funcdef_flag)
8839 {
8840 if (warn_return_type
8841 && return_type == return_normal)
8842 /* Save warning until we know what is really going on. */
8843 warn_about_return_type = 1;
8844 }
8845 else if (RIDBIT_SETP (RID_TYPEDEF, specbits))
8846 pedwarn ("ANSI C++ forbids typedef which does not specify a type");
8847 else if (innermost_code != CALL_EXPR || pedantic
8848 || (warn_return_type && return_type == return_normal))
8849 {
8850 if (innermost_code == CALL_EXPR)
8851 cp_pedwarn ("return-type of `%D' defaults to `int'", dname);
8852 else
8853 cp_pedwarn ("ANSI C++ forbids declaration `%D' with no type",
8854 dname);
8855 }
8856 type = integer_type_node;
8857 }
8858 }
8859 else if (return_type == return_dtor)
8860 {
8861 error ("return type specification for destructor invalid");
8862 type = void_type_node;
8863 }
8864 else if (return_type == return_ctor)
8865 {
8866 error ("return type specification for constructor invalid");
8867 type = build_pointer_type (ctor_return_type);
8868 }
8869 else if (return_type == return_conversion)
8870 {
8871 if (comptypes (type, ctor_return_type, 1) == 0)
8872 cp_error ("operator `%T' declared to return `%T'",
8873 ctor_return_type, type);
8874 else
8875 cp_pedwarn ("return type specified for `operator %T'",
8876 ctor_return_type);
8877
8878 type = ctor_return_type;
8879 }
8880
8881 ctype = NULL_TREE;
8882
8883 /* Now process the modifiers that were specified
8884 and check for invalid combinations. */
8885
8886 /* Long double is a special combination. */
8887
8888 if (RIDBIT_SETP (RID_LONG, specbits)
8889 && TYPE_MAIN_VARIANT (type) == double_type_node)
8890 {
8891 RIDBIT_RESET (RID_LONG, specbits);
8892 type = build_type_variant (long_double_type_node, TYPE_READONLY (type),
8893 TYPE_VOLATILE (type));
8894 }
8895
8896 /* Check all other uses of type modifiers. */
8897
8898 if (RIDBIT_SETP (RID_UNSIGNED, specbits)
8899 || RIDBIT_SETP (RID_SIGNED, specbits)
8900 || RIDBIT_SETP (RID_LONG, specbits)
8901 || RIDBIT_SETP (RID_SHORT, specbits))
8902 {
8903 int ok = 0;
8904
8905 if (TREE_CODE (type) == REAL_TYPE)
8906 error ("short, signed or unsigned invalid for `%s'", name);
8907 else if (TREE_CODE (type) != INTEGER_TYPE)
8908 error ("long, short, signed or unsigned invalid for `%s'", name);
8909 else if (RIDBIT_SETP (RID_LONG, specbits)
8910 && RIDBIT_SETP (RID_SHORT, specbits))
8911 error ("long and short specified together for `%s'", name);
8912 else if ((RIDBIT_SETP (RID_LONG, specbits)
8913 || RIDBIT_SETP (RID_SHORT, specbits))
8914 && explicit_char)
8915 error ("long or short specified with char for `%s'", name);
8916 else if ((RIDBIT_SETP (RID_LONG, specbits)
8917 || RIDBIT_SETP (RID_SHORT, specbits))
8918 && TREE_CODE (type) == REAL_TYPE)
8919 error ("long or short specified with floating type for `%s'", name);
8920 else if (RIDBIT_SETP (RID_SIGNED, specbits)
8921 && RIDBIT_SETP (RID_UNSIGNED, specbits))
8922 error ("signed and unsigned given together for `%s'", name);
8923 else
8924 {
8925 ok = 1;
8926 if (!explicit_int && !defaulted_int && !explicit_char && pedantic)
8927 {
8928 pedwarn ("long, short, signed or unsigned used invalidly for `%s'",
8929 name);
8930 if (flag_pedantic_errors)
8931 ok = 0;
8932 }
8933 }
8934
8935 /* Discard the type modifiers if they are invalid. */
8936 if (! ok)
8937 {
8938 RIDBIT_RESET (RID_UNSIGNED, specbits);
8939 RIDBIT_RESET (RID_SIGNED, specbits);
8940 RIDBIT_RESET (RID_LONG, specbits);
8941 RIDBIT_RESET (RID_SHORT, specbits);
8942 longlong = 0;
8943 }
8944 }
8945
8946 if (RIDBIT_SETP (RID_COMPLEX, specbits)
8947 && TREE_CODE (type) != INTEGER_TYPE && TREE_CODE (type) != REAL_TYPE)
8948 {
8949 error ("complex invalid for `%s'", name);
8950 RIDBIT_RESET (RID_COMPLEX, specbits);
8951 }
8952
8953 /* Decide whether an integer type is signed or not.
8954 Optionally treat bitfields as signed by default. */
8955 if (RIDBIT_SETP (RID_UNSIGNED, specbits)
8956 || (bitfield && ! flag_signed_bitfields
8957 && (explicit_int || defaulted_int || explicit_char
8958 /* A typedef for plain `int' without `signed'
8959 can be controlled just like plain `int'. */
8960 || ! (typedef_decl != NULL_TREE
8961 && C_TYPEDEF_EXPLICITLY_SIGNED (typedef_decl)))
8962 && TREE_CODE (type) != ENUMERAL_TYPE
8963 && RIDBIT_NOTSETP (RID_SIGNED, specbits)))
8964 {
8965 if (longlong)
8966 type = long_long_unsigned_type_node;
8967 else if (RIDBIT_SETP (RID_LONG, specbits))
8968 type = long_unsigned_type_node;
8969 else if (RIDBIT_SETP (RID_SHORT, specbits))
8970 type = short_unsigned_type_node;
8971 else if (type == char_type_node)
8972 type = unsigned_char_type_node;
8973 else if (typedef_decl)
8974 type = unsigned_type (type);
8975 else
8976 type = unsigned_type_node;
8977 }
8978 else if (RIDBIT_SETP (RID_SIGNED, specbits)
8979 && type == char_type_node)
8980 type = signed_char_type_node;
8981 else if (longlong)
8982 type = long_long_integer_type_node;
8983 else if (RIDBIT_SETP (RID_LONG, specbits))
8984 type = long_integer_type_node;
8985 else if (RIDBIT_SETP (RID_SHORT, specbits))
8986 type = short_integer_type_node;
8987
8988 if (RIDBIT_SETP (RID_COMPLEX, specbits))
8989 {
8990 /* If we just have "complex", it is equivalent to
8991 "complex double", but if any modifiers at all are specified it is
8992 the complex form of TYPE. E.g, "complex short" is
8993 "complex short int". */
8994
8995 if (defaulted_int && ! longlong
8996 && ! (RIDBIT_SETP (RID_LONG, specbits)
8997 || RIDBIT_SETP (RID_SHORT, specbits)
8998 || RIDBIT_SETP (RID_SIGNED, specbits)
8999 || RIDBIT_SETP (RID_UNSIGNED, specbits)))
9000 type = complex_double_type_node;
9001 else if (type == integer_type_node)
9002 type = complex_integer_type_node;
9003 else if (type == float_type_node)
9004 type = complex_float_type_node;
9005 else if (type == double_type_node)
9006 type = complex_double_type_node;
9007 else if (type == long_double_type_node)
9008 type = complex_long_double_type_node;
9009 else
9010 type = build_complex_type (type);
9011 }
9012
9013 if (return_type == return_conversion
9014 && (RIDBIT_SETP (RID_CONST, specbits)
9015 || RIDBIT_SETP (RID_VOLATILE, specbits)))
9016 cp_error ("`operator %T' cannot be cv-qualified",
9017 ctor_return_type);
9018
9019 /* Set CONSTP if this declaration is `const', whether by
9020 explicit specification or via a typedef.
9021 Likewise for VOLATILEP. */
9022
9023 constp = !! RIDBIT_SETP (RID_CONST, specbits) + TYPE_READONLY (type);
9024 volatilep = !! RIDBIT_SETP (RID_VOLATILE, specbits) + TYPE_VOLATILE (type);
9025 type = build_type_variant (type, 0, 0);
9026 staticp = 0;
9027 inlinep = !! RIDBIT_SETP (RID_INLINE, specbits);
9028 virtualp = RIDBIT_SETP (RID_VIRTUAL, specbits);
9029 RIDBIT_RESET (RID_VIRTUAL, specbits);
9030 explicitp = RIDBIT_SETP (RID_EXPLICIT, specbits) != 0;
9031 RIDBIT_RESET (RID_EXPLICIT, specbits);
9032
9033 if (RIDBIT_SETP (RID_STATIC, specbits))
9034 staticp = 1 + (decl_context == FIELD);
9035
9036 if (virtualp && staticp == 2)
9037 {
9038 cp_error ("member `%D' cannot be declared both virtual and static",
9039 dname);
9040 staticp = 0;
9041 }
9042 friendp = RIDBIT_SETP (RID_FRIEND, specbits);
9043 RIDBIT_RESET (RID_FRIEND, specbits);
9044
9045 if (RIDBIT_SETP (RID_MUTABLE, specbits))
9046 {
9047 if (decl_context == PARM)
9048 {
9049 error ("non-member `%s' cannot be declared `mutable'", name);
9050 RIDBIT_RESET (RID_MUTABLE, specbits);
9051 }
9052 else if (friendp || decl_context == TYPENAME)
9053 {
9054 error ("non-object member `%s' cannot be declared `mutable'", name);
9055 RIDBIT_RESET (RID_MUTABLE, specbits);
9056 }
9057 }
9058
9059 /* Warn if two storage classes are given. Default to `auto'. */
9060
9061 if (RIDBIT_ANY_SET (specbits))
9062 {
9063 if (RIDBIT_SETP (RID_STATIC, specbits)) nclasses++;
9064 if (RIDBIT_SETP (RID_EXTERN, specbits)) nclasses++;
9065 if (decl_context == PARM && nclasses > 0)
9066 error ("storage class specifiers invalid in parameter declarations");
9067 if (RIDBIT_SETP (RID_TYPEDEF, specbits))
9068 {
9069 if (decl_context == PARM)
9070 error ("typedef declaration invalid in parameter declaration");
9071 nclasses++;
9072 }
9073 if (RIDBIT_SETP (RID_AUTO, specbits)) nclasses++;
9074 if (RIDBIT_SETP (RID_REGISTER, specbits)) nclasses++;
9075 }
9076
9077 /* Give error if `virtual' is used outside of class declaration. */
9078 if (virtualp
9079 && (current_class_name == NULL_TREE || decl_context != FIELD))
9080 {
9081 error ("virtual outside class declaration");
9082 virtualp = 0;
9083 }
9084 if (current_class_name == NULL_TREE && RIDBIT_SETP (RID_MUTABLE, specbits))
9085 {
9086 error ("only members can be declared mutable");
9087 RIDBIT_RESET (RID_MUTABLE, specbits);
9088 }
9089
9090 /* Static anonymous unions are dealt with here. */
9091 if (staticp && decl_context == TYPENAME
9092 && TREE_CODE (declspecs) == TREE_LIST
9093 && ANON_UNION_TYPE_P (TREE_VALUE (declspecs)))
9094 decl_context = FIELD;
9095
9096 /* Give error if `const,' `volatile,' `inline,' `friend,' or `virtual'
9097 is used in a signature member function declaration. */
9098 if (decl_context == FIELD
9099 && IS_SIGNATURE (current_class_type)
9100 && RIDBIT_NOTSETP (RID_TYPEDEF, specbits))
9101 {
9102 if (constp)
9103 {
9104 error ("`const' specified for signature member function `%s'", name);
9105 constp = 0;
9106 }
9107 if (volatilep)
9108 {
9109 error ("`volatile' specified for signature member function `%s'",
9110 name);
9111 volatilep = 0;
9112 }
9113 if (inlinep)
9114 {
9115 error ("`inline' specified for signature member function `%s'", name);
9116 /* Later, we'll make signature member functions inline. */
9117 inlinep = 0;
9118 }
9119 if (friendp)
9120 {
9121 error ("`friend' declaration in signature definition");
9122 friendp = 0;
9123 }
9124 if (virtualp)
9125 {
9126 error ("`virtual' specified for signature member function `%s'",
9127 name);
9128 /* Later, we'll make signature member functions virtual. */
9129 virtualp = 0;
9130 }
9131 }
9132
9133 /* Warn about storage classes that are invalid for certain
9134 kinds of declarations (parameters, typenames, etc.). */
9135
9136 if (nclasses > 1)
9137 error ("multiple storage classes in declaration of `%s'", name);
9138 else if (decl_context != NORMAL && nclasses > 0)
9139 {
9140 if ((decl_context == PARM || decl_context == CATCHPARM)
9141 && (RIDBIT_SETP (RID_REGISTER, specbits)
9142 || RIDBIT_SETP (RID_AUTO, specbits)))
9143 ;
9144 else if (RIDBIT_SETP (RID_TYPEDEF, specbits))
9145 ;
9146 else if (decl_context == FIELD
9147 && ! IS_SIGNATURE (current_class_type)
9148 /* C++ allows static class elements */
9149 && RIDBIT_SETP (RID_STATIC, specbits))
9150 /* C++ also allows inlines and signed and unsigned elements,
9151 but in those cases we don't come in here. */
9152 ;
9153 else
9154 {
9155 if (decl_context == FIELD)
9156 {
9157 tree tmp = NULL_TREE;
9158 register int op = 0;
9159
9160 if (declarator)
9161 {
9162 /* Avoid trying to get an operand off an identifier node. */
9163 if (TREE_CODE (declarator) == IDENTIFIER_NODE)
9164 tmp = declarator;
9165 else
9166 tmp = TREE_OPERAND (declarator, 0);
9167 op = IDENTIFIER_OPNAME_P (tmp);
9168 }
9169 error ("storage class specified for %s `%s'",
9170 IS_SIGNATURE (current_class_type)
9171 ? (op
9172 ? "signature member operator"
9173 : "signature member function")
9174 : (op ? "member operator" : "field"),
9175 op ? operator_name_string (tmp) : name);
9176 }
9177 else
9178 error (((decl_context == PARM || decl_context == CATCHPARM)
9179 ? "storage class specified for parameter `%s'"
9180 : "storage class specified for typename"), name);
9181 RIDBIT_RESET (RID_REGISTER, specbits);
9182 RIDBIT_RESET (RID_AUTO, specbits);
9183 RIDBIT_RESET (RID_EXTERN, specbits);
9184
9185 if (decl_context == FIELD && IS_SIGNATURE (current_class_type))
9186 {
9187 RIDBIT_RESET (RID_STATIC, specbits);
9188 staticp = 0;
9189 }
9190 }
9191 }
9192 else if (RIDBIT_SETP (RID_EXTERN, specbits) && initialized && !funcdef_flag)
9193 {
9194 if (toplevel_bindings_p ())
9195 {
9196 /* It's common practice (and completely valid) to have a const
9197 be initialized and declared extern. */
9198 if (! constp)
9199 warning ("`%s' initialized and declared `extern'", name);
9200 }
9201 else
9202 error ("`%s' has both `extern' and initializer", name);
9203 }
9204 else if (RIDBIT_SETP (RID_EXTERN, specbits) && funcdef_flag
9205 && ! toplevel_bindings_p ())
9206 error ("nested function `%s' declared `extern'", name);
9207 else if (toplevel_bindings_p ())
9208 {
9209 if (RIDBIT_SETP (RID_AUTO, specbits))
9210 error ("top-level declaration of `%s' specifies `auto'", name);
9211 }
9212
9213 if (nclasses > 0 && friendp)
9214 error ("storage class specifiers invalid in friend function declarations");
9215
9216 /* Now figure out the structure of the declarator proper.
9217 Descend through it, creating more complex types, until we reach
9218 the declared identifier (or NULL_TREE, in an absolute declarator). */
9219
9220 while (declarator && TREE_CODE (declarator) != IDENTIFIER_NODE
9221 && TREE_CODE (declarator) != TEMPLATE_ID_EXPR)
9222 {
9223 /* Each level of DECLARATOR is either an ARRAY_REF (for ...[..]),
9224 an INDIRECT_REF (for *...),
9225 a CALL_EXPR (for ...(...)),
9226 an identifier (for the name being declared)
9227 or a null pointer (for the place in an absolute declarator
9228 where the name was omitted).
9229 For the last two cases, we have just exited the loop.
9230
9231 For C++ it could also be
9232 a SCOPE_REF (for class :: ...). In this case, we have converted
9233 sensible names to types, and those are the values we use to
9234 qualify the member name.
9235 an ADDR_EXPR (for &...),
9236 a BIT_NOT_EXPR (for destructors)
9237
9238 At this point, TYPE is the type of elements of an array,
9239 or for a function to return, or for a pointer to point to.
9240 After this sequence of ifs, TYPE is the type of the
9241 array or function or pointer, and DECLARATOR has had its
9242 outermost layer removed. */
9243
9244 if (type == error_mark_node)
9245 {
9246 if (TREE_CODE (declarator) == SCOPE_REF)
9247 declarator = TREE_OPERAND (declarator, 1);
9248 else
9249 declarator = TREE_OPERAND (declarator, 0);
9250 continue;
9251 }
9252 if (quals != NULL_TREE
9253 && (declarator == NULL_TREE
9254 || TREE_CODE (declarator) != SCOPE_REF))
9255 {
9256 if (ctype == NULL_TREE && TREE_CODE (type) == METHOD_TYPE)
9257 ctype = TYPE_METHOD_BASETYPE (type);
9258 if (ctype != NULL_TREE)
9259 {
9260 tree dummy = build_decl (TYPE_DECL, NULL_TREE, type);
9261 ctype = grok_method_quals (ctype, dummy, quals);
9262 type = TREE_TYPE (dummy);
9263 quals = NULL_TREE;
9264 }
9265 }
9266 switch (TREE_CODE (declarator))
9267 {
9268 case ARRAY_REF:
9269 {
9270 register tree itype = NULL_TREE;
9271 register tree size = TREE_OPERAND (declarator, 1);
9272 /* The index is a signed object `sizetype' bits wide. */
9273 tree index_type = signed_type (sizetype);
9274
9275 declarator = TREE_OPERAND (declarator, 0);
9276
9277 /* Check for some types that there cannot be arrays of. */
9278
9279 if (TREE_CODE (type) == VOID_TYPE)
9280 {
9281 cp_error ("declaration of `%D' as array of voids", dname);
9282 type = error_mark_node;
9283 }
9284
9285 if (TREE_CODE (type) == FUNCTION_TYPE)
9286 {
9287 cp_error ("declaration of `%D' as array of functions", dname);
9288 type = error_mark_node;
9289 }
9290
9291 /* ARM $8.4.3: Since you can't have a pointer to a reference,
9292 you can't have arrays of references. If we allowed them,
9293 then we'd be saying x[i] is valid for an array x, but
9294 then you'd have to ask: what does `*(x + i)' mean? */
9295 if (TREE_CODE (type) == REFERENCE_TYPE)
9296 {
9297 if (decl_context == TYPENAME)
9298 cp_error ("cannot make arrays of references");
9299 else
9300 cp_error ("declaration of `%D' as array of references",
9301 dname);
9302 type = error_mark_node;
9303 }
9304
9305 if (TREE_CODE (type) == OFFSET_TYPE)
9306 {
9307 cp_error ("declaration of `%D' as array of data members",
9308 dname);
9309 type = error_mark_node;
9310 }
9311
9312 if (TREE_CODE (type) == METHOD_TYPE)
9313 {
9314 cp_error ("declaration of `%D' as array of function members",
9315 dname);
9316 type = error_mark_node;
9317 }
9318
9319 if (size == error_mark_node)
9320 type = error_mark_node;
9321
9322 if (type == error_mark_node)
9323 continue;
9324
9325 if (size)
9326 {
9327 /* Must suspend_momentary here because the index
9328 type may need to live until the end of the function.
9329 For example, it is used in the declaration of a
9330 variable which requires destructing at the end of
9331 the function; then build_vec_delete will need this
9332 value. */
9333 int yes = suspend_momentary ();
9334 /* Might be a cast. */
9335 if (TREE_CODE (size) == NOP_EXPR
9336 && TREE_TYPE (size) == TREE_TYPE (TREE_OPERAND (size, 0)))
9337 size = TREE_OPERAND (size, 0);
9338
9339 /* If this involves a template parameter, it'll be
9340 constant, but we don't know what the value is yet. */
9341 if (processing_template_decl)
9342 {
9343 itype = make_node (INTEGER_TYPE);
9344 TYPE_MIN_VALUE (itype) = size_zero_node;
9345 TYPE_MAX_VALUE (itype) = build_min
9346 (MINUS_EXPR, sizetype, size, integer_one_node);
9347 goto dont_grok_size;
9348 }
9349
9350 if (TREE_CODE (TREE_TYPE (size)) != INTEGER_TYPE
9351 && TREE_CODE (TREE_TYPE (size)) != ENUMERAL_TYPE)
9352 {
9353 cp_error ("size of array `%D' has non-integer type",
9354 dname);
9355 size = integer_one_node;
9356 }
9357 if (TREE_READONLY_DECL_P (size))
9358 size = decl_constant_value (size);
9359 if (pedantic && integer_zerop (size))
9360 cp_pedwarn ("ANSI C++ forbids zero-size array `%D'", dname);
9361 if (TREE_CONSTANT (size))
9362 {
9363 int old_flag_pedantic_errors = flag_pedantic_errors;
9364 int old_pedantic = pedantic;
9365 pedantic = flag_pedantic_errors = 1;
9366 /* Always give overflow errors on array subscripts. */
9367 constant_expression_warning (size);
9368 pedantic = old_pedantic;
9369 flag_pedantic_errors = old_flag_pedantic_errors;
9370 if (INT_CST_LT (size, integer_zero_node))
9371 {
9372 cp_error ("size of array `%D' is negative", dname);
9373 size = integer_one_node;
9374 }
9375 }
9376 else
9377 {
9378 if (pedantic)
9379 {
9380 if (dname)
9381 cp_pedwarn ("ANSI C++ forbids variable-size array `%D'",
9382 dname);
9383 else
9384 cp_pedwarn ("ANSI C++ forbids variable-size array");
9385 }
9386 }
9387
9388 itype
9389 = fold (build_binary_op (MINUS_EXPR,
9390 cp_convert (index_type, size),
9391 cp_convert (index_type,
9392 integer_one_node), 1));
9393 if (! TREE_CONSTANT (itype))
9394 itype = variable_size (itype);
9395 else if (TREE_OVERFLOW (itype))
9396 {
9397 error ("overflow in array dimension");
9398 TREE_OVERFLOW (itype) = 0;
9399 }
9400
9401 /* If we're a parm, we need to have a permanent type so
9402 mangling checks for re-use will work right. If both the
9403 element and index types are permanent, the array type
9404 will be, too. */
9405 if (decl_context == PARM
9406 && allocation_temporary_p () && TREE_PERMANENT (type))
9407 {
9408 push_obstacks (&permanent_obstack, &permanent_obstack);
9409 itype = build_index_type (itype);
9410 pop_obstacks ();
9411 }
9412 else
9413 itype = build_index_type (itype);
9414
9415 dont_grok_size:
9416 resume_momentary (yes);
9417 }
9418
9419 /* Build the array type itself, then merge any constancy or
9420 volatility into the target type. We must do it in this order
9421 to ensure that the TYPE_MAIN_VARIANT field of the array type
9422 is set correctly. */
9423
9424 type = build_cplus_array_type (type, itype);
9425 if (constp || volatilep)
9426 type = cp_build_type_variant (type, constp, volatilep);
9427
9428 ctype = NULL_TREE;
9429 }
9430 break;
9431
9432 case CALL_EXPR:
9433 {
9434 tree arg_types;
9435 int funcdecl_p;
9436 tree inner_parms = TREE_OPERAND (declarator, 1);
9437 tree inner_decl = TREE_OPERAND (declarator, 0);
9438
9439 /* Declaring a function type.
9440 Make sure we have a valid type for the function to return. */
9441 #if 0
9442 /* Is this an error? Should they be merged into TYPE here? */
9443 if (pedantic && (constp || volatilep))
9444 pedwarn ("function declared to return const or volatile result");
9445 #else
9446 /* Merge any constancy or volatility into the function return
9447 type. */
9448
9449 if (constp || volatilep)
9450 {
9451 type = cp_build_type_variant (type, constp, volatilep);
9452 if (IS_AGGR_TYPE (type))
9453 build_pointer_type (type);
9454 constp = 0;
9455 volatilep = 0;
9456 }
9457 #endif
9458
9459 /* Warn about some types functions can't return. */
9460
9461 if (TREE_CODE (type) == FUNCTION_TYPE)
9462 {
9463 error ("`%s' declared as function returning a function", name);
9464 type = integer_type_node;
9465 }
9466 if (TREE_CODE (type) == ARRAY_TYPE)
9467 {
9468 error ("`%s' declared as function returning an array", name);
9469 type = integer_type_node;
9470 }
9471
9472 if (inner_decl && TREE_CODE (inner_decl) == SCOPE_REF)
9473 inner_decl = TREE_OPERAND (inner_decl, 1);
9474
9475 if (inner_decl && TREE_CODE (inner_decl) == TEMPLATE_ID_EXPR)
9476 inner_decl = dname;
9477
9478 /* Pick up type qualifiers which should be applied to `this'. */
9479 quals = TREE_OPERAND (declarator, 2);
9480
9481 /* Pick up the exception specifications. */
9482 raises = TREE_TYPE (declarator);
9483
9484 /* Say it's a definition only for the CALL_EXPR
9485 closest to the identifier. */
9486 funcdecl_p
9487 = inner_decl
9488 && (TREE_CODE (inner_decl) == IDENTIFIER_NODE
9489 || TREE_CODE (inner_decl) == TEMPLATE_ID_EXPR
9490 || TREE_CODE (inner_decl) == BIT_NOT_EXPR);
9491
9492 if (ctype == NULL_TREE
9493 && decl_context == FIELD
9494 && funcdecl_p
9495 && (friendp == 0 || dname == current_class_name))
9496 ctype = current_class_type;
9497
9498 if (ctype && return_type == return_conversion)
9499 TYPE_HAS_CONVERSION (ctype) = 1;
9500 if (ctype && constructor_name (ctype) == dname)
9501 {
9502 /* We are within a class's scope. If our declarator name
9503 is the same as the class name, and we are defining
9504 a function, then it is a constructor/destructor, and
9505 therefore returns a void type. */
9506
9507 if (flags == DTOR_FLAG)
9508 {
9509 /* ANSI C++ June 5 1992 WP 12.4.1. A destructor may
9510 not be declared const or volatile. A destructor
9511 may not be static. */
9512 if (staticp == 2)
9513 error ("destructor cannot be static member function");
9514 if (quals)
9515 {
9516 error ("destructors cannot be declared `const' or `volatile'");
9517 return void_type_node;
9518 }
9519 if (decl_context == FIELD)
9520 {
9521 if (! member_function_or_else (ctype, current_class_type,
9522 "destructor for alien class `%s' cannot be a member"))
9523 return void_type_node;
9524 }
9525 }
9526 else /* It's a constructor. */
9527 {
9528 if (explicitp == 1)
9529 explicitp = 2;
9530 /* ANSI C++ June 5 1992 WP 12.1.2. A constructor may
9531 not be declared const or volatile. A constructor may
9532 not be virtual. A constructor may not be static. */
9533 if (staticp == 2)
9534 error ("constructor cannot be static member function");
9535 if (virtualp)
9536 {
9537 pedwarn ("constructors cannot be declared virtual");
9538 virtualp = 0;
9539 }
9540 if (quals)
9541 {
9542 error ("constructors cannot be declared `const' or `volatile'");
9543 return void_type_node;
9544 }
9545 {
9546 RID_BIT_TYPE tmp_bits;
9547 bcopy ((void*)&specbits, (void*)&tmp_bits, sizeof (RID_BIT_TYPE));
9548 RIDBIT_RESET (RID_INLINE, tmp_bits);
9549 RIDBIT_RESET (RID_STATIC, tmp_bits);
9550 if (RIDBIT_ANY_SET (tmp_bits))
9551 error ("return value type specifier for constructor ignored");
9552 }
9553 type = build_pointer_type (ctype);
9554 if (decl_context == FIELD
9555 && IS_SIGNATURE (current_class_type))
9556 {
9557 error ("constructor not allowed in signature");
9558 return void_type_node;
9559 }
9560 else if (decl_context == FIELD)
9561 {
9562 if (! member_function_or_else (ctype, current_class_type,
9563 "constructor for alien class `%s' cannot be member"))
9564 return void_type_node;
9565 TYPE_HAS_CONSTRUCTOR (ctype) = 1;
9566 if (return_type != return_ctor)
9567 return NULL_TREE;
9568 }
9569 }
9570 if (decl_context == FIELD)
9571 staticp = 0;
9572 }
9573 else if (friendp)
9574 {
9575 if (initialized)
9576 error ("can't initialize friend function `%s'", name);
9577 if (virtualp)
9578 {
9579 /* Cannot be both friend and virtual. */
9580 error ("virtual functions cannot be friends");
9581 RIDBIT_RESET (RID_FRIEND, specbits);
9582 friendp = 0;
9583 }
9584 if (decl_context == NORMAL)
9585 error ("friend declaration not in class definition");
9586 if (current_function_decl && funcdef_flag)
9587 cp_error ("can't define friend function `%s' in a local class definition",
9588 name);
9589 }
9590
9591 /* Construct the function type and go to the next
9592 inner layer of declarator. */
9593
9594 declarator = TREE_OPERAND (declarator, 0);
9595
9596 /* FIXME: This is where default args should be fully
9597 processed. */
9598
9599 arg_types = grokparms (inner_parms, funcdecl_p ? funcdef_flag : 0);
9600
9601 if (declarator)
9602 {
9603 /* Get past destructors, etc.
9604 We know we have one because FLAGS will be non-zero.
9605
9606 Complain about improper parameter lists here. */
9607 if (TREE_CODE (declarator) == BIT_NOT_EXPR)
9608 {
9609 declarator = TREE_OPERAND (declarator, 0);
9610
9611 if (strict_prototype == 0 && arg_types == NULL_TREE)
9612 arg_types = void_list_node;
9613 else if (arg_types == NULL_TREE
9614 || arg_types != void_list_node)
9615 {
9616 error ("destructors cannot be specified with parameters");
9617 arg_types = void_list_node;
9618 }
9619 }
9620 }
9621
9622 /* ANSI says that `const int foo ();'
9623 does not make the function foo const. */
9624 type = build_function_type (type, arg_types);
9625
9626 {
9627 tree t;
9628 for (t = arg_types; t; t = TREE_CHAIN (t))
9629 if (TREE_PURPOSE (t)
9630 && TREE_CODE (TREE_PURPOSE (t)) == DEFAULT_ARG)
9631 {
9632 add_defarg_fn (type);
9633 break;
9634 }
9635 }
9636 }
9637 break;
9638
9639 case ADDR_EXPR:
9640 case INDIRECT_REF:
9641 /* Filter out pointers-to-references and references-to-references.
9642 We can get these if a TYPE_DECL is used. */
9643
9644 if (TREE_CODE (type) == REFERENCE_TYPE)
9645 {
9646 error ("cannot declare %s to references",
9647 TREE_CODE (declarator) == ADDR_EXPR
9648 ? "references" : "pointers");
9649 declarator = TREE_OPERAND (declarator, 0);
9650 continue;
9651 }
9652
9653 if (TREE_CODE (type) == OFFSET_TYPE
9654 && (TREE_CODE (TREE_TYPE (type)) == VOID_TYPE
9655 || TREE_CODE (TREE_TYPE (type)) == REFERENCE_TYPE))
9656 {
9657 cp_error ("cannot declare pointer to `%#T' member",
9658 TREE_TYPE (type));
9659 type = TREE_TYPE (type);
9660 }
9661
9662 /* Merge any constancy or volatility into the target type
9663 for the pointer. */
9664
9665 if (constp || volatilep)
9666 {
9667 /* A const or volatile signature pointer/reference is
9668 pointing to a const or volatile object, i.e., the
9669 `optr' is const or volatile, respectively, not the
9670 signature pointer/reference itself. */
9671 if (! IS_SIGNATURE (type))
9672 {
9673 type = cp_build_type_variant (type, constp, volatilep);
9674 if (IS_AGGR_TYPE (type))
9675 build_pointer_type (type);
9676 constp = 0;
9677 volatilep = 0;
9678 }
9679 }
9680
9681 if (IS_SIGNATURE (type))
9682 {
9683 if (TREE_CODE (declarator) == ADDR_EXPR)
9684 {
9685 if (CLASSTYPE_METHOD_VEC (type) == NULL_TREE
9686 && TYPE_SIZE (type))
9687 cp_warning ("empty signature `%T' used in signature reference declaration",
9688 type);
9689 #if 0
9690 type = build_signature_reference_type (type,
9691 constp, volatilep);
9692 #else
9693 sorry ("signature reference");
9694 return NULL_TREE;
9695 #endif
9696 }
9697 else
9698 {
9699 if (CLASSTYPE_METHOD_VEC (type) == NULL_TREE
9700 && TYPE_SIZE (type))
9701 cp_warning ("empty signature `%T' used in signature pointer declaration",
9702 type);
9703 type = build_signature_pointer_type (type,
9704 constp, volatilep);
9705 }
9706 constp = 0;
9707 volatilep = 0;
9708 }
9709 else if (TREE_CODE (declarator) == ADDR_EXPR)
9710 {
9711 if (TREE_CODE (type) == FUNCTION_TYPE)
9712 {
9713 error ("cannot declare references to functions; use pointer to function instead");
9714 type = build_pointer_type (type);
9715 }
9716 else
9717 {
9718 if (TREE_CODE (type) == VOID_TYPE)
9719 error ("invalid type: `void &'");
9720 else
9721 type = build_reference_type (type);
9722 }
9723 }
9724 else if (TREE_CODE (type) == METHOD_TYPE)
9725 {
9726 type = build_ptrmemfunc_type (build_pointer_type (type));
9727 }
9728 else
9729 type = build_pointer_type (type);
9730
9731 /* Process a list of type modifier keywords (such as
9732 const or volatile) that were given inside the `*' or `&'. */
9733
9734 if (TREE_TYPE (declarator))
9735 {
9736 register tree typemodlist;
9737 int erred = 0;
9738 for (typemodlist = TREE_TYPE (declarator); typemodlist;
9739 typemodlist = TREE_CHAIN (typemodlist))
9740 {
9741 if (TREE_VALUE (typemodlist) == ridpointers[(int) RID_CONST])
9742 constp++;
9743 else if (TREE_VALUE (typemodlist) == ridpointers[(int) RID_VOLATILE])
9744 volatilep++;
9745 else if (!erred)
9746 {
9747 erred = 1;
9748 error ("invalid type modifier within %s declarator",
9749 TREE_CODE (declarator) == ADDR_EXPR
9750 ? "reference" : "pointer");
9751 }
9752 }
9753 if (constp > 1)
9754 pedwarn ("duplicate `const'");
9755 if (volatilep > 1)
9756 pedwarn ("duplicate `volatile'");
9757 if (TREE_CODE (declarator) == ADDR_EXPR
9758 && (constp || volatilep))
9759 {
9760 if (constp)
9761 pedwarn ("discarding `const' applied to a reference");
9762 if (volatilep)
9763 pedwarn ("discarding `volatile' applied to a reference");
9764 constp = volatilep = 0;
9765 }
9766 }
9767 declarator = TREE_OPERAND (declarator, 0);
9768 ctype = NULL_TREE;
9769 break;
9770
9771 case SCOPE_REF:
9772 {
9773 /* We have converted type names to NULL_TREE if the
9774 name was bogus, or to a _TYPE node, if not.
9775
9776 The variable CTYPE holds the type we will ultimately
9777 resolve to. The code here just needs to build
9778 up appropriate member types. */
9779 tree sname = TREE_OPERAND (declarator, 1);
9780 tree t;
9781
9782 /* Destructors can have their visibilities changed as well. */
9783 if (TREE_CODE (sname) == BIT_NOT_EXPR)
9784 sname = TREE_OPERAND (sname, 0);
9785
9786 if (TREE_COMPLEXITY (declarator) == 0)
9787 /* This needs to be here, in case we are called
9788 multiple times. */ ;
9789 else if (TREE_COMPLEXITY (declarator) == -1)
9790 /* Namespace member. */
9791 pop_decl_namespace ();
9792 else if (friendp && (TREE_COMPLEXITY (declarator) < 2))
9793 /* Don't fall out into global scope. Hides real bug? --eichin */ ;
9794 else if (! IS_AGGR_TYPE_CODE
9795 (TREE_CODE (TREE_OPERAND (declarator, 0))))
9796 ;
9797 else if (TREE_COMPLEXITY (declarator) == current_class_depth)
9798 {
9799 /* Resolve any TYPENAME_TYPEs from the decl-specifier-seq
9800 that refer to ctype. They couldn't be resolved earlier
9801 because we hadn't pushed into the class yet.
9802 Example: resolve 'B<T>::type' in
9803 'B<typename B<T>::type> B<T>::f () { }'. */
9804 if (current_template_parms
9805 && uses_template_parms (type)
9806 && uses_template_parms (current_class_type))
9807 {
9808 tree args = current_template_args ();
9809 type = tsubst (type, args, NULL_TREE);
9810 }
9811
9812 /* This pop_nested_class corresponds to the
9813 push_nested_class used to push into class scope for
9814 parsing the argument list of a function decl, in
9815 qualified_id. */
9816 pop_nested_class (1);
9817 TREE_COMPLEXITY (declarator) = current_class_depth;
9818 }
9819 else
9820 my_friendly_abort (16);
9821
9822 if (TREE_OPERAND (declarator, 0) == NULL_TREE)
9823 {
9824 /* We had a reference to a global decl, or
9825 perhaps we were given a non-aggregate typedef,
9826 in which case we cleared this out, and should just
9827 keep going as though it wasn't there. */
9828 declarator = sname;
9829 continue;
9830 }
9831 ctype = TREE_OPERAND (declarator, 0);
9832
9833 t = ctype;
9834 while (t != NULL_TREE)
9835 {
9836 if (CLASSTYPE_TEMPLATE_INFO (t) &&
9837 !CLASSTYPE_TEMPLATE_SPECIALIZATION (t))
9838 template_count += 1;
9839 t = TYPE_MAIN_DECL (t);
9840 if (DECL_LANG_SPECIFIC (t))
9841 t = DECL_CLASS_CONTEXT (t);
9842 else
9843 t = NULL_TREE;
9844 }
9845
9846 if (sname == NULL_TREE)
9847 goto done_scoping;
9848
9849 if (TREE_CODE (sname) == IDENTIFIER_NODE)
9850 {
9851 /* This is the `standard' use of the scoping operator:
9852 basetype :: member . */
9853
9854 if (ctype == current_class_type)
9855 {
9856 /* class A {
9857 void A::f ();
9858 };
9859
9860 Is this ill-formed? */
9861
9862 if (pedantic)
9863 cp_pedwarn ("extra qualification `%T::' on member `%s' ignored",
9864 ctype, name);
9865 }
9866 else if (TREE_CODE (type) == FUNCTION_TYPE)
9867 {
9868 if (current_class_type == NULL_TREE
9869 || friendp)
9870 type = build_cplus_method_type (build_type_variant (ctype, constp, volatilep),
9871 TREE_TYPE (type), TYPE_ARG_TYPES (type));
9872 else
9873 {
9874 cp_error ("cannot declare member function `%T::%s' within `%T'",
9875 ctype, name, current_class_type);
9876 return void_type_node;
9877 }
9878 }
9879 else if (RIDBIT_SETP (RID_TYPEDEF, specbits)
9880 || TYPE_SIZE (complete_type (ctype)) != NULL_TREE)
9881 {
9882 /* Have to move this code elsewhere in this function.
9883 this code is used for i.e., typedef int A::M; M *pm;
9884
9885 It is? How? jason 10/2/94 */
9886
9887 if (current_class_type)
9888 {
9889 cp_error ("cannot declare member `%T::%s' within `%T'",
9890 ctype, name, current_class_type);
9891 return void_type_node;
9892 }
9893 type = build_offset_type (ctype, type);
9894 }
9895 else if (uses_template_parms (ctype))
9896 {
9897 if (TREE_CODE (type) == FUNCTION_TYPE)
9898 type
9899 = build_cplus_method_type (build_type_variant (ctype,
9900 constp,
9901 volatilep),
9902 TREE_TYPE (type),
9903 TYPE_ARG_TYPES (type));
9904 }
9905 else
9906 {
9907 cp_error ("structure `%T' not yet defined", ctype);
9908 return error_mark_node;
9909 }
9910
9911 declarator = sname;
9912 }
9913 else if (TREE_CODE (sname) == SCOPE_REF)
9914 my_friendly_abort (17);
9915 else
9916 {
9917 done_scoping:
9918 declarator = TREE_OPERAND (declarator, 1);
9919 if (declarator && TREE_CODE (declarator) == CALL_EXPR)
9920 /* In this case, we will deal with it later. */
9921 ;
9922 else
9923 {
9924 if (TREE_CODE (type) == FUNCTION_TYPE)
9925 type = build_cplus_method_type (build_type_variant (ctype, constp, volatilep), TREE_TYPE (type), TYPE_ARG_TYPES (type));
9926 else
9927 type = build_offset_type (ctype, type);
9928 }
9929 }
9930 }
9931 break;
9932
9933 case BIT_NOT_EXPR:
9934 declarator = TREE_OPERAND (declarator, 0);
9935 break;
9936
9937 case RECORD_TYPE:
9938 case UNION_TYPE:
9939 case ENUMERAL_TYPE:
9940 declarator = NULL_TREE;
9941 break;
9942
9943 case ERROR_MARK:
9944 declarator = NULL_TREE;
9945 break;
9946
9947 default:
9948 my_friendly_abort (158);
9949 }
9950 }
9951
9952 if (explicitp == 1)
9953 {
9954 error ("only constructors can be declared `explicit'");
9955 explicitp = 0;
9956 }
9957
9958 /* Now TYPE has the actual type. */
9959
9960 /* If this is declaring a typedef name, return a TYPE_DECL. */
9961
9962 if (RIDBIT_SETP (RID_MUTABLE, specbits))
9963 {
9964 if (constp)
9965 {
9966 error ("const `%s' cannot be declared `mutable'", name);
9967 RIDBIT_RESET (RID_MUTABLE, specbits);
9968 }
9969 else if (staticp)
9970 {
9971 error ("static `%s' cannot be declared `mutable'", name);
9972 RIDBIT_RESET (RID_MUTABLE, specbits);
9973 }
9974 }
9975
9976 if (RIDBIT_SETP (RID_TYPEDEF, specbits) && decl_context != TYPENAME)
9977 {
9978 tree decl;
9979
9980 /* Note that the grammar rejects storage classes
9981 in typenames, fields or parameters. */
9982 if (constp || volatilep)
9983 type = cp_build_type_variant (type, constp, volatilep);
9984 if (current_lang_name == lang_name_java)
9985 TYPE_FOR_JAVA (type) = 1;
9986
9987 if (decl_context == FIELD)
9988 {
9989 if (declarator == current_class_name)
9990 cp_pedwarn ("ANSI C++ forbids nested type `%D' with same name as enclosing class",
9991 declarator);
9992 decl = build_lang_decl (TYPE_DECL, declarator, type);
9993 if (IS_SIGNATURE (current_class_type) && opaque_typedef)
9994 SIGNATURE_HAS_OPAQUE_TYPEDECLS (current_class_type) = 1;
9995 }
9996 else
9997 {
9998 /* Make sure this typedef lives as long as its type,
9999 since it might be used as a template parameter. */
10000 if (type != error_mark_node)
10001 push_obstacks (TYPE_OBSTACK (type), TYPE_OBSTACK (type));
10002 decl = build_decl (TYPE_DECL, declarator, type);
10003 if (type != error_mark_node)
10004 pop_obstacks ();
10005 }
10006
10007 /* If the user declares "struct {...} foo" then `foo' will have
10008 an anonymous name. Fill that name in now. Nothing can
10009 refer to it, so nothing needs know about the name change.
10010 The TYPE_NAME field was filled in by build_struct_xref. */
10011 if (type != error_mark_node
10012 && TYPE_NAME (type)
10013 && TREE_CODE (TYPE_NAME (type)) == TYPE_DECL
10014 && ANON_AGGRNAME_P (TYPE_IDENTIFIER (type)))
10015 {
10016 /* For anonymous structs that are cv-qualified, need to use
10017 TYPE_MAIN_VARIANT so that name will mangle correctly. As
10018 type not referenced after this block, don't bother
10019 resetting type to original type, ie. TREE_TYPE (decl). */
10020 type = TYPE_MAIN_VARIANT (type);
10021
10022 /* Replace the anonymous name with the real name everywhere. */
10023 lookup_tag_reverse (type, declarator);
10024 TYPE_NAME (type) = decl;
10025
10026 if (TYPE_LANG_SPECIFIC (type))
10027 TYPE_WAS_ANONYMOUS (type) = 1;
10028
10029 /* XXX Temporarily set the scope.
10030 When returning, start_decl expects it as NULL_TREE,
10031 and will then then set it using pushdecl. */
10032 my_friendly_assert (DECL_CONTEXT (decl) == NULL_TREE, 980404);
10033 if (current_class_type)
10034 DECL_CONTEXT (decl) = current_class_type;
10035 else
10036 DECL_CONTEXT (decl) = FROB_CONTEXT (current_namespace);
10037
10038 DECL_ASSEMBLER_NAME (decl) = DECL_NAME (decl);
10039 DECL_ASSEMBLER_NAME (decl)
10040 = get_identifier (build_overload_name (type, 1, 1));
10041 DECL_CONTEXT (decl) = NULL_TREE;
10042
10043 /* FIXME remangle member functions; member functions of a
10044 type with external linkage have external linkage. */
10045 }
10046
10047 if (TREE_CODE (type) == OFFSET_TYPE || TREE_CODE (type) == METHOD_TYPE)
10048 {
10049 cp_error_at ("typedef name may not be class-qualified", decl);
10050 return NULL_TREE;
10051 }
10052 else if (quals)
10053 {
10054 if (ctype == NULL_TREE)
10055 {
10056 if (TREE_CODE (type) != METHOD_TYPE)
10057 cp_error_at ("invalid type qualifier for non-method type", decl);
10058 else
10059 ctype = TYPE_METHOD_BASETYPE (type);
10060 }
10061 if (ctype != NULL_TREE)
10062 grok_method_quals (ctype, decl, quals);
10063 }
10064
10065 if (RIDBIT_SETP (RID_SIGNED, specbits)
10066 || (typedef_decl && C_TYPEDEF_EXPLICITLY_SIGNED (typedef_decl)))
10067 C_TYPEDEF_EXPLICITLY_SIGNED (decl) = 1;
10068
10069 if (RIDBIT_SETP (RID_MUTABLE, specbits))
10070 {
10071 error ("non-object member `%s' cannot be declared mutable", name);
10072 }
10073
10074 bad_specifiers (decl, "type", virtualp, quals != NULL_TREE,
10075 inlinep, friendp, raises != NULL_TREE);
10076
10077 if (initialized)
10078 error ("typedef declaration includes an initializer");
10079
10080 return decl;
10081 }
10082
10083 /* Detect the case of an array type of unspecified size
10084 which came, as such, direct from a typedef name.
10085 We must copy the type, so that each identifier gets
10086 a distinct type, so that each identifier's size can be
10087 controlled separately by its own initializer. */
10088
10089 if (type == typedef_type && TREE_CODE (type) == ARRAY_TYPE
10090 && TYPE_DOMAIN (type) == NULL_TREE)
10091 {
10092 type = build_cplus_array_type (TREE_TYPE (type), TYPE_DOMAIN (type));
10093 }
10094
10095 /* If this is a type name (such as, in a cast or sizeof),
10096 compute the type and return it now. */
10097
10098 if (decl_context == TYPENAME)
10099 {
10100 /* Note that the grammar rejects storage classes
10101 in typenames, fields or parameters. */
10102 if (constp || volatilep)
10103 {
10104 if (IS_SIGNATURE (type))
10105 error ("`const' or `volatile' specified with signature type");
10106 else
10107 type = cp_build_type_variant (type, constp, volatilep);
10108 }
10109
10110 /* Special case: "friend class foo" looks like a TYPENAME context. */
10111 if (friendp)
10112 {
10113 if (volatilep)
10114 {
10115 cp_error ("`volatile' specified for friend class declaration");
10116 volatilep = 0;
10117 }
10118 if (inlinep)
10119 {
10120 cp_error ("`inline' specified for friend class declaration");
10121 inlinep = 0;
10122 }
10123
10124 /* Only try to do this stuff if we didn't already give up. */
10125 if (type != integer_type_node)
10126 {
10127 /* A friendly class? */
10128 if (current_class_type)
10129 make_friend_class (current_class_type, TYPE_MAIN_VARIANT (type));
10130 else
10131 error ("trying to make class `%s' a friend of global scope",
10132 TYPE_NAME_STRING (type));
10133 type = void_type_node;
10134 }
10135 }
10136 else if (quals)
10137 {
10138 tree dummy = build_decl (TYPE_DECL, declarator, type);
10139 if (ctype == NULL_TREE)
10140 {
10141 my_friendly_assert (TREE_CODE (type) == METHOD_TYPE, 159);
10142 ctype = TYPE_METHOD_BASETYPE (type);
10143 }
10144 grok_method_quals (ctype, dummy, quals);
10145 type = TREE_TYPE (dummy);
10146 }
10147
10148 return type;
10149 }
10150 else if (declarator == NULL_TREE && decl_context != PARM
10151 && decl_context != CATCHPARM
10152 && TREE_CODE (type) != UNION_TYPE
10153 && ! bitfield)
10154 {
10155 cp_error ("abstract declarator `%T' used as declaration", type);
10156 declarator = make_anon_name ();
10157 }
10158
10159 /* `void' at top level (not within pointer)
10160 is allowed only in typedefs or type names.
10161 We don't complain about parms either, but that is because
10162 a better error message can be made later. */
10163
10164 if (TREE_CODE (type) == VOID_TYPE && decl_context != PARM)
10165 {
10166 if (! declarator)
10167 error ("unnamed variable or field declared void");
10168 else if (TREE_CODE (declarator) == IDENTIFIER_NODE)
10169 {
10170 if (IDENTIFIER_OPNAME_P (declarator))
10171 my_friendly_abort (356);
10172 else
10173 error ("variable or field `%s' declared void", name);
10174 }
10175 else
10176 error ("variable or field declared void");
10177 type = integer_type_node;
10178 }
10179
10180 /* Now create the decl, which may be a VAR_DECL, a PARM_DECL
10181 or a FUNCTION_DECL, depending on DECL_CONTEXT and TYPE. */
10182
10183 {
10184 register tree decl;
10185
10186 if (decl_context == PARM)
10187 {
10188 if (ctype || in_namespace)
10189 error ("cannot use `::' in parameter declaration");
10190
10191 /* A parameter declared as an array of T is really a pointer to T.
10192 One declared as a function is really a pointer to a function.
10193 One declared as a member is really a pointer to member. */
10194
10195 if (TREE_CODE (type) == ARRAY_TYPE)
10196 {
10197 /* Transfer const-ness of array into that of type pointed to. */
10198 type = build_pointer_type
10199 (cp_build_type_variant (TREE_TYPE (type), constp, volatilep));
10200 volatilep = constp = 0;
10201 }
10202 else if (TREE_CODE (type) == FUNCTION_TYPE)
10203 type = build_pointer_type (type);
10204 else if (TREE_CODE (type) == OFFSET_TYPE)
10205 type = build_pointer_type (type);
10206 else if (TREE_CODE (type) == VOID_TYPE && declarator)
10207 {
10208 error ("declaration of `%s' as void", name);
10209 return NULL_TREE;
10210 }
10211
10212 decl = build_decl (PARM_DECL, declarator, complete_type (type));
10213
10214 bad_specifiers (decl, "parameter", virtualp, quals != NULL_TREE,
10215 inlinep, friendp, raises != NULL_TREE);
10216 if (current_class_type
10217 && IS_SIGNATURE (current_class_type))
10218 {
10219 if (inlinep)
10220 error ("parameter of signature member function declared `inline'");
10221 if (RIDBIT_SETP (RID_AUTO, specbits))
10222 error ("parameter of signature member function declared `auto'");
10223 if (RIDBIT_SETP (RID_REGISTER, specbits))
10224 error ("parameter of signature member function declared `register'");
10225 }
10226
10227 /* Compute the type actually passed in the parmlist,
10228 for the case where there is no prototype.
10229 (For example, shorts and chars are passed as ints.)
10230 When there is a prototype, this is overridden later. */
10231
10232 DECL_ARG_TYPE (decl) = type_promotes_to (type);
10233 }
10234 else if (decl_context == FIELD)
10235 {
10236 if (type == error_mark_node)
10237 {
10238 /* Happens when declaring arrays of sizes which
10239 are error_mark_node, for example. */
10240 decl = NULL_TREE;
10241 }
10242 else if (in_namespace)
10243 {
10244 /* Something like struct S { int N::j; }; */
10245 cp_error ("invalid use of `::'");
10246 decl = NULL_TREE;
10247 }
10248 else if (TREE_CODE (type) == FUNCTION_TYPE)
10249 {
10250 int publicp = 0;
10251 tree function_context;
10252
10253 /* We catch the others as conflicts with the builtin
10254 typedefs. */
10255 if (friendp && declarator == ridpointers[(int) RID_SIGNED])
10256 {
10257 cp_error ("function `%D' cannot be declared friend",
10258 declarator);
10259 friendp = 0;
10260 }
10261
10262 if (friendp == 0)
10263 {
10264 if (ctype == NULL_TREE)
10265 ctype = current_class_type;
10266
10267 if (ctype == NULL_TREE)
10268 {
10269 cp_error ("can't make `%D' into a method -- not in a class",
10270 declarator);
10271 return void_type_node;
10272 }
10273
10274 /* ``A union may [ ... ] not [ have ] virtual functions.''
10275 ARM 9.5 */
10276 if (virtualp && TREE_CODE (ctype) == UNION_TYPE)
10277 {
10278 cp_error ("function `%D' declared virtual inside a union",
10279 declarator);
10280 return void_type_node;
10281 }
10282
10283 if (declarator == ansi_opname[(int) NEW_EXPR]
10284 || declarator == ansi_opname[(int) VEC_NEW_EXPR]
10285 || declarator == ansi_opname[(int) DELETE_EXPR]
10286 || declarator == ansi_opname[(int) VEC_DELETE_EXPR])
10287 {
10288 if (virtualp)
10289 {
10290 cp_error ("`%D' cannot be declared virtual, since it is always static",
10291 declarator);
10292 virtualp = 0;
10293 }
10294 }
10295 else if (staticp < 2)
10296 type = build_cplus_method_type (build_type_variant (ctype, constp, volatilep),
10297 TREE_TYPE (type), TYPE_ARG_TYPES (type));
10298 }
10299
10300 /* Tell grokfndecl if it needs to set TREE_PUBLIC on the node. */
10301 function_context = (ctype != NULL_TREE) ?
10302 hack_decl_function_context (TYPE_MAIN_DECL (ctype)) : NULL_TREE;
10303 publicp = (! friendp || ! staticp)
10304 && function_context == NULL_TREE;
10305 decl = grokfndecl (ctype, type,
10306 TREE_CODE (declarator) != TEMPLATE_ID_EXPR
10307 ? declarator : dname,
10308 declarator,
10309 virtualp, flags, quals, raises, attrlist,
10310 friendp ? -1 : 0, friendp, publicp, inlinep,
10311 funcdef_flag, template_count, in_namespace);
10312 if (decl == NULL_TREE)
10313 return NULL_TREE;
10314 #if 0
10315 /* This clobbers the attrs stored in `decl' from `attrlist'. */
10316 /* The decl and setting of decl_machine_attr is also turned off. */
10317 decl = build_decl_attribute_variant (decl, decl_machine_attr);
10318 #endif
10319
10320 if (explicitp == 2)
10321 DECL_NONCONVERTING_P (decl) = 1;
10322 }
10323 else if (TREE_CODE (type) == METHOD_TYPE)
10324 {
10325 /* We only get here for friend declarations of
10326 members of other classes. */
10327 /* All method decls are public, so tell grokfndecl to set
10328 TREE_PUBLIC, also. */
10329 decl = grokfndecl (ctype, type, declarator, declarator,
10330 virtualp, flags, quals, raises, attrlist,
10331 friendp ? -1 : 0, friendp, 1, 0, funcdef_flag,
10332 template_count, in_namespace);
10333 if (decl == NULL_TREE)
10334 return NULL_TREE;
10335 }
10336 else if (!staticp && ! processing_template_decl
10337 && TYPE_SIZE (complete_type (type)) == NULL_TREE
10338 && (TREE_CODE (type) != ARRAY_TYPE || initialized == 0))
10339 {
10340 if (declarator)
10341 cp_error ("field `%D' has incomplete type", declarator);
10342 else
10343 cp_error ("name `%T' has incomplete type", type);
10344
10345 /* If we're instantiating a template, tell them which
10346 instantiation made the field's type be incomplete. */
10347 if (current_class_type
10348 && TYPE_NAME (current_class_type)
10349 && IDENTIFIER_TEMPLATE (TYPE_IDENTIFIER (current_class_type))
10350 && declspecs && TREE_VALUE (declspecs)
10351 && TREE_TYPE (TREE_VALUE (declspecs)) == type)
10352 cp_error (" in instantiation of template `%T'",
10353 current_class_type);
10354
10355 type = error_mark_node;
10356 decl = NULL_TREE;
10357 }
10358 else
10359 {
10360 if (friendp)
10361 {
10362 error ("`%s' is neither function nor method; cannot be declared friend",
10363 IDENTIFIER_POINTER (declarator));
10364 friendp = 0;
10365 }
10366 decl = NULL_TREE;
10367 }
10368
10369 if (friendp)
10370 {
10371 /* Friends are treated specially. */
10372 if (ctype == current_class_type)
10373 warning ("member functions are implicitly friends of their class");
10374 else
10375 {
10376 tree t = NULL_TREE;
10377 if (decl && DECL_NAME (decl))
10378 {
10379 if (template_class_depth (current_class_type) == 0)
10380 decl
10381 = check_explicit_specialization
10382 (declarator, decl,
10383 template_count, 2 * (funcdef_flag != 0) + 4);
10384 t = do_friend (ctype, declarator, decl,
10385 last_function_parms, flags, quals,
10386 funcdef_flag);
10387 }
10388 if (t && funcdef_flag)
10389 return t;
10390
10391 return void_type_node;
10392 }
10393 }
10394
10395 /* Structure field. It may not be a function, except for C++ */
10396
10397 if (decl == NULL_TREE)
10398 {
10399 if (initialized)
10400 {
10401 if (!staticp)
10402 {
10403 /* An attempt is being made to initialize a non-static
10404 member. But, from [class.mem]:
10405
10406 4 A member-declarator can contain a
10407 constant-initializer only if it declares a static
10408 member (_class.static_) of integral or enumeration
10409 type, see _class.static.data_.
10410
10411 This used to be relatively common practice, but
10412 the rest of the compiler does not correctly
10413 handle the initialization unless the member is
10414 static so we make it static below. */
10415 cp_pedwarn ("ANSI C++ forbids initialization of %s `%D'",
10416 constp ? "const member" : "member",
10417 declarator);
10418 cp_pedwarn ("making `%D' static", declarator);
10419 staticp = 1;
10420 }
10421
10422 /* Motion 10 at San Diego: If a static const integral data
10423 member is initialized with an integral constant
10424 expression, the initializer may appear either in the
10425 declaration (within the class), or in the definition,
10426 but not both. If it appears in the class, the member is
10427 a member constant. The file-scope definition is always
10428 required. */
10429 if (CLASS_TYPE_P (type)
10430 || TREE_CODE (type) == REFERENCE_TYPE)
10431 {
10432 cp_error ("in-class initialization of static data member of non-integral type `%T'",
10433 type);
10434 /* If we just return the declaration, crashes will
10435 sometimes occur. We therefore return
10436 void_type_node, as if this was a friend
10437 declaration, to cause callers to completely
10438 ignore this declaration. */
10439 return void_type_node;
10440 }
10441 else if (!constp)
10442 cp_error ("ANSI C++ forbids in-class initialization of non-const static member `%D'",
10443 declarator);
10444 else if (pedantic && ! INTEGRAL_TYPE_P (type)
10445 && !uses_template_parms (type))
10446 cp_pedwarn ("ANSI C++ forbids initialization of member constant `%D' of non-integral type `%T'", declarator, type);
10447 }
10448
10449 if (staticp)
10450 {
10451 /* ANSI C++ Apr '95 wp 9.2 */
10452 if (declarator == current_class_name)
10453 cp_pedwarn ("ANSI C++ forbids static member `%D' with same name as enclosing class",
10454 declarator);
10455
10456 /* C++ allows static class members.
10457 All other work for this is done by grokfield.
10458 This VAR_DCL is built by build_lang_field_decl.
10459 All other VAR_DECLs are built by build_decl. */
10460 decl = build_lang_field_decl (VAR_DECL, declarator, type);
10461 TREE_STATIC (decl) = 1;
10462 /* In class context, 'static' means public access. */
10463 TREE_PUBLIC (decl) = DECL_EXTERNAL (decl) = 1;
10464 }
10465 else
10466 {
10467 decl = build_lang_field_decl (FIELD_DECL, declarator, type);
10468 if (RIDBIT_SETP (RID_MUTABLE, specbits))
10469 {
10470 DECL_MUTABLE_P (decl) = 1;
10471 RIDBIT_RESET (RID_MUTABLE, specbits);
10472 }
10473 }
10474
10475 bad_specifiers (decl, "field", virtualp, quals != NULL_TREE,
10476 inlinep, friendp, raises != NULL_TREE);
10477 }
10478 }
10479 else if (TREE_CODE (type) == FUNCTION_TYPE || TREE_CODE (type) == METHOD_TYPE)
10480 {
10481 tree original_name;
10482 int publicp = 0;
10483
10484 if (! declarator)
10485 return NULL_TREE;
10486
10487 if (TREE_CODE (declarator) == TEMPLATE_ID_EXPR)
10488 original_name = dname;
10489 else
10490 original_name = declarator;
10491
10492 if (RIDBIT_SETP (RID_AUTO, specbits))
10493 error ("storage class `auto' invalid for function `%s'", name);
10494 else if (RIDBIT_SETP (RID_REGISTER, specbits))
10495 error ("storage class `register' invalid for function `%s'", name);
10496
10497 /* Function declaration not at top level.
10498 Storage classes other than `extern' are not allowed
10499 and `extern' makes no difference. */
10500 if (! toplevel_bindings_p ()
10501 && (RIDBIT_SETP (RID_STATIC, specbits)
10502 || RIDBIT_SETP (RID_INLINE, specbits))
10503 && pedantic)
10504 {
10505 if (RIDBIT_SETP (RID_STATIC, specbits))
10506 pedwarn ("storage class `static' invalid for function `%s' declared out of global scope", name);
10507 else
10508 pedwarn ("storage class `inline' invalid for function `%s' declared out of global scope", name);
10509 }
10510
10511 if (ctype == NULL_TREE)
10512 {
10513 if (virtualp)
10514 {
10515 error ("virtual non-class function `%s'", name);
10516 virtualp = 0;
10517 }
10518
10519 if (current_lang_name == lang_name_cplusplus
10520 && ! processing_template_decl
10521 && ! MAIN_NAME_P (original_name)
10522 && ! (IDENTIFIER_LENGTH (original_name) > 10
10523 && IDENTIFIER_POINTER (original_name)[0] == '_'
10524 && IDENTIFIER_POINTER (original_name)[1] == '_'
10525 && strncmp (IDENTIFIER_POINTER (original_name)+2, "builtin_", 8) == 0))
10526 /* Plain overloading: will not be grok'd by grokclassfn. */
10527 if (name_mangling_version < 1
10528 || TREE_CODE (declarator) != TEMPLATE_ID_EXPR)
10529 declarator = build_decl_overload (dname, TYPE_ARG_TYPES (type), 0);
10530 }
10531 else if (TREE_CODE (type) == FUNCTION_TYPE && staticp < 2)
10532 type = build_cplus_method_type (build_type_variant (ctype, constp, volatilep),
10533 TREE_TYPE (type), TYPE_ARG_TYPES (type));
10534
10535 /* Record presence of `static'. */
10536 publicp = (ctype != NULL_TREE
10537 || RIDBIT_SETP (RID_EXTERN, specbits)
10538 || !RIDBIT_SETP (RID_STATIC, specbits));
10539
10540 decl = grokfndecl (ctype, type, original_name, declarator,
10541 virtualp, flags, quals, raises, attrlist,
10542 1, friendp,
10543 publicp, inlinep, funcdef_flag,
10544 template_count, in_namespace);
10545 if (decl == NULL_TREE)
10546 return NULL_TREE;
10547
10548 /* Among other times, could occur from check_explicit_specialization
10549 returning an error_mark_node. */
10550 if (decl == error_mark_node)
10551 return error_mark_node;
10552
10553 if (ctype == NULL_TREE && DECL_LANGUAGE (decl) != lang_c
10554 && (! DECL_USE_TEMPLATE (decl) ||
10555 name_mangling_version < 1))
10556 DECL_ASSEMBLER_NAME (decl) = declarator;
10557
10558 if (staticp == 1)
10559 {
10560 int illegal_static = 0;
10561
10562 /* Don't allow a static member function in a class, and forbid
10563 declaring main to be static. */
10564 if (TREE_CODE (type) == METHOD_TYPE)
10565 {
10566 cp_pedwarn ("cannot declare member function `%D' to have static linkage", decl);
10567 illegal_static = 1;
10568 }
10569 else if (current_function_decl)
10570 {
10571 /* FIXME need arm citation */
10572 error ("cannot declare static function inside another function");
10573 illegal_static = 1;
10574 }
10575
10576 if (illegal_static)
10577 {
10578 staticp = 0;
10579 RIDBIT_RESET (RID_STATIC, specbits);
10580 }
10581 }
10582 }
10583 else
10584 {
10585 /* It's a variable. */
10586
10587 if (decl_context == CATCHPARM)
10588 {
10589 if (ctype)
10590 {
10591 ctype = NULL_TREE;
10592 error ("cannot use `::' in parameter declaration");
10593 }
10594
10595 /* A parameter declared as an array of T is really a pointer to T.
10596 One declared as a function is really a pointer to a function.
10597 One declared as a member is really a pointer to member. */
10598
10599 if (TREE_CODE (type) == ARRAY_TYPE)
10600 {
10601 /* Transfer const-ness of array into that of type
10602 pointed to. */
10603 type = build_pointer_type
10604 (cp_build_type_variant (TREE_TYPE (type), constp, volatilep));
10605 volatilep = constp = 0;
10606 }
10607 else if (TREE_CODE (type) == FUNCTION_TYPE)
10608 type = build_pointer_type (type);
10609 else if (TREE_CODE (type) == OFFSET_TYPE)
10610 type = build_pointer_type (type);
10611 }
10612
10613 /* An uninitialized decl with `extern' is a reference. */
10614 decl = grokvardecl (type, declarator, &specbits,
10615 initialized, constp, in_namespace);
10616 bad_specifiers (decl, "variable", virtualp, quals != NULL_TREE,
10617 inlinep, friendp, raises != NULL_TREE);
10618
10619 if (ctype)
10620 {
10621 DECL_CONTEXT (decl) = ctype;
10622 if (staticp == 1)
10623 {
10624 cp_pedwarn ("static member `%D' re-declared as static", decl);
10625 staticp = 0;
10626 RIDBIT_RESET (RID_STATIC, specbits);
10627 }
10628 if (RIDBIT_SETP (RID_REGISTER, specbits) && TREE_STATIC (decl))
10629 {
10630 cp_error ("static member `%D' declared `register'", decl);
10631 RIDBIT_RESET (RID_REGISTER, specbits);
10632 }
10633 if (RIDBIT_SETP (RID_EXTERN, specbits) && pedantic)
10634 {
10635 cp_pedwarn ("cannot explicitly declare member `%#D' to have extern linkage",
10636 decl);
10637 RIDBIT_RESET (RID_EXTERN, specbits);
10638 }
10639 }
10640 }
10641
10642 if (RIDBIT_SETP (RID_MUTABLE, specbits))
10643 {
10644 error ("`%s' cannot be declared mutable", name);
10645 }
10646
10647 /* Record `register' declaration for warnings on &
10648 and in case doing stupid register allocation. */
10649
10650 if (RIDBIT_SETP (RID_REGISTER, specbits))
10651 DECL_REGISTER (decl) = 1;
10652
10653 if (RIDBIT_SETP (RID_EXTERN, specbits))
10654 DECL_THIS_EXTERN (decl) = 1;
10655
10656 if (RIDBIT_SETP (RID_STATIC, specbits))
10657 DECL_THIS_STATIC (decl) = 1;
10658
10659 /* Record constancy and volatility. */
10660
10661 if (constp)
10662 TREE_READONLY (decl) = TREE_CODE (type) != REFERENCE_TYPE;
10663 if (volatilep)
10664 {
10665 TREE_SIDE_EFFECTS (decl) = 1;
10666 TREE_THIS_VOLATILE (decl) = 1;
10667 }
10668
10669 return decl;
10670 }
10671 }
10672 \f
10673 /* Tell if a parmlist/exprlist looks like an exprlist or a parmlist.
10674 An empty exprlist is a parmlist. An exprlist which
10675 contains only identifiers at the global level
10676 is a parmlist. Otherwise, it is an exprlist. */
10677
10678 int
10679 parmlist_is_exprlist (exprs)
10680 tree exprs;
10681 {
10682 if (exprs == NULL_TREE || TREE_PARMLIST (exprs))
10683 return 0;
10684
10685 if (toplevel_bindings_p ())
10686 {
10687 /* At the global level, if these are all identifiers,
10688 then it is a parmlist. */
10689 while (exprs)
10690 {
10691 if (TREE_CODE (TREE_VALUE (exprs)) != IDENTIFIER_NODE)
10692 return 1;
10693 exprs = TREE_CHAIN (exprs);
10694 }
10695 return 0;
10696 }
10697 return 1;
10698 }
10699
10700 /* Subroutine of `grokparms'. In a fcn definition, arg types must
10701 be complete.
10702
10703 C++: also subroutine of `start_function'. */
10704
10705 static void
10706 require_complete_types_for_parms (parms)
10707 tree parms;
10708 {
10709 if (processing_template_decl)
10710 return;
10711
10712 while (parms)
10713 {
10714 tree type = TREE_TYPE (parms);
10715 if (TYPE_SIZE (complete_type (type)) == NULL_TREE)
10716 {
10717 if (DECL_NAME (parms))
10718 error ("parameter `%s' has incomplete type",
10719 IDENTIFIER_POINTER (DECL_NAME (parms)));
10720 else
10721 error ("parameter has incomplete type");
10722 TREE_TYPE (parms) = error_mark_node;
10723 }
10724 #if 0
10725 /* If the arg types are incomplete in a declaration,
10726 they must include undefined tags.
10727 These tags can never be defined in the scope of the declaration,
10728 so the types can never be completed,
10729 and no call can be compiled successfully. */
10730 /* This is not the right behavior for C++, but not having
10731 it is also probably wrong. */
10732 else
10733 {
10734 /* Now warn if is a pointer to an incomplete type. */
10735 while (TREE_CODE (type) == POINTER_TYPE
10736 || TREE_CODE (type) == REFERENCE_TYPE)
10737 type = TREE_TYPE (type);
10738 type = TYPE_MAIN_VARIANT (type);
10739 if (TYPE_SIZE (type) == NULL_TREE)
10740 {
10741 if (DECL_NAME (parm) != NULL_TREE)
10742 warning ("parameter `%s' points to incomplete type",
10743 IDENTIFIER_POINTER (DECL_NAME (parm)));
10744 else
10745 warning ("parameter points to incomplete type");
10746 }
10747 }
10748 #endif
10749 parms = TREE_CHAIN (parms);
10750 }
10751 }
10752
10753 /* Decode the list of parameter types for a function type.
10754 Given the list of things declared inside the parens,
10755 return a list of types.
10756
10757 The list we receive can have three kinds of elements:
10758 an IDENTIFIER_NODE for names given without types,
10759 a TREE_LIST node for arguments given as typespecs or names with typespecs,
10760 or void_type_node, to mark the end of an argument list
10761 when additional arguments are not permitted (... was not used).
10762
10763 FUNCDEF_FLAG is nonzero for a function definition, 0 for
10764 a mere declaration. A nonempty identifier-list gets an error message
10765 when FUNCDEF_FLAG is zero.
10766 If FUNCDEF_FLAG is 1, then parameter types must be complete.
10767 If FUNCDEF_FLAG is -1, then parameter types may be incomplete.
10768
10769 If all elements of the input list contain types,
10770 we return a list of the types.
10771 If all elements contain no type (except perhaps a void_type_node
10772 at the end), we return a null list.
10773 If some have types and some do not, it is an error, and we
10774 return a null list.
10775
10776 Also set last_function_parms to either
10777 a list of names (IDENTIFIER_NODEs) or a chain of PARM_DECLs.
10778 A list of names is converted to a chain of PARM_DECLs
10779 by store_parm_decls so that ultimately it is always a chain of decls.
10780
10781 Note that in C++, parameters can take default values. These default
10782 values are in the TREE_PURPOSE field of the TREE_LIST. It is
10783 an error to specify default values which are followed by parameters
10784 that have no default values, or an ELLIPSES. For simplicities sake,
10785 only parameters which are specified with their types can take on
10786 default values. */
10787
10788 static tree
10789 grokparms (first_parm, funcdef_flag)
10790 tree first_parm;
10791 int funcdef_flag;
10792 {
10793 tree result = NULL_TREE;
10794 tree decls = NULL_TREE;
10795
10796 if (first_parm != NULL_TREE
10797 && TREE_CODE (TREE_VALUE (first_parm)) == IDENTIFIER_NODE)
10798 {
10799 if (! funcdef_flag)
10800 pedwarn ("parameter names (without types) in function declaration");
10801 last_function_parms = first_parm;
10802 return NULL_TREE;
10803 }
10804 else if (first_parm != NULL_TREE
10805 && TREE_CODE (TREE_VALUE (first_parm)) != TREE_LIST
10806 && TREE_CODE (TREE_VALUE (first_parm)) != VOID_TYPE)
10807 my_friendly_abort (145);
10808 else
10809 {
10810 /* Types were specified. This is a list of declarators
10811 each represented as a TREE_LIST node. */
10812 register tree parm, chain;
10813 int any_init = 0, any_error = 0;
10814
10815 if (first_parm != NULL_TREE)
10816 {
10817 tree last_result = NULL_TREE;
10818 tree last_decl = NULL_TREE;
10819
10820 for (parm = first_parm; parm != NULL_TREE; parm = chain)
10821 {
10822 tree type = NULL_TREE, list_node = parm;
10823 register tree decl = TREE_VALUE (parm);
10824 tree init = TREE_PURPOSE (parm);
10825
10826 chain = TREE_CHAIN (parm);
10827 /* @@ weak defense against parse errors. */
10828 if (TREE_CODE (decl) != VOID_TYPE
10829 && TREE_CODE (decl) != TREE_LIST)
10830 {
10831 /* Give various messages as the need arises. */
10832 if (TREE_CODE (decl) == STRING_CST)
10833 cp_error ("invalid string constant `%E'", decl);
10834 else if (TREE_CODE (decl) == INTEGER_CST)
10835 error ("invalid integer constant in parameter list, did you forget to give parameter name?");
10836 continue;
10837 }
10838
10839 if (TREE_CODE (decl) != VOID_TYPE)
10840 {
10841 decl = grokdeclarator (TREE_VALUE (decl),
10842 TREE_PURPOSE (decl),
10843 PARM, init != NULL_TREE,
10844 NULL_TREE);
10845 if (! decl)
10846 continue;
10847 type = TREE_TYPE (decl);
10848 if (TREE_CODE (type) == VOID_TYPE)
10849 decl = void_type_node;
10850 else if (TREE_CODE (type) == METHOD_TYPE)
10851 {
10852 if (DECL_NAME (decl))
10853 /* Cannot use the decl here because
10854 we don't have DECL_CONTEXT set up yet. */
10855 cp_error ("parameter `%D' invalidly declared method type",
10856 DECL_NAME (decl));
10857 else
10858 error ("parameter invalidly declared method type");
10859 type = build_pointer_type (type);
10860 TREE_TYPE (decl) = type;
10861 }
10862 else if (TREE_CODE (type) == OFFSET_TYPE)
10863 {
10864 if (DECL_NAME (decl))
10865 cp_error ("parameter `%D' invalidly declared offset type",
10866 DECL_NAME (decl));
10867 else
10868 error ("parameter invalidly declared offset type");
10869 type = build_pointer_type (type);
10870 TREE_TYPE (decl) = type;
10871 }
10872 else if (TREE_CODE (type) == RECORD_TYPE
10873 && TYPE_LANG_SPECIFIC (type)
10874 && CLASSTYPE_ABSTRACT_VIRTUALS (type))
10875 {
10876 abstract_virtuals_error (decl, type);
10877 any_error = 1; /* Seems like a good idea. */
10878 }
10879 else if (TREE_CODE (type) == RECORD_TYPE
10880 && TYPE_LANG_SPECIFIC (type)
10881 && IS_SIGNATURE (type))
10882 {
10883 signature_error (decl, type);
10884 any_error = 1; /* Seems like a good idea. */
10885 }
10886 else if (POINTER_TYPE_P (type))
10887 {
10888 tree t = type;
10889 while (POINTER_TYPE_P (t)
10890 || (TREE_CODE (t) == ARRAY_TYPE
10891 && TYPE_DOMAIN (t) != NULL_TREE))
10892 t = TREE_TYPE (t);
10893 if (TREE_CODE (t) == ARRAY_TYPE)
10894 cp_error ("parameter type `%T' includes pointer to array of unknown bound",
10895 type);
10896 }
10897 }
10898
10899 if (TREE_CODE (decl) == VOID_TYPE)
10900 {
10901 if (result == NULL_TREE)
10902 {
10903 result = void_list_node;
10904 last_result = result;
10905 }
10906 else
10907 {
10908 TREE_CHAIN (last_result) = void_list_node;
10909 last_result = void_list_node;
10910 }
10911 if (chain
10912 && (chain != void_list_node || TREE_CHAIN (chain)))
10913 error ("`void' in parameter list must be entire list");
10914 break;
10915 }
10916
10917 /* Since there is a prototype, args are passed in their own types. */
10918 DECL_ARG_TYPE (decl) = TREE_TYPE (decl);
10919 #ifdef PROMOTE_PROTOTYPES
10920 if ((TREE_CODE (type) == INTEGER_TYPE
10921 || TREE_CODE (type) == ENUMERAL_TYPE)
10922 && TYPE_PRECISION (type) < TYPE_PRECISION (integer_type_node))
10923 DECL_ARG_TYPE (decl) = integer_type_node;
10924 #endif
10925 if (!any_error)
10926 {
10927 if (init)
10928 {
10929 any_init++;
10930 if (TREE_CODE (init) == SAVE_EXPR)
10931 PARM_DECL_EXPR (init) = 1;
10932 else if (processing_template_decl)
10933 ;
10934 /* Unparsed default arg from in-class decl. */
10935 else if (TREE_CODE (init) == DEFAULT_ARG)
10936 ;
10937 else if (TREE_CODE (init) == VAR_DECL
10938 || TREE_CODE (init) == PARM_DECL)
10939 {
10940 if (IDENTIFIER_LOCAL_VALUE (DECL_NAME (init)))
10941 {
10942 /* ``Local variables may not be used in default
10943 argument expressions.'' dpANSI C++ 8.2.6 */
10944 /* If extern int i; within a function is not
10945 considered a local variable, then this code is
10946 wrong. */
10947 cp_error ("local variable `%D' may not be used as a default argument", init);
10948 any_error = 1;
10949 }
10950 else if (TREE_READONLY_DECL_P (init))
10951 init = decl_constant_value (init);
10952 }
10953 else
10954 init = require_instantiated_type (type, init, integer_zero_node);
10955 if (! processing_template_decl
10956 && init != error_mark_node
10957 && TREE_CODE (init) != DEFAULT_ARG
10958 && ! can_convert_arg (type, TREE_TYPE (init), init))
10959 cp_pedwarn ("invalid type `%T' for default argument to `%#D'",
10960 TREE_TYPE (init), decl);
10961 }
10962 }
10963 else
10964 init = NULL_TREE;
10965
10966 if (decls == NULL_TREE)
10967 {
10968 decls = decl;
10969 last_decl = decls;
10970 }
10971 else
10972 {
10973 TREE_CHAIN (last_decl) = decl;
10974 last_decl = decl;
10975 }
10976 if (! current_function_decl && TREE_PERMANENT (list_node))
10977 {
10978 TREE_PURPOSE (list_node) = init;
10979 TREE_VALUE (list_node) = type;
10980 TREE_CHAIN (list_node) = NULL_TREE;
10981 }
10982 else
10983 list_node = saveable_tree_cons (init, type, NULL_TREE);
10984 if (result == NULL_TREE)
10985 {
10986 result = list_node;
10987 last_result = result;
10988 }
10989 else
10990 {
10991 TREE_CHAIN (last_result) = list_node;
10992 last_result = list_node;
10993 }
10994 }
10995 if (last_result)
10996 TREE_CHAIN (last_result) = NULL_TREE;
10997 /* If there are no parameters, and the function does not end
10998 with `...', then last_decl will be NULL_TREE. */
10999 if (last_decl != NULL_TREE)
11000 TREE_CHAIN (last_decl) = NULL_TREE;
11001 }
11002 }
11003
11004 last_function_parms = decls;
11005
11006 /* In a fcn definition, arg types must be complete. */
11007 if (funcdef_flag > 0)
11008 require_complete_types_for_parms (last_function_parms);
11009
11010 return result;
11011 }
11012
11013 /* Called from the parser to update an element of TYPE_ARG_TYPES for some
11014 FUNCTION_TYPE with the newly parsed version of its default argument, which
11015 was previously digested as text. See snarf_defarg et al in lex.c. */
11016
11017 void
11018 replace_defarg (arg, init)
11019 tree arg, init;
11020 {
11021 if (! processing_template_decl
11022 && ! can_convert_arg (TREE_VALUE (arg), TREE_TYPE (init), init))
11023 cp_pedwarn ("invalid type `%T' for default argument to `%T'",
11024 TREE_TYPE (init), TREE_VALUE (arg));
11025 TREE_PURPOSE (arg) = init;
11026 }
11027 \f
11028 int
11029 copy_args_p (d)
11030 tree d;
11031 {
11032 tree t = FUNCTION_ARG_CHAIN (d);
11033 if (DECL_CONSTRUCTOR_P (d)
11034 && TYPE_USES_VIRTUAL_BASECLASSES (DECL_CONTEXT (d)))
11035 t = TREE_CHAIN (t);
11036 if (t && TREE_CODE (TREE_VALUE (t)) == REFERENCE_TYPE
11037 && (TYPE_MAIN_VARIANT (TREE_TYPE (TREE_VALUE (t)))
11038 == DECL_CLASS_CONTEXT (d))
11039 && (TREE_CHAIN (t) == NULL_TREE
11040 || TREE_CHAIN (t) == void_list_node
11041 || TREE_PURPOSE (TREE_CHAIN (t))))
11042 return 1;
11043 return 0;
11044 }
11045
11046 /* These memoizing functions keep track of special properties which
11047 a class may have. `grok_ctor_properties' notices whether a class
11048 has a constructor of the form X(X&), and also complains
11049 if the class has a constructor of the form X(X).
11050 `grok_op_properties' takes notice of the various forms of
11051 operator= which are defined, as well as what sorts of type conversion
11052 may apply. Both functions take a FUNCTION_DECL as an argument. */
11053
11054 int
11055 grok_ctor_properties (ctype, decl)
11056 tree ctype, decl;
11057 {
11058 tree parmtypes = FUNCTION_ARG_CHAIN (decl);
11059 tree parmtype = parmtypes ? TREE_VALUE (parmtypes) : void_type_node;
11060
11061 /* When a type has virtual baseclasses, a magical first int argument is
11062 added to any ctor so we can tell if the class has been initialized
11063 yet. This could screw things up in this function, so we deliberately
11064 ignore the leading int if we're in that situation. */
11065 if (TYPE_USES_VIRTUAL_BASECLASSES (ctype))
11066 {
11067 my_friendly_assert (parmtypes
11068 && TREE_VALUE (parmtypes) == integer_type_node,
11069 980529);
11070 parmtypes = TREE_CHAIN (parmtypes);
11071 parmtype = TREE_VALUE (parmtypes);
11072 }
11073
11074 if (TREE_CODE (parmtype) == REFERENCE_TYPE
11075 && TYPE_MAIN_VARIANT (TREE_TYPE (parmtype)) == ctype
11076 && (TREE_CHAIN (parmtypes) == NULL_TREE
11077 || TREE_CHAIN (parmtypes) == void_list_node
11078 || TREE_PURPOSE (TREE_CHAIN (parmtypes))))
11079 {
11080 TYPE_HAS_INIT_REF (ctype) = 1;
11081 if (TYPE_READONLY (TREE_TYPE (parmtype)))
11082 TYPE_HAS_CONST_INIT_REF (ctype) = 1;
11083 }
11084 else if (TYPE_MAIN_VARIANT (parmtype) == ctype
11085 && TREE_CHAIN (parmtypes) != NULL_TREE
11086 && TREE_CHAIN (parmtypes) == void_list_node)
11087 {
11088 cp_error ("invalid constructor; you probably meant `%T (const %T&)'",
11089 ctype, ctype);
11090 SET_IDENTIFIER_ERROR_LOCUS (DECL_NAME (decl), ctype);
11091 return 0;
11092 }
11093 else if (TREE_CODE (parmtype) == VOID_TYPE
11094 || TREE_PURPOSE (parmtypes) != NULL_TREE)
11095 TYPE_HAS_DEFAULT_CONSTRUCTOR (ctype) = 1;
11096
11097 return 1;
11098 }
11099
11100 /* An operator with this name can be either unary or binary. */
11101
11102 static int
11103 ambi_op_p (name)
11104 tree name;
11105 {
11106 return (name == ansi_opname [(int) INDIRECT_REF]
11107 || name == ansi_opname [(int) ADDR_EXPR]
11108 || name == ansi_opname [(int) NEGATE_EXPR]
11109 || name == ansi_opname[(int) POSTINCREMENT_EXPR]
11110 || name == ansi_opname[(int) POSTDECREMENT_EXPR]
11111 || name == ansi_opname [(int) CONVERT_EXPR]);
11112 }
11113
11114 /* An operator with this name can only be unary. */
11115
11116 static int
11117 unary_op_p (name)
11118 tree name;
11119 {
11120 return (name == ansi_opname [(int) TRUTH_NOT_EXPR]
11121 || name == ansi_opname [(int) BIT_NOT_EXPR]
11122 || name == ansi_opname [(int) COMPONENT_REF]
11123 || OPERATOR_TYPENAME_P (name));
11124 }
11125
11126 /* Do a little sanity-checking on how they declared their operator. */
11127
11128 void
11129 grok_op_properties (decl, virtualp, friendp)
11130 tree decl;
11131 int virtualp, friendp;
11132 {
11133 tree argtypes = TYPE_ARG_TYPES (TREE_TYPE (decl));
11134 int methodp = (TREE_CODE (TREE_TYPE (decl)) == METHOD_TYPE);
11135 tree name = DECL_NAME (decl);
11136
11137 if (current_class_type == NULL_TREE)
11138 friendp = 1;
11139
11140 if (! friendp)
11141 {
11142 if (name == ansi_opname[(int) MODIFY_EXPR])
11143 TYPE_HAS_ASSIGNMENT (current_class_type) = 1;
11144 else if (name == ansi_opname[(int) CALL_EXPR])
11145 TYPE_OVERLOADS_CALL_EXPR (current_class_type) = 1;
11146 else if (name == ansi_opname[(int) ARRAY_REF])
11147 TYPE_OVERLOADS_ARRAY_REF (current_class_type) = 1;
11148 else if (name == ansi_opname[(int) COMPONENT_REF]
11149 || name == ansi_opname[(int) MEMBER_REF])
11150 TYPE_OVERLOADS_ARROW (current_class_type) = 1;
11151 else if (name == ansi_opname[(int) NEW_EXPR])
11152 TYPE_GETS_NEW (current_class_type) |= 1;
11153 else if (name == ansi_opname[(int) DELETE_EXPR])
11154 TYPE_GETS_DELETE (current_class_type) |= 1;
11155 else if (name == ansi_opname[(int) VEC_NEW_EXPR])
11156 TYPE_GETS_NEW (current_class_type) |= 2;
11157 else if (name == ansi_opname[(int) VEC_DELETE_EXPR])
11158 TYPE_GETS_DELETE (current_class_type) |= 2;
11159 }
11160
11161 if (name == ansi_opname[(int) NEW_EXPR]
11162 || name == ansi_opname[(int) VEC_NEW_EXPR])
11163 {
11164 /* When the compiler encounters the definition of A::operator new, it
11165 doesn't look at the class declaration to find out if it's static. */
11166 if (methodp)
11167 revert_static_member_fn (&decl, NULL, NULL);
11168
11169 /* Take care of function decl if we had syntax errors. */
11170 if (argtypes == NULL_TREE)
11171 TREE_TYPE (decl)
11172 = build_function_type (ptr_type_node,
11173 hash_tree_chain (integer_type_node,
11174 void_list_node));
11175 else
11176 TREE_TYPE (decl) = coerce_new_type (TREE_TYPE (decl));
11177 }
11178 else if (name == ansi_opname[(int) DELETE_EXPR]
11179 || name == ansi_opname[(int) VEC_DELETE_EXPR])
11180 {
11181 if (methodp)
11182 revert_static_member_fn (&decl, NULL, NULL);
11183
11184 if (argtypes == NULL_TREE)
11185 TREE_TYPE (decl)
11186 = build_function_type (void_type_node,
11187 hash_tree_chain (ptr_type_node,
11188 void_list_node));
11189 else
11190 {
11191 TREE_TYPE (decl) = coerce_delete_type (TREE_TYPE (decl));
11192
11193 if (! friendp && name == ansi_opname[(int) VEC_DELETE_EXPR]
11194 && (TREE_CHAIN (TYPE_ARG_TYPES (TREE_TYPE (decl)))
11195 != void_list_node))
11196 TYPE_VEC_DELETE_TAKES_SIZE (current_class_type) = 1;
11197 }
11198 }
11199 else
11200 {
11201 /* An operator function must either be a non-static member function
11202 or have at least one parameter of a class, a reference to a class,
11203 an enumeration, or a reference to an enumeration. 13.4.0.6 */
11204 if (! methodp || DECL_STATIC_FUNCTION_P (decl))
11205 {
11206 if (OPERATOR_TYPENAME_P (name)
11207 || name == ansi_opname[(int) CALL_EXPR]
11208 || name == ansi_opname[(int) MODIFY_EXPR]
11209 || name == ansi_opname[(int) COMPONENT_REF]
11210 || name == ansi_opname[(int) ARRAY_REF])
11211 cp_error ("`%D' must be a nonstatic member function", decl);
11212 else
11213 {
11214 tree p = argtypes;
11215
11216 if (DECL_STATIC_FUNCTION_P (decl))
11217 cp_error ("`%D' must be either a non-static member function or a non-member function", decl);
11218
11219 if (p)
11220 for (; TREE_CODE (TREE_VALUE (p)) != VOID_TYPE ; p = TREE_CHAIN (p))
11221 {
11222 tree arg = TREE_VALUE (p);
11223 if (TREE_CODE (arg) == REFERENCE_TYPE)
11224 arg = TREE_TYPE (arg);
11225
11226 /* This lets bad template code slip through. */
11227 if (IS_AGGR_TYPE (arg)
11228 || TREE_CODE (arg) == ENUMERAL_TYPE
11229 || TREE_CODE (arg) == TEMPLATE_TYPE_PARM
11230 || TREE_CODE (arg) == TEMPLATE_TEMPLATE_PARM)
11231 goto foundaggr;
11232 }
11233 cp_error
11234 ("`%D' must have an argument of class or enumerated type",
11235 decl);
11236 foundaggr:
11237 ;
11238 }
11239 }
11240
11241 if (name == ansi_opname[(int) CALL_EXPR])
11242 return; /* No restrictions on args. */
11243
11244 if (IDENTIFIER_TYPENAME_P (name) && ! DECL_TEMPLATE_INFO (decl))
11245 {
11246 tree t = TREE_TYPE (name);
11247 if (TREE_CODE (t) == VOID_TYPE)
11248 pedwarn ("void is not a valid type conversion operator");
11249 else if (! friendp)
11250 {
11251 int ref = (TREE_CODE (t) == REFERENCE_TYPE);
11252 char *what = 0;
11253 if (ref)
11254 t = TYPE_MAIN_VARIANT (TREE_TYPE (t));
11255
11256 if (t == current_class_type)
11257 what = "the same type";
11258 /* Don't force t to be complete here. */
11259 else if (IS_AGGR_TYPE (t)
11260 && TYPE_SIZE (t)
11261 && DERIVED_FROM_P (t, current_class_type))
11262 what = "a base class";
11263
11264 if (what)
11265 warning ("conversion to %s%s will never use a type conversion operator",
11266 ref ? "a reference to " : "", what);
11267 }
11268 }
11269
11270 if (name == ansi_opname[(int) MODIFY_EXPR])
11271 {
11272 tree parmtype;
11273
11274 if (list_length (argtypes) != 3 && methodp)
11275 {
11276 cp_error ("`%D' must take exactly one argument", decl);
11277 return;
11278 }
11279 parmtype = TREE_VALUE (TREE_CHAIN (argtypes));
11280
11281 if (copy_assignment_arg_p (parmtype, virtualp)
11282 && ! friendp)
11283 {
11284 TYPE_HAS_ASSIGN_REF (current_class_type) = 1;
11285 if (TREE_CODE (parmtype) != REFERENCE_TYPE
11286 || TYPE_READONLY (TREE_TYPE (parmtype)))
11287 TYPE_HAS_CONST_ASSIGN_REF (current_class_type) = 1;
11288 }
11289 }
11290 else if (name == ansi_opname[(int) COND_EXPR])
11291 {
11292 /* 13.4.0.3 */
11293 pedwarn ("ANSI C++ prohibits overloading operator ?:");
11294 if (list_length (argtypes) != 4)
11295 cp_error ("`%D' must take exactly three arguments", decl);
11296 }
11297 else if (ambi_op_p (name))
11298 {
11299 if (list_length (argtypes) == 2)
11300 /* prefix */;
11301 else if (list_length (argtypes) == 3)
11302 {
11303 if ((name == ansi_opname[(int) POSTINCREMENT_EXPR]
11304 || name == ansi_opname[(int) POSTDECREMENT_EXPR])
11305 && ! processing_template_decl
11306 && TREE_VALUE (TREE_CHAIN (argtypes)) != integer_type_node)
11307 {
11308 if (methodp)
11309 cp_error ("postfix `%D' must take `int' as its argument",
11310 decl);
11311 else
11312 cp_error
11313 ("postfix `%D' must take `int' as its second argument",
11314 decl);
11315 }
11316 }
11317 else
11318 {
11319 if (methodp)
11320 cp_error ("`%D' must take either zero or one argument", decl);
11321 else
11322 cp_error ("`%D' must take either one or two arguments", decl);
11323 }
11324
11325 /* More Effective C++ rule 6. */
11326 if (warn_ecpp
11327 && (name == ansi_opname[(int) POSTINCREMENT_EXPR]
11328 || name == ansi_opname[(int) POSTDECREMENT_EXPR]))
11329 {
11330 tree arg = TREE_VALUE (argtypes);
11331 tree ret = TREE_TYPE (TREE_TYPE (decl));
11332 if (methodp || TREE_CODE (arg) == REFERENCE_TYPE)
11333 arg = TREE_TYPE (arg);
11334 arg = TYPE_MAIN_VARIANT (arg);
11335 if (list_length (argtypes) == 2)
11336 {
11337 if (TREE_CODE (ret) != REFERENCE_TYPE
11338 || !comptypes (TYPE_MAIN_VARIANT (TREE_TYPE (ret)),
11339 arg, 1))
11340 cp_warning ("prefix `%D' should return `%T'", decl,
11341 build_reference_type (arg));
11342 }
11343 else
11344 {
11345 if (!comptypes (TYPE_MAIN_VARIANT (ret), arg, 1))
11346 cp_warning ("postfix `%D' should return `%T'", decl, arg);
11347 }
11348 }
11349 }
11350 else if (unary_op_p (name))
11351 {
11352 if (list_length (argtypes) != 2)
11353 {
11354 if (methodp)
11355 cp_error ("`%D' must take `void'", decl);
11356 else
11357 cp_error ("`%D' must take exactly one argument", decl);
11358 }
11359 }
11360 else /* if (binary_op_p (name)) */
11361 {
11362 if (list_length (argtypes) != 3)
11363 {
11364 if (methodp)
11365 cp_error ("`%D' must take exactly one argument", decl);
11366 else
11367 cp_error ("`%D' must take exactly two arguments", decl);
11368 }
11369
11370 /* More Effective C++ rule 7. */
11371 if (warn_ecpp
11372 && (name == ansi_opname [TRUTH_ANDIF_EXPR]
11373 || name == ansi_opname [TRUTH_ORIF_EXPR]
11374 || name == ansi_opname [COMPOUND_EXPR]))
11375 cp_warning ("user-defined `%D' always evaluates both arguments",
11376 decl);
11377 }
11378
11379 /* Effective C++ rule 23. */
11380 if (warn_ecpp
11381 && list_length (argtypes) == 3
11382 && (name == ansi_opname [PLUS_EXPR]
11383 || name == ansi_opname [MINUS_EXPR]
11384 || name == ansi_opname [TRUNC_DIV_EXPR]
11385 || name == ansi_opname [MULT_EXPR])
11386 && TREE_CODE (TREE_TYPE (TREE_TYPE (decl))) == REFERENCE_TYPE)
11387 cp_warning ("`%D' should return by value", decl);
11388
11389 /* 13.4.0.8 */
11390 if (argtypes)
11391 for (; argtypes != void_list_node ; argtypes = TREE_CHAIN (argtypes))
11392 if (TREE_PURPOSE (argtypes))
11393 {
11394 TREE_PURPOSE (argtypes) = NULL_TREE;
11395 if (name == ansi_opname[(int) POSTINCREMENT_EXPR]
11396 || name == ansi_opname[(int) POSTDECREMENT_EXPR])
11397 {
11398 if (pedantic)
11399 cp_pedwarn ("`%D' cannot have default arguments", decl);
11400 }
11401 else
11402 cp_error ("`%D' cannot have default arguments", decl);
11403 }
11404 }
11405 }
11406 \f
11407 /* Get the struct, enum or union (CODE says which) with tag NAME.
11408 Define the tag as a forward-reference if it is not defined.
11409
11410 C++: If a class derivation is given, process it here, and report
11411 an error if multiple derivation declarations are not identical.
11412
11413 If this is a definition, come in through xref_tag and only look in
11414 the current frame for the name (since C++ allows new names in any
11415 scope.) */
11416
11417 tree
11418 xref_tag (code_type_node, name, globalize)
11419 tree code_type_node;
11420 tree name;
11421 int globalize;
11422 {
11423 enum tag_types tag_code;
11424 enum tree_code code;
11425 int temp = 0;
11426 register tree ref, t;
11427 struct binding_level *b = inner_binding_level;
11428 int got_type = 0;
11429 tree attributes = NULL_TREE;
11430
11431 /* If we are called from the parser, code_type_node will sometimes be a
11432 TREE_LIST. This indicates that the user wrote
11433 "class __attribute__ ((foo)) bar". Extract the attributes so we can
11434 use them later. */
11435 if (TREE_CODE (code_type_node) == TREE_LIST)
11436 {
11437 attributes = TREE_PURPOSE (code_type_node);
11438 code_type_node = TREE_VALUE (code_type_node);
11439 }
11440
11441 tag_code = (enum tag_types) TREE_INT_CST_LOW (code_type_node);
11442 switch (tag_code)
11443 {
11444 case record_type:
11445 case class_type:
11446 case signature_type:
11447 code = RECORD_TYPE;
11448 break;
11449 case union_type:
11450 code = UNION_TYPE;
11451 break;
11452 case enum_type:
11453 code = ENUMERAL_TYPE;
11454 break;
11455 default:
11456 my_friendly_abort (18);
11457 }
11458
11459 /* If a cross reference is requested, look up the type
11460 already defined for this tag and return it. */
11461 if (TREE_CODE_CLASS (TREE_CODE (name)) == 't')
11462 {
11463 t = name;
11464 name = TYPE_IDENTIFIER (t);
11465 got_type = 1;
11466 }
11467 else
11468 t = IDENTIFIER_TYPE_VALUE (name);
11469 if (t && TREE_CODE (t) != code && TREE_CODE (t) != TEMPLATE_TYPE_PARM
11470 && TREE_CODE (t) != TEMPLATE_TEMPLATE_PARM)
11471 t = NULL_TREE;
11472
11473 if (! globalize)
11474 {
11475 if (t && (TREE_CODE (t) == TEMPLATE_TYPE_PARM
11476 || TREE_CODE (t) == TEMPLATE_TEMPLATE_PARM))
11477 {
11478 cp_error ("redeclaration of template type-parameter `%T'", name);
11479 cp_error_at (" previously declared here `%#D'",
11480 TEMPLATE_TYPE_DECL (t));
11481 }
11482 if (t && TYPE_CONTEXT (t) && got_type)
11483 ref = t;
11484 else
11485 /* If we know we are defining this tag, only look it up in
11486 this scope and don't try to find it as a type. */
11487 ref = lookup_tag (code, name, b, 1);
11488 }
11489 else
11490 {
11491 if (current_class_type
11492 && template_class_depth (current_class_type)
11493 && PROCESSING_REAL_TEMPLATE_DECL_P ())
11494 /* Since GLOBALIZE is non-zero, we are not looking at a
11495 definition of this tag. Since, in addition, we are currently
11496 processing a (member) template declaration of a template
11497 class, we don't want to do any lookup at all; consider:
11498
11499 template <class X>
11500 struct S1
11501
11502 template <class U>
11503 struct S2
11504 { template <class V>
11505 friend struct S1; };
11506
11507 Here, the S2::S1 declaration should not be confused with the
11508 outer declaration. In particular, the inner version should
11509 have a template parameter of level 2, not level 1. This
11510 would be particularly important if the member declaration
11511 were instead:
11512
11513 template <class V = U> friend struct S1;
11514
11515 say, when we should tsubst into `U' when instantiating S2. */
11516 ref = NULL_TREE;
11517 else
11518 {
11519 if (t)
11520 ref = t;
11521 else
11522 ref = lookup_tag (code, name, b, 0);
11523
11524 if (! ref)
11525 {
11526 /* Try finding it as a type declaration. If that wins,
11527 use it. */
11528 ref = lookup_name (name, 1);
11529
11530 if (ref != NULL_TREE
11531 && processing_template_decl
11532 && DECL_CLASS_TEMPLATE_P (ref)
11533 && template_class_depth (current_class_type) == 0)
11534 /* Since GLOBALIZE is true, we're declaring a global
11535 template, so we want this type. */
11536 ref = DECL_RESULT (ref);
11537
11538 if (ref && TREE_CODE (ref) == TYPE_DECL
11539 && TREE_CODE (TREE_TYPE (ref)) == code)
11540 ref = TREE_TYPE (ref);
11541 else
11542 ref = NULL_TREE;
11543 }
11544 }
11545 }
11546
11547 push_obstacks_nochange ();
11548
11549 if (! ref)
11550 {
11551 /* If no such tag is yet defined, create a forward-reference node
11552 and record it as the "definition".
11553 When a real declaration of this type is found,
11554 the forward-reference will be altered into a real type. */
11555
11556 /* In C++, since these migrate into the global scope, we must
11557 build them on the permanent obstack. */
11558
11559 temp = allocation_temporary_p ();
11560 if (temp)
11561 end_temporary_allocation ();
11562
11563 if (code == ENUMERAL_TYPE)
11564 {
11565 cp_error ("use of enum `%#D' without previous declaration", name);
11566
11567 ref = make_node (ENUMERAL_TYPE);
11568
11569 /* Give the type a default layout like unsigned int
11570 to avoid crashing if it does not get defined. */
11571 TYPE_MODE (ref) = TYPE_MODE (unsigned_type_node);
11572 TYPE_ALIGN (ref) = TYPE_ALIGN (unsigned_type_node);
11573 TREE_UNSIGNED (ref) = 1;
11574 TYPE_PRECISION (ref) = TYPE_PRECISION (unsigned_type_node);
11575 TYPE_MIN_VALUE (ref) = TYPE_MIN_VALUE (unsigned_type_node);
11576 TYPE_MAX_VALUE (ref) = TYPE_MAX_VALUE (unsigned_type_node);
11577
11578 /* Enable us to recognize when a type is created in class context.
11579 To do nested classes correctly, this should probably be cleared
11580 out when we leave this classes scope. Currently this in only
11581 done in `start_enum'. */
11582
11583 pushtag (name, ref, globalize);
11584 }
11585 else
11586 {
11587 struct binding_level *old_b = class_binding_level;
11588
11589 ref = make_lang_type (code);
11590
11591 if (tag_code == signature_type)
11592 {
11593 SET_SIGNATURE (ref);
11594 /* Since a signature type will be turned into the type
11595 of signature tables, it's not only an interface. */
11596 CLASSTYPE_INTERFACE_ONLY (ref) = 0;
11597 SET_CLASSTYPE_INTERFACE_KNOWN (ref);
11598 /* A signature doesn't have a vtable. */
11599 CLASSTYPE_VTABLE_NEEDS_WRITING (ref) = 0;
11600 }
11601
11602 #ifdef NONNESTED_CLASSES
11603 /* Class types don't nest the way enums do. */
11604 class_binding_level = (struct binding_level *)0;
11605 #endif
11606 pushtag (name, ref, globalize);
11607 class_binding_level = old_b;
11608 }
11609 }
11610 else
11611 {
11612 /* If it no longer looks like a nested type, make sure it's
11613 in global scope.
11614 If it is not an IDENTIFIER, this is not a declaration */
11615 if (b->namespace_p && !class_binding_level
11616 && TREE_CODE (name) == IDENTIFIER_NODE)
11617 {
11618 if (IDENTIFIER_NAMESPACE_VALUE (name) == NULL_TREE)
11619 SET_IDENTIFIER_NAMESPACE_VALUE (name, TYPE_NAME (ref));
11620 }
11621
11622 if (!globalize && processing_template_decl && IS_AGGR_TYPE (ref))
11623 redeclare_class_template (ref, current_template_parms);
11624 }
11625
11626 /* Until the type is defined, tentatively accept whatever
11627 structure tag the user hands us. */
11628 if (TYPE_SIZE (ref) == NULL_TREE
11629 && ref != current_class_type
11630 /* Have to check this, in case we have contradictory tag info. */
11631 && IS_AGGR_TYPE_CODE (TREE_CODE (ref)))
11632 {
11633 if (tag_code == class_type)
11634 CLASSTYPE_DECLARED_CLASS (ref) = 1;
11635 else if (tag_code == record_type || tag_code == signature_type)
11636 CLASSTYPE_DECLARED_CLASS (ref) = 0;
11637 }
11638
11639 pop_obstacks ();
11640
11641 TREE_TYPE (ref) = attributes;
11642
11643 return ref;
11644 }
11645
11646 tree
11647 xref_tag_from_type (old, id, globalize)
11648 tree old, id;
11649 int globalize;
11650 {
11651 tree code_type_node;
11652
11653 if (TREE_CODE (old) == RECORD_TYPE)
11654 code_type_node = (CLASSTYPE_DECLARED_CLASS (old)
11655 ? class_type_node : record_type_node);
11656 else
11657 code_type_node = union_type_node;
11658
11659 if (id == NULL_TREE)
11660 id = TYPE_IDENTIFIER (old);
11661
11662 return xref_tag (code_type_node, id, globalize);
11663 }
11664
11665 void
11666 xref_basetypes (code_type_node, name, ref, binfo)
11667 tree code_type_node;
11668 tree name, ref;
11669 tree binfo;
11670 {
11671 /* In the declaration `A : X, Y, ... Z' we mark all the types
11672 (A, X, Y, ..., Z) so we can check for duplicates. */
11673 tree binfos;
11674 int i, len;
11675 enum tag_types tag_code = (enum tag_types) TREE_INT_CST_LOW (code_type_node);
11676
11677 if (tag_code == union_type)
11678 {
11679 cp_error ("derived union `%T' invalid", ref);
11680 return;
11681 }
11682
11683 len = list_length (binfo);
11684 push_obstacks (TYPE_OBSTACK (ref), TYPE_OBSTACK (ref));
11685
11686 SET_CLASSTYPE_MARKED (ref);
11687 BINFO_BASETYPES (TYPE_BINFO (ref)) = binfos = make_tree_vec (len);
11688
11689 for (i = 0; binfo; binfo = TREE_CHAIN (binfo))
11690 {
11691 /* The base of a derived struct is public by default. */
11692 int via_public
11693 = (TREE_PURPOSE (binfo) == access_public_node
11694 || TREE_PURPOSE (binfo) == access_public_virtual_node
11695 || (tag_code != class_type
11696 && (TREE_PURPOSE (binfo) == access_default_node
11697 || TREE_PURPOSE (binfo) == access_default_virtual_node)));
11698 int via_protected
11699 = (TREE_PURPOSE (binfo) == access_protected_node
11700 || TREE_PURPOSE (binfo) == access_protected_virtual_node);
11701 int via_virtual
11702 = (TREE_PURPOSE (binfo) == access_private_virtual_node
11703 || TREE_PURPOSE (binfo) == access_protected_virtual_node
11704 || TREE_PURPOSE (binfo) == access_public_virtual_node
11705 || TREE_PURPOSE (binfo) == access_default_virtual_node);
11706 tree basetype = TREE_VALUE (binfo);
11707 tree base_binfo;
11708
11709 if (basetype && TREE_CODE (basetype) == TYPE_DECL)
11710 basetype = TREE_TYPE (basetype);
11711 if (!basetype
11712 || (TREE_CODE (basetype) != RECORD_TYPE
11713 && TREE_CODE (basetype) != TYPENAME_TYPE
11714 && TREE_CODE (basetype) != TEMPLATE_TYPE_PARM
11715 && TREE_CODE (basetype) != TEMPLATE_TEMPLATE_PARM))
11716 {
11717 cp_error ("base type `%T' fails to be a struct or class type",
11718 TREE_VALUE (binfo));
11719 continue;
11720 }
11721
11722 GNU_xref_hier (name, basetype, via_public, via_virtual, 0);
11723
11724 #if 1
11725 /* This code replaces similar code in layout_basetypes.
11726 We put the complete_type first for implicit `typename'. */
11727 if (TYPE_SIZE (complete_type (basetype)) == NULL_TREE
11728 && ! (current_template_parms && uses_template_parms (basetype)))
11729 {
11730 cp_error ("base class `%T' has incomplete type", basetype);
11731 continue;
11732 }
11733 #endif
11734 else
11735 {
11736 if (CLASSTYPE_MARKED (basetype))
11737 {
11738 if (basetype == ref)
11739 cp_error ("recursive type `%T' undefined", basetype);
11740 else
11741 cp_error ("duplicate base type `%T' invalid", basetype);
11742 continue;
11743 }
11744
11745 if (TYPE_FOR_JAVA (basetype)
11746 && current_lang_stack == current_lang_base)
11747 TYPE_FOR_JAVA (ref) = 1;
11748
11749 /* Note that the BINFO records which describe individual
11750 inheritances are *not* shared in the lattice! They
11751 cannot be shared because a given baseclass may be
11752 inherited with different `accessibility' by different
11753 derived classes. (Each BINFO record describing an
11754 individual inheritance contains flags which say what
11755 the `accessibility' of that particular inheritance is.) */
11756
11757 base_binfo = make_binfo (integer_zero_node, basetype,
11758 TYPE_BINFO_VTABLE (basetype),
11759 TYPE_BINFO_VIRTUALS (basetype));
11760
11761 TREE_VEC_ELT (binfos, i) = base_binfo;
11762 TREE_VIA_PUBLIC (base_binfo) = via_public;
11763 TREE_VIA_PROTECTED (base_binfo) = via_protected;
11764 TREE_VIA_VIRTUAL (base_binfo) = via_virtual;
11765 BINFO_INHERITANCE_CHAIN (base_binfo) = TYPE_BINFO (ref);
11766
11767 /* We need to unshare the binfos now so that lookups during class
11768 definition work. */
11769 unshare_base_binfos (base_binfo);
11770
11771 SET_CLASSTYPE_MARKED (basetype);
11772
11773 /* We are free to modify these bits because they are meaningless
11774 at top level, and BASETYPE is a top-level type. */
11775 if (via_virtual || TYPE_USES_VIRTUAL_BASECLASSES (basetype))
11776 {
11777 TYPE_USES_VIRTUAL_BASECLASSES (ref) = 1;
11778 TYPE_USES_COMPLEX_INHERITANCE (ref) = 1;
11779 }
11780
11781 TYPE_GETS_NEW (ref) |= TYPE_GETS_NEW (basetype);
11782 TYPE_GETS_DELETE (ref) |= TYPE_GETS_DELETE (basetype);
11783 CLASSTYPE_LOCAL_TYPEDECLS (ref) |= CLASSTYPE_LOCAL_TYPEDECLS (basetype);
11784 i += 1;
11785 }
11786 }
11787 if (i)
11788 TREE_VEC_LENGTH (binfos) = i;
11789 else
11790 BINFO_BASETYPES (TYPE_BINFO (ref)) = NULL_TREE;
11791
11792 if (i > 1)
11793 TYPE_USES_MULTIPLE_INHERITANCE (ref) = 1;
11794 else if (i == 1)
11795 TYPE_USES_MULTIPLE_INHERITANCE (ref)
11796 = TYPE_USES_MULTIPLE_INHERITANCE (BINFO_TYPE (TREE_VEC_ELT (binfos, 0)));
11797 if (TYPE_USES_MULTIPLE_INHERITANCE (ref))
11798 TYPE_USES_COMPLEX_INHERITANCE (ref) = 1;
11799
11800 /* Unmark all the types. */
11801 while (--i >= 0)
11802 CLEAR_CLASSTYPE_MARKED (BINFO_TYPE (TREE_VEC_ELT (binfos, i)));
11803 CLEAR_CLASSTYPE_MARKED (ref);
11804
11805 pop_obstacks ();
11806 }
11807
11808 \f
11809 tree current_local_enum = NULL_TREE;
11810
11811 /* Begin compiling the definition of an enumeration type.
11812 NAME is its name (or null if anonymous).
11813 Returns the type object, as yet incomplete.
11814 Also records info about it so that build_enumerator
11815 may be used to declare the individual values as they are read. */
11816
11817 tree
11818 start_enum (name)
11819 tree name;
11820 {
11821 register tree enumtype = NULL_TREE;
11822 struct binding_level *b = inner_binding_level;
11823
11824 /* We are wasting space here and putting these on the permanent_obstack so
11825 that typeid(local enum) will work correctly. */
11826 #if 0
11827 if (processing_template_decl && current_function_decl)
11828 #endif
11829
11830 end_temporary_allocation ();
11831
11832 /* If this is the real definition for a previous forward reference,
11833 fill in the contents in the same object that used to be the
11834 forward reference. */
11835
11836 if (name != NULL_TREE)
11837 enumtype = lookup_tag (ENUMERAL_TYPE, name, b, 1);
11838
11839 if (enumtype != NULL_TREE && TREE_CODE (enumtype) == ENUMERAL_TYPE)
11840 cp_error ("multiple definition of `%#T'", enumtype);
11841 else
11842 {
11843 enumtype = make_node (ENUMERAL_TYPE);
11844 pushtag (name, enumtype, 0);
11845 }
11846
11847 if (current_class_type)
11848 TREE_ADDRESSABLE (b->tags) = 1;
11849
11850 current_local_enum = NULL_TREE;
11851
11852 /* We don't copy this value because build_enumerator needs to do it. */
11853 enum_next_value = integer_zero_node;
11854 enum_overflow = 0;
11855
11856 GNU_xref_decl (current_function_decl, enumtype);
11857 return enumtype;
11858 }
11859
11860 /* After processing and defining all the values of an enumeration type,
11861 install their decls in the enumeration type and finish it off.
11862 ENUMTYPE is the type object and VALUES a list of name-value pairs.
11863 Returns ENUMTYPE. */
11864
11865 tree
11866 finish_enum (enumtype)
11867 tree enumtype;
11868 {
11869 register tree minnode = NULL_TREE, maxnode = NULL_TREE;
11870 /* Calculate the maximum value of any enumerator in this type. */
11871
11872 tree values = TYPE_VALUES (enumtype);
11873 if (values)
11874 {
11875 tree pair;
11876
11877 for (pair = values; pair; pair = TREE_CHAIN (pair))
11878 {
11879 tree decl;
11880 tree value;
11881
11882 /* The TREE_VALUE is a CONST_DECL for this enumeration
11883 constant. */
11884 decl = TREE_VALUE (pair);
11885
11886 /* The type of the CONST_DECL is the type of the enumeration,
11887 not an INTEGER_TYPE. */
11888 TREE_TYPE (decl) = enumtype;
11889
11890 /* The DECL_INITIAL will be NULL if we are processing a
11891 template declaration and this enumeration constant had no
11892 explicit initializer. */
11893 value = DECL_INITIAL (decl);
11894 if (value)
11895 {
11896 /* Set the TREE_TYPE for the VALUE as well. When
11897 processing a template, however, we might have a
11898 TEMPLATE_PARM_INDEX, and we should not change the
11899 type of such a thing. */
11900 if (TREE_CODE (value) == TEMPLATE_PARM_INDEX)
11901 DECL_INITIAL (decl) = value
11902 = build1 (NOP_EXPR, enumtype, value);
11903 TREE_TYPE (value) = enumtype;
11904
11905 if (!processing_template_decl)
11906 {
11907 if (!minnode)
11908 minnode = maxnode = value;
11909 else if (tree_int_cst_lt (maxnode, value))
11910 maxnode = value;
11911 else if (tree_int_cst_lt (value, minnode))
11912 minnode = value;
11913 }
11914 }
11915
11916 /* In the list we're building up, we want the enumeration
11917 values, not the CONST_DECLs. */
11918 TREE_VALUE (pair) = value;
11919 }
11920 }
11921 else
11922 maxnode = minnode = integer_zero_node;
11923
11924 TYPE_VALUES (enumtype) = nreverse (values);
11925
11926 if (processing_template_decl)
11927 {
11928 if (current_function_decl)
11929 {
11930 add_tree (build_min (TAG_DEFN, enumtype));
11931 resume_temporary_allocation ();
11932 }
11933 return enumtype;
11934 }
11935
11936 {
11937 int unsignedp = tree_int_cst_sgn (minnode) >= 0;
11938 int lowprec = min_precision (minnode, unsignedp);
11939 int highprec = min_precision (maxnode, unsignedp);
11940 int precision = MAX (lowprec, highprec);
11941
11942 TYPE_SIZE (enumtype) = NULL_TREE;
11943
11944 /* Set TYPE_MIN_VALUE and TYPE_MAX_VALUE according to `precision'. */
11945
11946 TYPE_PRECISION (enumtype) = precision;
11947 if (unsignedp)
11948 fixup_unsigned_type (enumtype);
11949 else
11950 fixup_signed_type (enumtype);
11951
11952 if (flag_short_enums || (precision > TYPE_PRECISION (integer_type_node)))
11953 /* Use the width of the narrowest normal C type which is wide enough. */
11954 TYPE_PRECISION (enumtype) = TYPE_PRECISION (type_for_size
11955 (precision, 1));
11956 else
11957 TYPE_PRECISION (enumtype) = TYPE_PRECISION (integer_type_node);
11958
11959 TYPE_SIZE (enumtype) = 0;
11960 layout_type (enumtype);
11961 }
11962
11963 {
11964 register tree tem;
11965
11966 /* Fix up all variant types of this enum type. */
11967 for (tem = TYPE_MAIN_VARIANT (enumtype); tem;
11968 tem = TYPE_NEXT_VARIANT (tem))
11969 {
11970 TYPE_VALUES (tem) = TYPE_VALUES (enumtype);
11971 TYPE_MIN_VALUE (tem) = TYPE_MIN_VALUE (enumtype);
11972 TYPE_MAX_VALUE (tem) = TYPE_MAX_VALUE (enumtype);
11973 TYPE_SIZE (tem) = TYPE_SIZE (enumtype);
11974 TYPE_SIZE_UNIT (tem) = TYPE_SIZE_UNIT (enumtype);
11975 TYPE_MODE (tem) = TYPE_MODE (enumtype);
11976 TYPE_PRECISION (tem) = TYPE_PRECISION (enumtype);
11977 TYPE_ALIGN (tem) = TYPE_ALIGN (enumtype);
11978 TREE_UNSIGNED (tem) = TREE_UNSIGNED (enumtype);
11979 }
11980 }
11981
11982 /* Finish debugging output for this type. */
11983 rest_of_type_compilation (enumtype, namespace_bindings_p ());
11984
11985 return enumtype;
11986 }
11987
11988 /* Build and install a CONST_DECL for one value of the
11989 current enumeration type (one that was begun with start_enum).
11990 Return a tree-list containing the name and its value.
11991 Assignment of sequential values by default is handled here. */
11992
11993 tree
11994 build_enumerator (name, value)
11995 tree name, value;
11996 {
11997 tree decl, result;
11998 tree context;
11999
12000 /* Remove no-op casts from the value. */
12001 if (value)
12002 STRIP_TYPE_NOPS (value);
12003
12004 if (! processing_template_decl)
12005 {
12006 /* Validate and default VALUE. */
12007 if (value != NULL_TREE)
12008 {
12009 if (TREE_READONLY_DECL_P (value))
12010 value = decl_constant_value (value);
12011
12012 if (TREE_CODE (value) == INTEGER_CST)
12013 {
12014 value = default_conversion (value);
12015 constant_expression_warning (value);
12016 }
12017 else
12018 {
12019 cp_error ("enumerator value for `%D' not integer constant", name);
12020 value = NULL_TREE;
12021 }
12022 }
12023
12024 /* Default based on previous value. */
12025 if (value == NULL_TREE && ! processing_template_decl)
12026 {
12027 value = enum_next_value;
12028 if (enum_overflow)
12029 cp_error ("overflow in enumeration values at `%D'", name);
12030 }
12031
12032 /* Remove no-op casts from the value. */
12033 if (value)
12034 STRIP_TYPE_NOPS (value);
12035 #if 0
12036 /* To fix MAX_VAL enum consts. (bkoz) */
12037 TREE_TYPE (value) = integer_type_node;
12038 #endif
12039 }
12040
12041 /* We have to always copy here; not all INTEGER_CSTs are unshared,
12042 and there's no wedding ring. Look at size_int()...*/
12043 if (value != NULL_TREE)
12044 value = copy_node (value);
12045
12046 /* C++ associates enums with global, function, or class declarations. */
12047
12048 context = current_scope ();
12049 if (context && context == current_class_type)
12050 /* This enum declaration is local to the class. */
12051 decl = build_lang_field_decl (CONST_DECL, name, integer_type_node);
12052 else
12053 /* It's a global enum, or it's local to a function. (Note local to
12054 a function could mean local to a class method. */
12055 decl = build_decl (CONST_DECL, name, integer_type_node);
12056
12057 DECL_CONTEXT (decl) = FROB_CONTEXT (context);
12058 DECL_INITIAL (decl) = value;
12059 TREE_READONLY (decl) = 1;
12060
12061 if (context && context == current_class_type)
12062 {
12063 pushdecl_class_level (decl);
12064 TREE_CHAIN (decl) = current_local_enum;
12065 current_local_enum = decl;
12066 }
12067 else
12068 {
12069 pushdecl (decl);
12070 GNU_xref_decl (current_function_decl, decl);
12071 }
12072
12073 if (! processing_template_decl)
12074 {
12075 /* Set basis for default for next value. */
12076 enum_next_value = build_binary_op_nodefault (PLUS_EXPR, value,
12077 integer_one_node, PLUS_EXPR);
12078 enum_overflow = tree_int_cst_lt (enum_next_value, value);
12079 }
12080
12081 result = saveable_tree_cons (name, decl, NULL_TREE);
12082 return result;
12083 }
12084
12085 /* Called after we have finished the declaration of an enumeration
12086 type, and, perhaps, some objects whose type involves the
12087 enumeration type. DECL, if non-NULL, is the declaration of the
12088 first such object.
12089
12090 If CURRENT_LOCAL_ENUM is NULL, the DECL is returned.
12091
12092 If CURRENT_LOCAL_ENUM is non-NULL, it should be the CONST_DECL for
12093 the last enumeration constant of an enumeration type that is a
12094 member of a class. The enumeration constants are already chained
12095 together through their TREE_CHAIN fields. This function sets the
12096 TREE_CHAIN of the last enumeration constant to DECL. The
12097 CONST_DECL for the last enumeration constant is returned.
12098
12099 CURRENT_LOCAL_ENUM will always be NULL when this function
12100 returns. */
12101
12102 tree
12103 grok_enum_decls (decl)
12104 tree decl;
12105 {
12106 tree d = current_local_enum;
12107
12108 if (d == NULL_TREE)
12109 return decl;
12110
12111 while (1)
12112 {
12113 if (TREE_CHAIN (d) == NULL_TREE)
12114 {
12115 TREE_CHAIN (d) = decl;
12116 break;
12117 }
12118 d = TREE_CHAIN (d);
12119 }
12120
12121 decl = current_local_enum;
12122 current_local_enum = NULL_TREE;
12123
12124 return decl;
12125 }
12126 \f
12127 static int function_depth;
12128
12129 /* Create the FUNCTION_DECL for a function definition.
12130 DECLSPECS and DECLARATOR are the parts of the declaration;
12131 they describe the function's name and the type it returns,
12132 but twisted together in a fashion that parallels the syntax of C.
12133
12134 This function creates a binding context for the function body
12135 as well as setting up the FUNCTION_DECL in current_function_decl.
12136
12137 Returns 1 on success. If the DECLARATOR is not suitable for a function
12138 (it defines a datum instead), we return 0, which tells
12139 yyparse to report a parse error.
12140
12141 For C++, we must first check whether that datum makes any sense.
12142 For example, "class A local_a(1,2);" means that variable local_a
12143 is an aggregate of type A, which should have a constructor
12144 applied to it with the argument list [1, 2].
12145
12146 @@ There is currently no way to retrieve the storage
12147 @@ allocated to FUNCTION (or all of its parms) if we return
12148 @@ something we had previously. */
12149
12150 int
12151 start_function (declspecs, declarator, attrs, pre_parsed_p)
12152 tree declspecs, declarator, attrs;
12153 int pre_parsed_p;
12154 {
12155 tree decl1;
12156 tree ctype = NULL_TREE;
12157 tree fntype;
12158 tree restype;
12159 extern int have_extern_spec;
12160 extern int used_extern_spec;
12161 int doing_friend = 0;
12162
12163 /* Sanity check. */
12164 my_friendly_assert (TREE_CODE (TREE_VALUE (void_list_node)) == VOID_TYPE, 160);
12165 my_friendly_assert (TREE_CHAIN (void_list_node) == NULL_TREE, 161);
12166
12167 /* Assume, until we see it does. */
12168 current_function_returns_value = 0;
12169 current_function_returns_null = 0;
12170 warn_about_return_type = 0;
12171 named_labels = 0;
12172 shadowed_labels = 0;
12173 current_function_assigns_this = 0;
12174 current_function_just_assigned_this = 0;
12175 current_function_parms_stored = 0;
12176 original_result_rtx = NULL_RTX;
12177 base_init_expr = NULL_TREE;
12178 current_base_init_list = NULL_TREE;
12179 current_member_init_list = NULL_TREE;
12180 ctor_label = dtor_label = NULL_TREE;
12181 static_labelno = 0;
12182
12183 clear_temp_name ();
12184
12185 /* This should only be done once on the top most decl. */
12186 if (have_extern_spec && !used_extern_spec)
12187 {
12188 declspecs = decl_tree_cons (NULL_TREE, get_identifier ("extern"), declspecs);
12189 used_extern_spec = 1;
12190 }
12191
12192 if (pre_parsed_p)
12193 {
12194 decl1 = declarator;
12195
12196 #if 0
12197 /* What was this testing for, exactly? */
12198 if (! DECL_ARGUMENTS (decl1)
12199 && !DECL_STATIC_FUNCTION_P (decl1)
12200 && !DECL_ARTIFICIAL (decl1)
12201 && DECL_CLASS_SCOPE_P (decl1)
12202 && TYPE_IDENTIFIER (DECL_CONTEXT (decl1))
12203 && IDENTIFIER_TEMPLATE (TYPE_IDENTIFIER (DECL_CONTEXT (decl1))))
12204 {
12205 tree binding = binding_for_name (DECL_NAME (decl1),
12206 current_namespace);
12207 cp_error ("redeclaration of `%#D'", decl1);
12208 if (IDENTIFIER_CLASS_VALUE (DECL_NAME (decl1)))
12209 cp_error_at ("previous declaration here", IDENTIFIER_CLASS_VALUE (DECL_NAME (decl1)));
12210 else if (BINDING_VALUE (binding))
12211 cp_error_at ("previous declaration here", BINDING_VALUE (binding));
12212 }
12213 #endif
12214
12215 fntype = TREE_TYPE (decl1);
12216 if (TREE_CODE (fntype) == METHOD_TYPE)
12217 ctype = TYPE_METHOD_BASETYPE (fntype);
12218
12219 /* ANSI C++ June 5 1992 WP 11.4.5. A friend function defined in a
12220 class is in the (lexical) scope of the class in which it is
12221 defined. */
12222 if (!ctype && DECL_FRIEND_P (decl1))
12223 {
12224 ctype = DECL_CLASS_CONTEXT (decl1);
12225
12226 /* CTYPE could be null here if we're dealing with a template;
12227 for example, `inline friend float foo()' inside a template
12228 will have no CTYPE set. */
12229 if (ctype && TREE_CODE (ctype) != RECORD_TYPE)
12230 ctype = NULL_TREE;
12231 else
12232 doing_friend = 1;
12233 }
12234
12235 /* In a fcn definition, arg types must be complete. */
12236 require_complete_types_for_parms (DECL_ARGUMENTS (decl1));
12237
12238 /* In case some arg types were completed since the declaration was
12239 parsed, fix up the decls. */
12240 {
12241 tree t = DECL_ARGUMENTS (decl1);
12242 for (; t; t = TREE_CHAIN (t))
12243 layout_decl (t, 0);
12244 }
12245
12246 last_function_parms = DECL_ARGUMENTS (decl1);
12247 last_function_parm_tags = NULL_TREE;
12248 }
12249 else
12250 {
12251 decl1 = grokdeclarator (declarator, declspecs, FUNCDEF, 1, NULL_TREE);
12252 /* If the declarator is not suitable for a function definition,
12253 cause a syntax error. */
12254 if (decl1 == NULL_TREE || TREE_CODE (decl1) != FUNCTION_DECL) return 0;
12255
12256 fntype = TREE_TYPE (decl1);
12257
12258 restype = TREE_TYPE (fntype);
12259 if (IS_AGGR_TYPE (restype) && ! TYPE_PTRMEMFUNC_P (restype)
12260 && ! CLASSTYPE_GOT_SEMICOLON (restype))
12261 {
12262 cp_error ("semicolon missing after declaration of `%#T'", restype);
12263 shadow_tag (build_expr_list (NULL_TREE, restype));
12264 CLASSTYPE_GOT_SEMICOLON (restype) = 1;
12265 if (TREE_CODE (fntype) == FUNCTION_TYPE)
12266 fntype = build_function_type (integer_type_node,
12267 TYPE_ARG_TYPES (fntype));
12268 else
12269 fntype = build_cplus_method_type (build_type_variant (TYPE_METHOD_BASETYPE (fntype), TREE_READONLY (decl1), TREE_SIDE_EFFECTS (decl1)),
12270 integer_type_node,
12271 TYPE_ARG_TYPES (fntype));
12272 TREE_TYPE (decl1) = fntype;
12273 }
12274
12275 if (TREE_CODE (fntype) == METHOD_TYPE)
12276 ctype = TYPE_METHOD_BASETYPE (fntype);
12277 else if (DECL_MAIN_P (decl1))
12278 {
12279 /* If this doesn't return integer_type, complain. */
12280 if (TREE_TYPE (TREE_TYPE (decl1)) != integer_type_node)
12281 {
12282 if (pedantic || warn_return_type)
12283 pedwarn ("return type for `main' changed to `int'");
12284 TREE_TYPE (decl1) = fntype = default_function_type;
12285 }
12286 warn_about_return_type = 0;
12287 }
12288 }
12289
12290 /* Warn if function was previously implicitly declared
12291 (but not if we warned then). */
12292 if (! warn_implicit
12293 && IDENTIFIER_IMPLICIT_DECL (DECL_NAME (decl1)) != NULL_TREE)
12294 cp_warning_at ("`%D' implicitly declared before its definition", IDENTIFIER_IMPLICIT_DECL (DECL_NAME (decl1)));
12295
12296 current_function_decl = decl1;
12297 /* Save the parm names or decls from this function's declarator
12298 where store_parm_decls will find them. */
12299 current_function_parms = last_function_parms;
12300 current_function_parm_tags = last_function_parm_tags;
12301
12302 announce_function (decl1);
12303
12304 if (! processing_template_decl)
12305 {
12306 if (TYPE_SIZE (complete_type (TREE_TYPE (fntype))) == NULL_TREE)
12307 {
12308 cp_error ("return-type `%#T' is an incomplete type",
12309 TREE_TYPE (fntype));
12310
12311 /* Make it return void instead, but don't change the
12312 type of the DECL_RESULT, in case we have a named return value. */
12313 if (ctype)
12314 TREE_TYPE (decl1)
12315 = build_cplus_method_type (build_type_variant (ctype,
12316 TREE_READONLY (decl1),
12317 TREE_SIDE_EFFECTS (decl1)),
12318 void_type_node,
12319 FUNCTION_ARG_CHAIN (decl1));
12320 else
12321 TREE_TYPE (decl1)
12322 = build_function_type (void_type_node,
12323 TYPE_ARG_TYPES (TREE_TYPE (decl1)));
12324 DECL_RESULT (decl1)
12325 = build_decl (RESULT_DECL, 0, TYPE_MAIN_VARIANT (TREE_TYPE (fntype)));
12326 TREE_READONLY (DECL_RESULT (decl1)) = TYPE_READONLY (TREE_TYPE (fntype));
12327 TREE_THIS_VOLATILE (DECL_RESULT (decl1)) = TYPE_VOLATILE (TREE_TYPE (fntype));
12328 }
12329
12330 if (TYPE_LANG_SPECIFIC (TREE_TYPE (fntype))
12331 && CLASSTYPE_ABSTRACT_VIRTUALS (TREE_TYPE (fntype)))
12332 abstract_virtuals_error (decl1, TREE_TYPE (fntype));
12333 }
12334
12335 if (warn_about_return_type)
12336 pedwarn ("return-type defaults to `int'");
12337
12338 /* Effective C++ rule 15. See also c_expand_return. */
12339 if (warn_ecpp
12340 && DECL_NAME (decl1) == ansi_opname[(int) MODIFY_EXPR]
12341 && TREE_CODE (TREE_TYPE (fntype)) == VOID_TYPE)
12342 cp_warning ("`operator=' should return a reference to `*this'");
12343
12344 /* Make the init_value nonzero so pushdecl knows this is not tentative.
12345 error_mark_node is replaced below (in poplevel) with the BLOCK. */
12346 DECL_INITIAL (decl1) = error_mark_node;
12347
12348 /* This function exists in static storage.
12349 (This does not mean `static' in the C sense!) */
12350 TREE_STATIC (decl1) = 1;
12351
12352 /* Set up current_class_type, and enter the scope of the class, if
12353 appropriate. */
12354 if (ctype)
12355 push_nested_class (ctype, 1);
12356 else if (DECL_STATIC_FUNCTION_P (decl1))
12357 push_nested_class (DECL_CONTEXT (decl1), 2);
12358
12359 /* We must call push_template_decl after current_class_type is set
12360 up. (If we are processing inline definitions after exiting a
12361 class scope, current_class_type will be NULL_TREE until set above
12362 by push_nested_class.) */
12363 if (processing_template_decl)
12364 decl1 = push_template_decl (decl1);
12365
12366 /* Record the decl so that the function name is defined.
12367 If we already have a decl for this name, and it is a FUNCTION_DECL,
12368 use the old decl. */
12369 if (!processing_template_decl && pre_parsed_p == 0)
12370 {
12371 /* A specialization is not used to guide overload resolution. */
12372 if ((flag_guiding_decls
12373 || !DECL_TEMPLATE_SPECIALIZATION (decl1))
12374 && ! DECL_FUNCTION_MEMBER_P (decl1))
12375 decl1 = pushdecl (decl1);
12376 else
12377 {
12378 /* We need to set the DECL_CONTEXT. */
12379 if (!DECL_CONTEXT (decl1) && DECL_TEMPLATE_INFO (decl1))
12380 DECL_CONTEXT (decl1) = DECL_CONTEXT (DECL_TI_TEMPLATE (decl1));
12381 /* And make sure we have enough default args. */
12382 check_default_args (decl1);
12383 }
12384 DECL_MAIN_VARIANT (decl1) = decl1;
12385 fntype = TREE_TYPE (decl1);
12386 }
12387
12388 current_function_decl = decl1;
12389
12390 if (DECL_INTERFACE_KNOWN (decl1))
12391 {
12392 tree ctx = hack_decl_function_context (decl1);
12393
12394 if (DECL_NOT_REALLY_EXTERN (decl1))
12395 DECL_EXTERNAL (decl1) = 0;
12396
12397 if (ctx != NULL_TREE && DECL_THIS_INLINE (ctx)
12398 && TREE_PUBLIC (ctx))
12399 /* This is a function in a local class in an extern inline
12400 function. */
12401 comdat_linkage (decl1);
12402 }
12403 /* If this function belongs to an interface, it is public.
12404 If it belongs to someone else's interface, it is also external.
12405 It doesn't matter whether it's inline or not. */
12406 else if (interface_unknown == 0
12407 && (! DECL_TEMPLATE_INSTANTIATION (decl1)
12408 || flag_alt_external_templates))
12409 {
12410 if (DECL_THIS_INLINE (decl1) || DECL_TEMPLATE_INSTANTIATION (decl1)
12411 || processing_template_decl)
12412 DECL_EXTERNAL (decl1)
12413 = (interface_only
12414 || (DECL_THIS_INLINE (decl1) && ! flag_implement_inlines));
12415 else
12416 DECL_EXTERNAL (decl1) = 0;
12417 DECL_NOT_REALLY_EXTERN (decl1) = 0;
12418 DECL_INTERFACE_KNOWN (decl1) = 1;
12419 }
12420 else
12421 {
12422 /* This is a definition, not a reference.
12423 So clear DECL_EXTERNAL. */
12424 DECL_EXTERNAL (decl1) = 0;
12425
12426 if ((DECL_THIS_INLINE (decl1) || DECL_TEMPLATE_INSTANTIATION (decl1))
12427 && ! DECL_INTERFACE_KNOWN (decl1)
12428 /* Don't try to defer nested functions for now. */
12429 && ! hack_decl_function_context (decl1))
12430 DECL_DEFER_OUTPUT (decl1) = 1;
12431 else
12432 DECL_INTERFACE_KNOWN (decl1) = 1;
12433 }
12434
12435 if (ctype != NULL_TREE && DECL_STATIC_FUNCTION_P (decl1))
12436 {
12437 if (TREE_CODE (fntype) == METHOD_TYPE)
12438 TREE_TYPE (decl1) = fntype
12439 = build_function_type (TREE_TYPE (fntype),
12440 TREE_CHAIN (TYPE_ARG_TYPES (fntype)));
12441 current_function_parms = TREE_CHAIN (current_function_parms);
12442 DECL_ARGUMENTS (decl1) = current_function_parms;
12443 ctype = NULL_TREE;
12444 }
12445 restype = TREE_TYPE (fntype);
12446
12447 if (ctype)
12448 {
12449 /* If we're compiling a friend function, neither of the variables
12450 current_class_ptr nor current_class_type will have values. */
12451 if (! doing_friend)
12452 {
12453 /* We know that this was set up by `grokclassfn'.
12454 We do not wait until `store_parm_decls', since evil
12455 parse errors may never get us to that point. Here
12456 we keep the consistency between `current_class_type'
12457 and `current_class_ptr'. */
12458 tree t = current_function_parms;
12459
12460 my_friendly_assert (t != NULL_TREE
12461 && TREE_CODE (t) == PARM_DECL, 162);
12462
12463 if (TREE_CODE (TREE_TYPE (t)) == POINTER_TYPE)
12464 {
12465 int i = suspend_momentary ();
12466
12467 /* Fool build_indirect_ref. */
12468 current_class_ptr = NULL_TREE;
12469 current_class_ref = build_indirect_ref (t, NULL_PTR);
12470 current_class_ptr = t;
12471 resume_momentary (i);
12472 }
12473 else
12474 /* We're having a signature pointer here. */
12475 current_class_ref = current_class_ptr = t;
12476
12477 }
12478 }
12479 else
12480 {
12481 if (!DECL_STATIC_FUNCTION_P (decl1))
12482 push_memoized_context (NULL_TREE, 1);
12483 current_class_ptr = current_class_ref = NULL_TREE;
12484 }
12485
12486 pushlevel (0);
12487 current_binding_level->parm_flag = 1;
12488
12489 GNU_xref_function (decl1, current_function_parms);
12490
12491 if (attrs)
12492 cplus_decl_attributes (decl1, NULL_TREE, attrs);
12493 make_function_rtl (decl1);
12494
12495 /* Promote the value to int before returning it. */
12496 if (C_PROMOTING_INTEGER_TYPE_P (restype))
12497 restype = type_promotes_to (restype);
12498
12499 /* If this fcn was already referenced via a block-scope `extern' decl
12500 (or an implicit decl), propagate certain information about the usage. */
12501 if (TREE_ADDRESSABLE (DECL_ASSEMBLER_NAME (decl1)))
12502 TREE_ADDRESSABLE (decl1) = 1;
12503
12504 if (DECL_RESULT (decl1) == NULL_TREE)
12505 {
12506 DECL_RESULT (decl1)
12507 = build_decl (RESULT_DECL, 0, TYPE_MAIN_VARIANT (restype));
12508 TREE_READONLY (DECL_RESULT (decl1)) = TYPE_READONLY (restype);
12509 TREE_THIS_VOLATILE (DECL_RESULT (decl1)) = TYPE_VOLATILE (restype);
12510 }
12511
12512 /* Allocate further tree nodes temporarily during compilation
12513 of this function only. Tiemann moved up here from bottom of fn. */
12514 /* If this is a nested function, then we must continue to allocate RTL
12515 on the permanent obstack in case we need to inline it later. */
12516 if (! hack_decl_function_context (decl1))
12517 temporary_allocation ();
12518
12519 if (processing_template_decl)
12520 {
12521 ++minimal_parse_mode;
12522 last_tree = DECL_SAVED_TREE (decl1)
12523 = build_nt (EXPR_STMT, void_zero_node);
12524 }
12525
12526 ++function_depth;
12527
12528 if (DESTRUCTOR_NAME_P (DECL_ASSEMBLER_NAME (decl1))
12529 && DECL_LANGUAGE (decl1) == lang_cplusplus)
12530 {
12531 dtor_label = build_decl (LABEL_DECL, NULL_TREE, NULL_TREE);
12532 ctor_label = NULL_TREE;
12533 }
12534 else
12535 {
12536 dtor_label = NULL_TREE;
12537 if (DECL_CONSTRUCTOR_P (decl1))
12538 ctor_label = build_decl (LABEL_DECL, NULL_TREE, NULL_TREE);
12539 }
12540
12541 return 1;
12542 }
12543 \f
12544 /* Called after store_parm_decls for a function-try-block. We need to update
12545 last_parm_cleanup_insn so that the base initializers for a constructor
12546 are run within this block, not before it. */
12547
12548 void
12549 expand_start_early_try_stmts ()
12550 {
12551 expand_start_try_stmts ();
12552 last_parm_cleanup_insn = get_last_insn ();
12553 }
12554
12555 /* Store the parameter declarations into the current function declaration.
12556 This is called after parsing the parameter declarations, before
12557 digesting the body of the function.
12558
12559 Also install to binding contour return value identifier, if any. */
12560
12561 void
12562 store_parm_decls ()
12563 {
12564 register tree fndecl = current_function_decl;
12565 register tree parm;
12566 int parms_have_cleanups = 0;
12567 tree cleanups = NULL_TREE;
12568
12569 /* This is either a chain of PARM_DECLs (when a prototype is used). */
12570 tree specparms = current_function_parms;
12571
12572 /* This is a list of types declared among parms in a prototype. */
12573 tree parmtags = current_function_parm_tags;
12574
12575 /* This is a chain of any other decls that came in among the parm
12576 declarations. If a parm is declared with enum {foo, bar} x;
12577 then CONST_DECLs for foo and bar are put here. */
12578 tree nonparms = NULL_TREE;
12579
12580 if (toplevel_bindings_p ())
12581 fatal ("parse errors have confused me too much");
12582
12583 /* Initialize RTL machinery. */
12584 init_function_start (fndecl, input_filename, lineno);
12585
12586 /* Declare __FUNCTION__ and __PRETTY_FUNCTION__ for this function. */
12587 declare_function_name ();
12588
12589 /* Create a binding level for the parms. */
12590 expand_start_bindings (0);
12591
12592 if (specparms != NULL_TREE)
12593 {
12594 /* This case is when the function was defined with an ANSI prototype.
12595 The parms already have decls, so we need not do anything here
12596 except record them as in effect
12597 and complain if any redundant old-style parm decls were written. */
12598
12599 register tree next;
12600
12601 /* Must clear this because it might contain TYPE_DECLs declared
12602 at class level. */
12603 storedecls (NULL_TREE);
12604
12605 for (parm = nreverse (specparms); parm; parm = next)
12606 {
12607 next = TREE_CHAIN (parm);
12608 if (TREE_CODE (parm) == PARM_DECL)
12609 {
12610 tree cleanup;
12611 if (DECL_NAME (parm) == NULL_TREE)
12612 {
12613 pushdecl (parm);
12614 }
12615 else if (TREE_CODE (TREE_TYPE (parm)) == VOID_TYPE)
12616 cp_error ("parameter `%D' declared void", parm);
12617 else
12618 {
12619 /* Now fill in DECL_REFERENCE_SLOT for any of the parm decls.
12620 A parameter is assumed not to have any side effects.
12621 If this should change for any reason, then this
12622 will have to wrap the bashed reference type in a save_expr.
12623
12624 Also, if the parameter type is declared to be an X
12625 and there is an X(X&) constructor, we cannot lay it
12626 into the stack (any more), so we make this parameter
12627 look like it is really of reference type. Functions
12628 which pass parameters to this function will know to
12629 create a temporary in their frame, and pass a reference
12630 to that. */
12631
12632 if (TREE_CODE (TREE_TYPE (parm)) == REFERENCE_TYPE
12633 && TYPE_SIZE (TREE_TYPE (TREE_TYPE (parm))))
12634 SET_DECL_REFERENCE_SLOT (parm, convert_from_reference (parm));
12635
12636 pushdecl (parm);
12637 }
12638 if (! processing_template_decl
12639 && (cleanup = maybe_build_cleanup (parm), cleanup))
12640 {
12641 expand_decl (parm);
12642 parms_have_cleanups = 1;
12643
12644 /* Keep track of the cleanups. */
12645 cleanups = tree_cons (parm, cleanup, cleanups);
12646 }
12647 }
12648 else
12649 {
12650 /* If we find an enum constant or a type tag,
12651 put it aside for the moment. */
12652 TREE_CHAIN (parm) = NULL_TREE;
12653 nonparms = chainon (nonparms, parm);
12654 }
12655 }
12656
12657 /* Get the decls in their original chain order
12658 and record in the function. This is all and only the
12659 PARM_DECLs that were pushed into scope by the loop above. */
12660 DECL_ARGUMENTS (fndecl) = getdecls ();
12661
12662 storetags (chainon (parmtags, gettags ()));
12663 }
12664 else
12665 DECL_ARGUMENTS (fndecl) = NULL_TREE;
12666
12667 /* Now store the final chain of decls for the arguments
12668 as the decl-chain of the current lexical scope.
12669 Put the enumerators in as well, at the front so that
12670 DECL_ARGUMENTS is not modified. */
12671
12672 storedecls (chainon (nonparms, DECL_ARGUMENTS (fndecl)));
12673
12674 /* Initialize the RTL code for the function. */
12675 DECL_SAVED_INSNS (fndecl) = NULL_RTX;
12676 if (! processing_template_decl)
12677 expand_function_start (fndecl, parms_have_cleanups);
12678
12679 current_function_parms_stored = 1;
12680
12681 /* If this function is `main', emit a call to `__main'
12682 to run global initializers, etc. */
12683 if (DECL_MAIN_P (fndecl))
12684 expand_main_function ();
12685
12686 /* Now that we have initialized the parms, we can start their
12687 cleanups. We cannot do this before, since expand_decl_cleanup
12688 should not be called before the parm can be used. */
12689 if (cleanups
12690 && ! processing_template_decl)
12691 {
12692 for (cleanups = nreverse (cleanups); cleanups; cleanups = TREE_CHAIN (cleanups))
12693 {
12694 if (! expand_decl_cleanup (TREE_PURPOSE (cleanups), TREE_VALUE (cleanups)))
12695 cp_error ("parser lost in parsing declaration of `%D'",
12696 TREE_PURPOSE (cleanups));
12697 }
12698 }
12699
12700 /* Create a binding contour which can be used to catch
12701 cleanup-generated temporaries. Also, if the return value needs or
12702 has initialization, deal with that now. */
12703 if (parms_have_cleanups)
12704 {
12705 pushlevel (0);
12706 expand_start_bindings (0);
12707 }
12708
12709 if (! processing_template_decl && flag_exceptions)
12710 {
12711 /* Do the starting of the exception specifications, if we have any. */
12712 if (TYPE_RAISES_EXCEPTIONS (TREE_TYPE (current_function_decl)))
12713 expand_start_eh_spec ();
12714 }
12715
12716 last_parm_cleanup_insn = get_last_insn ();
12717 last_dtor_insn = get_last_insn ();
12718 }
12719
12720 /* Bind a name and initialization to the return value of
12721 the current function. */
12722
12723 void
12724 store_return_init (return_id, init)
12725 tree return_id, init;
12726 {
12727 tree decl = DECL_RESULT (current_function_decl);
12728
12729 if (pedantic)
12730 /* Give this error as many times as there are occurrences,
12731 so that users can use Emacs compilation buffers to find
12732 and fix all such places. */
12733 pedwarn ("ANSI C++ does not permit named return values");
12734
12735 if (return_id != NULL_TREE)
12736 {
12737 if (DECL_NAME (decl) == NULL_TREE)
12738 {
12739 DECL_NAME (decl) = return_id;
12740 DECL_ASSEMBLER_NAME (decl) = return_id;
12741 }
12742 else
12743 cp_error ("return identifier `%D' already in place", decl);
12744 }
12745
12746 /* Can't let this happen for constructors. */
12747 if (DECL_CONSTRUCTOR_P (current_function_decl))
12748 {
12749 error ("can't redefine default return value for constructors");
12750 return;
12751 }
12752
12753 /* If we have a named return value, put that in our scope as well. */
12754 if (DECL_NAME (decl) != NULL_TREE)
12755 {
12756 /* If this named return value comes in a register,
12757 put it in a pseudo-register. */
12758 if (DECL_REGISTER (decl))
12759 {
12760 original_result_rtx = DECL_RTL (decl);
12761 DECL_RTL (decl) = gen_reg_rtx (DECL_MODE (decl));
12762 }
12763
12764 /* Let `cp_finish_decl' know that this initializer is ok. */
12765 DECL_INITIAL (decl) = init;
12766 pushdecl (decl);
12767
12768 if (minimal_parse_mode)
12769 add_tree (build_min_nt (RETURN_INIT, return_id,
12770 copy_to_permanent (init)));
12771 else
12772 cp_finish_decl (decl, init, NULL_TREE, 0, 0);
12773 }
12774 }
12775
12776 \f
12777 /* Finish up a function declaration and compile that function
12778 all the way to assembler language output. The free the storage
12779 for the function definition.
12780
12781 This is called after parsing the body of the function definition.
12782 LINENO is the current line number.
12783
12784 C++: CALL_POPLEVEL is non-zero if an extra call to poplevel
12785 (and expand_end_bindings) must be made to take care of the binding
12786 contour for the base initializers. This is only relevant for
12787 constructors.
12788
12789 NESTED is nonzero if we were in the middle of compiling another function
12790 when we started on this one. */
12791
12792 void
12793 finish_function (lineno, call_poplevel, nested)
12794 int lineno;
12795 int call_poplevel;
12796 int nested;
12797 {
12798 register tree fndecl = current_function_decl;
12799 tree fntype, ctype = NULL_TREE;
12800 rtx last_parm_insn, insns;
12801 /* Label to use if this function is supposed to return a value. */
12802 tree no_return_label = NULL_TREE;
12803 tree decls = NULL_TREE;
12804
12805 /* When we get some parse errors, we can end up without a
12806 current_function_decl, so cope. */
12807 if (fndecl == NULL_TREE)
12808 return;
12809
12810 if (! nested && function_depth > 1)
12811 nested = 1;
12812
12813 fntype = TREE_TYPE (fndecl);
12814
12815 /* TREE_READONLY (fndecl) = 1;
12816 This caused &foo to be of type ptr-to-const-function
12817 which then got a warning when stored in a ptr-to-function variable. */
12818
12819 /* This happens on strange parse errors. */
12820 if (! current_function_parms_stored)
12821 {
12822 call_poplevel = 0;
12823 store_parm_decls ();
12824 }
12825
12826 if (processing_template_decl)
12827 {
12828 if (DECL_CONSTRUCTOR_P (fndecl) && call_poplevel)
12829 {
12830 decls = getdecls ();
12831 expand_end_bindings (decls, decls != NULL_TREE, 0);
12832 poplevel (decls != NULL_TREE, 0, 0);
12833 }
12834 }
12835 else
12836 {
12837 if (write_symbols != NO_DEBUG /*&& TREE_CODE (fntype) != METHOD_TYPE*/)
12838 {
12839 tree ttype = target_type (fntype);
12840 tree parmdecl;
12841
12842 if (IS_AGGR_TYPE (ttype))
12843 /* Let debugger know it should output info for this type. */
12844 note_debug_info_needed (ttype);
12845
12846 for (parmdecl = DECL_ARGUMENTS (fndecl); parmdecl; parmdecl = TREE_CHAIN (parmdecl))
12847 {
12848 ttype = target_type (TREE_TYPE (parmdecl));
12849 if (IS_AGGR_TYPE (ttype))
12850 /* Let debugger know it should output info for this type. */
12851 note_debug_info_needed (ttype);
12852 }
12853 }
12854
12855 /* Clean house because we will need to reorder insns here. */
12856 do_pending_stack_adjust ();
12857
12858 if (dtor_label)
12859 {
12860 tree binfo = TYPE_BINFO (current_class_type);
12861 tree cond = integer_one_node;
12862 tree exprstmt;
12863 tree in_charge_node = lookup_name (in_charge_identifier, 0);
12864 tree virtual_size;
12865 int ok_to_optimize_dtor = 0;
12866 int empty_dtor = get_last_insn () == last_dtor_insn;
12867
12868 if (current_function_assigns_this)
12869 cond = build (NE_EXPR, boolean_type_node,
12870 current_class_ptr, integer_zero_node);
12871 else
12872 {
12873 int n_baseclasses = CLASSTYPE_N_BASECLASSES (current_class_type);
12874
12875 /* If this destructor is empty, then we don't need to check
12876 whether `this' is NULL in some cases. */
12877 if ((flag_this_is_variable & 1) == 0)
12878 ok_to_optimize_dtor = 1;
12879 else if (empty_dtor)
12880 ok_to_optimize_dtor
12881 = (n_baseclasses == 0
12882 || (n_baseclasses == 1
12883 && TYPE_HAS_DESTRUCTOR (TYPE_BINFO_BASETYPE (current_class_type, 0))));
12884 }
12885
12886 /* These initializations might go inline. Protect
12887 the binding level of the parms. */
12888 pushlevel (0);
12889 expand_start_bindings (0);
12890
12891 if (current_function_assigns_this)
12892 {
12893 current_function_assigns_this = 0;
12894 current_function_just_assigned_this = 0;
12895 }
12896
12897 /* Generate the code to call destructor on base class.
12898 If this destructor belongs to a class with virtual
12899 functions, then set the virtual function table
12900 pointer to represent the type of our base class. */
12901
12902 /* This side-effect makes call to `build_delete' generate the
12903 code we have to have at the end of this destructor. */
12904 TYPE_HAS_DESTRUCTOR (current_class_type) = 0;
12905
12906 /* These are two cases where we cannot delegate deletion. */
12907 if (TYPE_USES_VIRTUAL_BASECLASSES (current_class_type)
12908 || TYPE_GETS_REG_DELETE (current_class_type))
12909 exprstmt = build_delete (current_class_type, current_class_ref, integer_zero_node,
12910 LOOKUP_NONVIRTUAL|LOOKUP_DESTRUCTOR|LOOKUP_NORMAL, 0);
12911 else
12912 exprstmt = build_delete (current_class_type, current_class_ref, in_charge_node,
12913 LOOKUP_NONVIRTUAL|LOOKUP_DESTRUCTOR|LOOKUP_NORMAL, 0);
12914
12915 /* If we did not assign to this, then `this' is non-zero at
12916 the end of a destructor. As a special optimization, don't
12917 emit test if this is an empty destructor. If it does nothing,
12918 it does nothing. If it calls a base destructor, the base
12919 destructor will perform the test. */
12920
12921 if (exprstmt != error_mark_node
12922 && (TREE_CODE (exprstmt) != NOP_EXPR
12923 || TREE_OPERAND (exprstmt, 0) != integer_zero_node
12924 || TYPE_USES_VIRTUAL_BASECLASSES (current_class_type)))
12925 {
12926 expand_label (dtor_label);
12927 if (cond != integer_one_node)
12928 expand_start_cond (cond, 0);
12929 if (exprstmt != void_zero_node)
12930 /* Don't call `expand_expr_stmt' if we're not going to do
12931 anything, since -Wall will give a diagnostic. */
12932 expand_expr_stmt (exprstmt);
12933
12934 /* Run destructor on all virtual baseclasses. */
12935 if (TYPE_USES_VIRTUAL_BASECLASSES (current_class_type))
12936 {
12937 tree vbases = nreverse (copy_list (CLASSTYPE_VBASECLASSES (current_class_type)));
12938 expand_start_cond (build (BIT_AND_EXPR, integer_type_node,
12939 in_charge_node, integer_two_node), 0);
12940 while (vbases)
12941 {
12942 if (TYPE_NEEDS_DESTRUCTOR (BINFO_TYPE (vbases)))
12943 {
12944 tree vb = get_vbase
12945 (BINFO_TYPE (vbases),
12946 TYPE_BINFO (current_class_type));
12947 expand_expr_stmt
12948 (build_scoped_method_call
12949 (current_class_ref, vb, dtor_identifier,
12950 build_expr_list (NULL_TREE, integer_zero_node)));
12951 }
12952 vbases = TREE_CHAIN (vbases);
12953 }
12954 expand_end_cond ();
12955 }
12956
12957 do_pending_stack_adjust ();
12958 if (cond != integer_one_node)
12959 expand_end_cond ();
12960 }
12961
12962 TYPE_HAS_DESTRUCTOR (current_class_type) = 1;
12963
12964 virtual_size = c_sizeof (current_class_type);
12965
12966 /* At the end, call delete if that's what's requested. */
12967
12968 /* FDIS sez: At the point of definition of a virtual destructor
12969 (including an implicit definition), non-placement operator
12970 delete shall be looked up in the scope of the destructor's
12971 class and if found shall be accessible and unambiguous.
12972
12973 This is somewhat unclear, but I take it to mean that if the
12974 class only defines placement deletes we don't do anything here.
12975 So we pass LOOKUP_SPECULATIVELY; delete_sanity will complain
12976 for us if they ever try to delete one of these. */
12977
12978 if (TYPE_GETS_REG_DELETE (current_class_type)
12979 || TYPE_USES_VIRTUAL_BASECLASSES (current_class_type))
12980 exprstmt = build_op_delete_call
12981 (DELETE_EXPR, current_class_ptr, virtual_size,
12982 LOOKUP_NORMAL | LOOKUP_SPECULATIVELY, NULL_TREE);
12983 else
12984 exprstmt = NULL_TREE;
12985
12986 if (exprstmt)
12987 {
12988 cond = build (BIT_AND_EXPR, integer_type_node,
12989 in_charge_node, integer_one_node);
12990 expand_start_cond (cond, 0);
12991 expand_expr_stmt (exprstmt);
12992 expand_end_cond ();
12993 }
12994
12995 /* End of destructor. */
12996 expand_end_bindings (NULL_TREE, getdecls () != NULL_TREE, 0);
12997 poplevel (2, 0, 0); /* XXX change to 1 */
12998
12999 /* Back to the top of destructor. */
13000 /* Don't execute destructor code if `this' is NULL. */
13001
13002 start_sequence ();
13003
13004 /* If the dtor is empty, and we know there is not possible way we
13005 could use any vtable entries, before they are possibly set by
13006 a base class dtor, we don't have to setup the vtables, as we
13007 know that any base class dtoring will set up any vtables it
13008 needs. We avoid MI, because one base class dtor can do a
13009 virtual dispatch to an overridden function that would need to
13010 have a non-related vtable set up, we cannot avoid setting up
13011 vtables in that case. We could change this to see if there is
13012 just one vtable. */
13013 if (! empty_dtor || TYPE_USES_COMPLEX_INHERITANCE (current_class_type))
13014 {
13015 /* Make all virtual function table pointers in non-virtual base
13016 classes point to CURRENT_CLASS_TYPE's virtual function
13017 tables. */
13018 expand_direct_vtbls_init (binfo, binfo, 1, 0, current_class_ptr);
13019
13020 if (TYPE_USES_VIRTUAL_BASECLASSES (current_class_type))
13021 expand_indirect_vtbls_init (binfo, current_class_ref, current_class_ptr);
13022 }
13023
13024 if (! ok_to_optimize_dtor)
13025 {
13026 cond = build_binary_op (NE_EXPR,
13027 current_class_ptr, integer_zero_node, 1);
13028 expand_start_cond (cond, 0);
13029 }
13030
13031 insns = get_insns ();
13032 end_sequence ();
13033
13034 last_parm_insn = get_first_nonparm_insn ();
13035 if (last_parm_insn == NULL_RTX)
13036 last_parm_insn = get_last_insn ();
13037 else
13038 last_parm_insn = previous_insn (last_parm_insn);
13039
13040 emit_insns_after (insns, last_parm_insn);
13041
13042 if (! ok_to_optimize_dtor)
13043 expand_end_cond ();
13044 }
13045 else if (current_function_assigns_this)
13046 {
13047 /* Does not need to call emit_base_init, because
13048 that is done (if needed) just after assignment to this
13049 is seen. */
13050
13051 if (DECL_CONSTRUCTOR_P (current_function_decl))
13052 {
13053 end_protect_partials ();
13054 expand_label (ctor_label);
13055 ctor_label = NULL_TREE;
13056
13057 if (call_poplevel)
13058 {
13059 decls = getdecls ();
13060 expand_end_bindings (decls, decls != NULL_TREE, 0);
13061 poplevel (decls != NULL_TREE, 0, 0);
13062 }
13063 /* c_expand_return knows to return 'this' from a constructor. */
13064 c_expand_return (NULL_TREE);
13065 }
13066 else if (TREE_CODE (TREE_TYPE (DECL_RESULT (current_function_decl))) != VOID_TYPE
13067 && return_label != NULL_RTX)
13068 no_return_label = build_decl (LABEL_DECL, NULL_TREE, NULL_TREE);
13069
13070 current_function_assigns_this = 0;
13071 current_function_just_assigned_this = 0;
13072 base_init_expr = NULL_TREE;
13073 }
13074 else if (DECL_CONSTRUCTOR_P (fndecl))
13075 {
13076 tree cond = NULL_TREE, thenclause = NULL_TREE;
13077 /* Allow constructor for a type to get a new instance of the object
13078 using `build_new'. */
13079 tree abstract_virtuals = CLASSTYPE_ABSTRACT_VIRTUALS (current_class_type);
13080 CLASSTYPE_ABSTRACT_VIRTUALS (current_class_type) = NULL_TREE;
13081
13082 DECL_RETURNS_FIRST_ARG (fndecl) = 1;
13083
13084 if (flag_this_is_variable > 0)
13085 {
13086 cond = build_binary_op (EQ_EXPR,
13087 current_class_ptr, integer_zero_node, 1);
13088 thenclause = build_modify_expr (current_class_ptr, NOP_EXPR,
13089 build_new (NULL_TREE, current_class_type, void_type_node, 0));
13090 }
13091
13092 CLASSTYPE_ABSTRACT_VIRTUALS (current_class_type) = abstract_virtuals;
13093
13094 start_sequence ();
13095
13096 if (flag_this_is_variable > 0)
13097 {
13098 expand_start_cond (cond, 0);
13099 expand_expr_stmt (thenclause);
13100 expand_end_cond ();
13101 }
13102
13103 /* Emit insns from `emit_base_init' which sets up virtual
13104 function table pointer(s). */
13105 if (base_init_expr)
13106 {
13107 expand_expr_stmt (base_init_expr);
13108 base_init_expr = NULL_TREE;
13109 }
13110
13111 insns = get_insns ();
13112 end_sequence ();
13113
13114 /* This is where the body of the constructor begins. */
13115
13116 emit_insns_after (insns, last_parm_cleanup_insn);
13117
13118 end_protect_partials ();
13119
13120 /* This is where the body of the constructor ends. */
13121 expand_label (ctor_label);
13122 ctor_label = NULL_TREE;
13123
13124 if (call_poplevel)
13125 {
13126 decls = getdecls ();
13127 expand_end_bindings (decls, decls != NULL_TREE, 0);
13128 poplevel (decls != NULL_TREE, 1, 0);
13129 }
13130
13131 /* c_expand_return knows to return 'this' from a constructor. */
13132 c_expand_return (NULL_TREE);
13133
13134 current_function_assigns_this = 0;
13135 current_function_just_assigned_this = 0;
13136 }
13137 else if (DECL_MAIN_P (fndecl))
13138 {
13139 /* Make it so that `main' always returns 0 by default. */
13140 #ifdef VMS
13141 c_expand_return (integer_one_node);
13142 #else
13143 c_expand_return (integer_zero_node);
13144 #endif
13145 }
13146 else if (return_label != NULL_RTX
13147 && current_function_return_value == NULL_TREE
13148 && ! DECL_NAME (DECL_RESULT (current_function_decl)))
13149 no_return_label = build_decl (LABEL_DECL, NULL_TREE, NULL_TREE);
13150
13151 if (flag_exceptions)
13152 expand_exception_blocks ();
13153
13154 /* If this function is supposed to return a value, ensure that
13155 we do not fall into the cleanups by mistake. The end of our
13156 function will look like this:
13157
13158 user code (may have return stmt somewhere)
13159 goto no_return_label
13160 cleanup_label:
13161 cleanups
13162 goto return_label
13163 no_return_label:
13164 NOTE_INSN_FUNCTION_END
13165 return_label:
13166 things for return
13167
13168 If the user omits a return stmt in the USER CODE section, we
13169 will have a control path which reaches NOTE_INSN_FUNCTION_END.
13170 Otherwise, we won't. */
13171 if (no_return_label)
13172 {
13173 DECL_CONTEXT (no_return_label) = fndecl;
13174 DECL_INITIAL (no_return_label) = error_mark_node;
13175 DECL_SOURCE_FILE (no_return_label) = input_filename;
13176 DECL_SOURCE_LINE (no_return_label) = lineno;
13177 expand_goto (no_return_label);
13178 }
13179
13180 if (cleanup_label)
13181 {
13182 /* Remove the binding contour which is used
13183 to catch cleanup-generated temporaries. */
13184 expand_end_bindings (0, 0, 0);
13185 poplevel (0, 0, 0);
13186
13187 /* Emit label at beginning of cleanup code for parameters. */
13188 emit_label (cleanup_label);
13189 }
13190
13191 /* Get return value into register if that's where it's supposed to be. */
13192 if (original_result_rtx)
13193 fixup_result_decl (DECL_RESULT (fndecl), original_result_rtx);
13194
13195 /* Finish building code that will trigger warnings if users forget
13196 to make their functions return values. */
13197 if (no_return_label || cleanup_label)
13198 emit_jump (return_label);
13199 if (no_return_label)
13200 {
13201 /* We don't need to call `expand_*_return' here because we
13202 don't need any cleanups here--this path of code is only
13203 for error checking purposes. */
13204 expand_label (no_return_label);
13205 }
13206
13207 /* Generate rtl for function exit. */
13208 expand_function_end (input_filename, lineno, 1);
13209 }
13210
13211 /* This must come after expand_function_end because cleanups might
13212 have declarations (from inline functions) that need to go into
13213 this function's blocks. */
13214 if (current_binding_level->parm_flag != 1)
13215 my_friendly_abort (122);
13216 poplevel (1, 0, 1);
13217
13218 /* Reset scope for C++: if we were in the scope of a class,
13219 then when we finish this function, we are not longer so.
13220 This cannot be done until we know for sure that no more
13221 class members will ever be referenced in this function
13222 (i.e., calls to destructors). */
13223 if (current_class_name)
13224 {
13225 ctype = current_class_type;
13226 pop_nested_class (1);
13227 }
13228 else
13229 pop_memoized_context (1);
13230
13231 /* Must mark the RESULT_DECL as being in this function. */
13232 DECL_CONTEXT (DECL_RESULT (fndecl)) = fndecl;
13233
13234 /* Set the BLOCK_SUPERCONTEXT of the outermost function scope to point
13235 to the FUNCTION_DECL node itself. */
13236 BLOCK_SUPERCONTEXT (DECL_INITIAL (fndecl)) = fndecl;
13237
13238 if (! processing_template_decl)
13239 {
13240 int saved_flag_keep_inline_functions =
13241 flag_keep_inline_functions;
13242
13243 /* So we can tell if jump_optimize sets it to 1. */
13244 can_reach_end = 0;
13245
13246 if (DECL_CONTEXT (fndecl) != NULL_TREE
13247 && hack_decl_function_context (fndecl))
13248 /* Trick rest_of_compilation into not deferring output of this
13249 function, even if it is inline, since the rtl_obstack for
13250 this function is the function_obstack of the enclosing
13251 function and will be deallocated when the enclosing
13252 function is gone. See save_tree_status. */
13253 flag_keep_inline_functions = 1;
13254
13255 /* Run the optimizers and output the assembler code for this
13256 function. */
13257
13258 if (DECL_ARTIFICIAL (fndecl))
13259 {
13260 /* Do we really *want* to inline this synthesized method? */
13261
13262 int save_fif = flag_inline_functions;
13263 flag_inline_functions = 1;
13264
13265 /* Turn off DECL_INLINE for the moment so function_cannot_inline_p
13266 will check our size. */
13267 DECL_INLINE (fndecl) = 0;
13268
13269 rest_of_compilation (fndecl);
13270 flag_inline_functions = save_fif;
13271 }
13272 else
13273 rest_of_compilation (fndecl);
13274
13275 flag_keep_inline_functions = saved_flag_keep_inline_functions;
13276
13277 if (DECL_SAVED_INSNS (fndecl) && ! TREE_ASM_WRITTEN (fndecl))
13278 {
13279 /* Set DECL_EXTERNAL so that assemble_external will be called as
13280 necessary. We'll clear it again in finish_file. */
13281 if (! DECL_EXTERNAL (fndecl))
13282 DECL_NOT_REALLY_EXTERN (fndecl) = 1;
13283 DECL_EXTERNAL (fndecl) = 1;
13284 mark_inline_for_output (fndecl);
13285 }
13286
13287 if (ctype && TREE_ASM_WRITTEN (fndecl))
13288 note_debug_info_needed (ctype);
13289
13290 current_function_returns_null |= can_reach_end;
13291
13292 /* Since we don't normally go through c_expand_return for constructors,
13293 this normally gets the wrong value.
13294 Also, named return values have their return codes emitted after
13295 NOTE_INSN_FUNCTION_END, confusing jump.c. */
13296 if (DECL_CONSTRUCTOR_P (fndecl)
13297 || DECL_NAME (DECL_RESULT (fndecl)) != NULL_TREE)
13298 current_function_returns_null = 0;
13299
13300 if (TREE_THIS_VOLATILE (fndecl) && current_function_returns_null)
13301 cp_warning ("`noreturn' function `%D' does return", fndecl);
13302 else if ((warn_return_type || pedantic)
13303 && current_function_returns_null
13304 && TREE_CODE (TREE_TYPE (fntype)) != VOID_TYPE)
13305 {
13306 /* If this function returns non-void and control can drop through,
13307 complain. */
13308 cp_warning ("control reaches end of non-void function `%D'", fndecl);
13309 }
13310 /* With just -W, complain only if function returns both with
13311 and without a value. */
13312 else if (extra_warnings
13313 && current_function_returns_value && current_function_returns_null)
13314 warning ("this function may return with or without a value");
13315 }
13316
13317 --function_depth;
13318
13319 /* Free all the tree nodes making up this function. */
13320 /* Switch back to allocating nodes permanently
13321 until we start another function. */
13322 if (processing_template_decl)
13323 {
13324 --minimal_parse_mode;
13325 DECL_SAVED_TREE (fndecl) = TREE_CHAIN (DECL_SAVED_TREE (fndecl));
13326 }
13327
13328 if (! nested)
13329 permanent_allocation (1);
13330
13331 if (DECL_SAVED_INSNS (fndecl) == NULL_RTX)
13332 {
13333 tree t;
13334
13335 /* Stop pointing to the local nodes about to be freed. */
13336 /* But DECL_INITIAL must remain nonzero so we know this
13337 was an actual function definition. */
13338 DECL_INITIAL (fndecl) = error_mark_node;
13339 for (t = DECL_ARGUMENTS (fndecl); t; t = TREE_CHAIN (t))
13340 DECL_RTL (t) = DECL_INCOMING_RTL (t) = NULL_RTX;
13341 }
13342
13343 if (DECL_STATIC_CONSTRUCTOR (fndecl))
13344 static_ctors = perm_tree_cons (NULL_TREE, fndecl, static_ctors);
13345 if (DECL_STATIC_DESTRUCTOR (fndecl))
13346 static_dtors = perm_tree_cons (NULL_TREE, fndecl, static_dtors);
13347
13348 if (! nested)
13349 {
13350 /* Let the error reporting routines know that we're outside a
13351 function. For a nested function, this value is used in
13352 pop_cp_function_context and then reset via pop_function_context. */
13353 current_function_decl = NULL_TREE;
13354 }
13355
13356 named_label_uses = NULL;
13357 current_class_ptr = NULL_TREE;
13358 current_class_ref = NULL_TREE;
13359 }
13360 \f
13361 /* Create the FUNCTION_DECL for a function definition.
13362 LINE1 is the line number that the definition absolutely begins on.
13363 LINE2 is the line number that the name of the function appears on.
13364 DECLSPECS and DECLARATOR are the parts of the declaration;
13365 they describe the return type and the name of the function,
13366 but twisted together in a fashion that parallels the syntax of C.
13367
13368 This function creates a binding context for the function body
13369 as well as setting up the FUNCTION_DECL in current_function_decl.
13370
13371 Returns a FUNCTION_DECL on success.
13372
13373 If the DECLARATOR is not suitable for a function (it defines a datum
13374 instead), we return 0, which tells yyparse to report a parse error.
13375
13376 May return void_type_node indicating that this method is actually
13377 a friend. See grokfield for more details.
13378
13379 Came here with a `.pushlevel' .
13380
13381 DO NOT MAKE ANY CHANGES TO THIS CODE WITHOUT MAKING CORRESPONDING
13382 CHANGES TO CODE IN `grokfield'. */
13383
13384 tree
13385 start_method (declspecs, declarator)
13386 tree declarator, declspecs;
13387 {
13388 tree fndecl = grokdeclarator (declarator, declspecs, MEMFUNCDEF, 0,
13389 NULL_TREE);
13390
13391 /* Something too ugly to handle. */
13392 if (fndecl == NULL_TREE)
13393 return NULL_TREE;
13394
13395 /* Pass friends other than inline friend functions back. */
13396 if (fndecl == void_type_node)
13397 return fndecl;
13398
13399 if (TREE_CODE (fndecl) != FUNCTION_DECL)
13400 /* Not a function, tell parser to report parse error. */
13401 return NULL_TREE;
13402
13403 if (IS_SIGNATURE (current_class_type))
13404 IS_DEFAULT_IMPLEMENTATION (fndecl) = 1;
13405
13406 if (DECL_IN_AGGR_P (fndecl))
13407 {
13408 if (IDENTIFIER_ERROR_LOCUS (DECL_ASSEMBLER_NAME (fndecl)) != current_class_type)
13409 {
13410 if (DECL_CONTEXT (fndecl)
13411 && TREE_CODE( DECL_CONTEXT (fndecl)) != NAMESPACE_DECL)
13412 cp_error ("`%D' is already defined in class %s", fndecl,
13413 TYPE_NAME_STRING (DECL_CONTEXT (fndecl)));
13414 }
13415 return void_type_node;
13416 }
13417
13418 DECL_THIS_INLINE (fndecl) = 1;
13419
13420 if (flag_default_inline)
13421 DECL_INLINE (fndecl) = 1;
13422
13423 /* We process method specializations in finish_struct_1. */
13424 if (processing_template_decl && !DECL_TEMPLATE_SPECIALIZATION (fndecl))
13425 fndecl = push_template_decl (fndecl);
13426
13427 /* We read in the parameters on the maybepermanent_obstack,
13428 but we won't be getting back to them until after we
13429 may have clobbered them. So the call to preserve_data
13430 will keep them safe. */
13431 preserve_data ();
13432
13433 if (! DECL_FRIEND_P (fndecl))
13434 {
13435 if (TREE_CHAIN (fndecl))
13436 {
13437 fndecl = copy_node (fndecl);
13438 TREE_CHAIN (fndecl) = NULL_TREE;
13439 }
13440
13441 if (DECL_CONSTRUCTOR_P (fndecl))
13442 {
13443 if (! grok_ctor_properties (current_class_type, fndecl))
13444 return void_type_node;
13445 }
13446 else if (IDENTIFIER_OPNAME_P (DECL_NAME (fndecl)))
13447 grok_op_properties (fndecl, DECL_VIRTUAL_P (fndecl), 0);
13448 }
13449
13450 cp_finish_decl (fndecl, NULL_TREE, NULL_TREE, 0, 0);
13451
13452 /* Make a place for the parms */
13453 pushlevel (0);
13454 current_binding_level->parm_flag = 1;
13455
13456 DECL_IN_AGGR_P (fndecl) = 1;
13457 return fndecl;
13458 }
13459
13460 /* Go through the motions of finishing a function definition.
13461 We don't compile this method until after the whole class has
13462 been processed.
13463
13464 FINISH_METHOD must return something that looks as though it
13465 came from GROKFIELD (since we are defining a method, after all).
13466
13467 This is called after parsing the body of the function definition.
13468 STMTS is the chain of statements that makes up the function body.
13469
13470 DECL is the ..._DECL that `start_method' provided. */
13471
13472 tree
13473 finish_method (decl)
13474 tree decl;
13475 {
13476 register tree fndecl = decl;
13477 tree old_initial;
13478
13479 register tree link;
13480
13481 if (decl == void_type_node)
13482 return decl;
13483
13484 old_initial = DECL_INITIAL (fndecl);
13485
13486 /* Undo the level for the parms (from start_method).
13487 This is like poplevel, but it causes nothing to be
13488 saved. Saving information here confuses symbol-table
13489 output routines. Besides, this information will
13490 be correctly output when this method is actually
13491 compiled. */
13492
13493 /* Clear out the meanings of the local variables of this level;
13494 also record in each decl which block it belongs to. */
13495
13496 for (link = current_binding_level->names; link; link = TREE_CHAIN (link))
13497 {
13498 if (DECL_NAME (link) != NULL_TREE)
13499 IDENTIFIER_LOCAL_VALUE (DECL_NAME (link)) = 0;
13500 my_friendly_assert (TREE_CODE (link) != FUNCTION_DECL, 163);
13501 DECL_CONTEXT (link) = NULL_TREE;
13502 }
13503
13504 /* Restore all name-meanings of the outer levels
13505 that were shadowed by this level. */
13506
13507 for (link = current_binding_level->shadowed; link; link = TREE_CHAIN (link))
13508 IDENTIFIER_LOCAL_VALUE (TREE_PURPOSE (link)) = TREE_VALUE (link);
13509 for (link = current_binding_level->class_shadowed;
13510 link; link = TREE_CHAIN (link))
13511 IDENTIFIER_CLASS_VALUE (TREE_PURPOSE (link)) = TREE_VALUE (link);
13512 for (link = current_binding_level->type_shadowed;
13513 link; link = TREE_CHAIN (link))
13514 SET_IDENTIFIER_TYPE_VALUE (TREE_PURPOSE (link), TREE_VALUE (link));
13515
13516 GNU_xref_end_scope ((HOST_WIDE_INT) current_binding_level,
13517 (HOST_WIDE_INT) current_binding_level->level_chain,
13518 current_binding_level->parm_flag,
13519 current_binding_level->keep);
13520
13521 poplevel (0, 0, 0);
13522
13523 DECL_INITIAL (fndecl) = old_initial;
13524
13525 /* We used to check if the context of FNDECL was different from
13526 current_class_type as another way to get inside here. This didn't work
13527 for String.cc in libg++. */
13528 if (DECL_FRIEND_P (fndecl))
13529 {
13530 CLASSTYPE_INLINE_FRIENDS (current_class_type)
13531 = tree_cons (NULL_TREE, fndecl, CLASSTYPE_INLINE_FRIENDS (current_class_type));
13532 decl = void_type_node;
13533 }
13534
13535 return decl;
13536 }
13537 \f
13538 /* Called when a new struct TYPE is defined.
13539 If this structure or union completes the type of any previous
13540 variable declaration, lay it out and output its rtl. */
13541
13542 void
13543 hack_incomplete_structures (type)
13544 tree type;
13545 {
13546 tree *list;
13547
13548 if (current_binding_level->incomplete == NULL_TREE)
13549 return;
13550
13551 if (!type) /* Don't do this for class templates. */
13552 return;
13553
13554 for (list = &current_binding_level->incomplete; *list; )
13555 {
13556 tree decl = TREE_VALUE (*list);
13557 if ((decl && TREE_TYPE (decl) == type)
13558 || (TREE_TYPE (decl)
13559 && TREE_CODE (TREE_TYPE (decl)) == ARRAY_TYPE
13560 && TREE_TYPE (TREE_TYPE (decl)) == type))
13561 {
13562 int toplevel = toplevel_bindings_p ();
13563 if (TREE_CODE (TREE_TYPE (decl)) == ARRAY_TYPE
13564 && TREE_TYPE (TREE_TYPE (decl)) == type)
13565 layout_type (TREE_TYPE (decl));
13566 layout_decl (decl, 0);
13567 rest_of_decl_compilation (decl, NULL_PTR, toplevel, 0);
13568 if (! toplevel)
13569 {
13570 tree cleanup;
13571 expand_decl (decl);
13572 cleanup = maybe_build_cleanup (decl);
13573 expand_decl_init (decl);
13574 if (! expand_decl_cleanup (decl, cleanup))
13575 cp_error ("parser lost in parsing declaration of `%D'",
13576 decl);
13577 }
13578 *list = TREE_CHAIN (*list);
13579 }
13580 else
13581 list = &TREE_CHAIN (*list);
13582 }
13583 }
13584
13585 /* If DECL is of a type which needs a cleanup, build that cleanup here.
13586 See build_delete for information about AUTO_DELETE.
13587
13588 Don't build these on the momentary obstack; they must live
13589 the life of the binding contour. */
13590
13591 static tree
13592 maybe_build_cleanup_1 (decl, auto_delete)
13593 tree decl, auto_delete;
13594 {
13595 tree type = TREE_TYPE (decl);
13596 if (TYPE_NEEDS_DESTRUCTOR (type))
13597 {
13598 int temp = 0, flags = LOOKUP_NORMAL|LOOKUP_DESTRUCTOR;
13599 tree rval;
13600
13601 if (TREE_CODE (decl) != PARM_DECL)
13602 temp = suspend_momentary ();
13603
13604 if (TREE_CODE (type) == ARRAY_TYPE)
13605 rval = decl;
13606 else
13607 {
13608 mark_addressable (decl);
13609 rval = build_unary_op (ADDR_EXPR, decl, 0);
13610 }
13611
13612 /* Optimize for space over speed here. */
13613 if (! TYPE_USES_VIRTUAL_BASECLASSES (type)
13614 || flag_expensive_optimizations)
13615 flags |= LOOKUP_NONVIRTUAL;
13616
13617 rval = build_delete (TREE_TYPE (rval), rval, auto_delete, flags, 0);
13618
13619 if (TYPE_USES_VIRTUAL_BASECLASSES (type)
13620 && ! TYPE_HAS_DESTRUCTOR (type))
13621 rval = build_compound_expr (expr_tree_cons (NULL_TREE, rval,
13622 build_expr_list (NULL_TREE, build_vbase_delete (type, decl))));
13623
13624 if (TREE_CODE (decl) != PARM_DECL)
13625 resume_momentary (temp);
13626
13627 return rval;
13628 }
13629 return 0;
13630 }
13631
13632 /* If DECL is of a type which needs a cleanup, build that cleanup
13633 here. The cleanup does free the storage with a call to delete. */
13634
13635 tree
13636 maybe_build_cleanup_and_delete (decl)
13637 tree decl;
13638 {
13639 return maybe_build_cleanup_1 (decl, integer_three_node);
13640 }
13641
13642 /* If DECL is of a type which needs a cleanup, build that cleanup
13643 here. The cleanup does not free the storage with a call a delete. */
13644
13645 tree
13646 maybe_build_cleanup (decl)
13647 tree decl;
13648 {
13649 return maybe_build_cleanup_1 (decl, integer_two_node);
13650 }
13651 \f
13652 /* Expand a C++ expression at the statement level.
13653 This is needed to ferret out nodes which have UNKNOWN_TYPE.
13654 The C++ type checker should get all of these out when
13655 expressions are combined with other, type-providing, expressions,
13656 leaving only orphan expressions, such as:
13657
13658 &class::bar; / / takes its address, but does nothing with it. */
13659
13660 void
13661 cplus_expand_expr_stmt (exp)
13662 tree exp;
13663 {
13664 if (processing_template_decl)
13665 {
13666 add_tree (build_min_nt (EXPR_STMT, exp));
13667 return;
13668 }
13669
13670 /* Arrange for all temps to disappear. */
13671 expand_start_target_temps ();
13672
13673 if (TREE_TYPE (exp) == unknown_type_node)
13674 {
13675 if (TREE_CODE (exp) == ADDR_EXPR || TREE_CODE (exp) == TREE_LIST)
13676 error ("address of overloaded function with no contextual type information");
13677 else if (TREE_CODE (exp) == COMPONENT_REF)
13678 warning ("useless reference to a member function name, did you forget the ()?");
13679 }
13680 else
13681 {
13682 if (TREE_CODE (exp) == FUNCTION_DECL)
13683 {
13684 cp_warning ("reference, not call, to function `%D'", exp);
13685 warning ("at this point in file");
13686 }
13687
13688 #if 0
13689 /* We should do this eventually, but right now this causes regex.o from
13690 libg++ to miscompile, and tString to core dump. */
13691 exp = build1 (CLEANUP_POINT_EXPR, TREE_TYPE (exp), exp);
13692 #endif
13693
13694 /* Strip unused implicit INDIRECT_REFs of references. */
13695 if (TREE_CODE (exp) == INDIRECT_REF
13696 && TREE_CODE (TREE_TYPE (TREE_OPERAND (exp, 0))) == REFERENCE_TYPE)
13697 exp = TREE_OPERAND (exp, 0);
13698
13699 /* If we don't do this, we end up down inside expand_expr
13700 trying to do TYPE_MODE on the ERROR_MARK, and really
13701 go outside the bounds of the type. */
13702 if (exp != error_mark_node)
13703 expand_expr_stmt (break_out_cleanups (exp));
13704 }
13705
13706 /* Clean up any pending cleanups. This happens when a function call
13707 returns a cleanup-needing value that nobody uses. */
13708 expand_end_target_temps ();
13709 }
13710
13711 /* When a stmt has been parsed, this function is called.
13712
13713 Currently, this function only does something within a
13714 constructor's scope: if a stmt has just assigned to this,
13715 and we are in a derived class, we call `emit_base_init'. */
13716
13717 void
13718 finish_stmt ()
13719 {
13720 extern struct nesting *cond_stack, *loop_stack, *case_stack;
13721
13722
13723 if (current_function_assigns_this
13724 || ! current_function_just_assigned_this)
13725 return;
13726 if (DECL_CONSTRUCTOR_P (current_function_decl))
13727 {
13728 /* Constructors must wait until we are out of control
13729 zones before calling base constructors. */
13730 if (cond_stack || loop_stack || case_stack)
13731 return;
13732 expand_expr_stmt (base_init_expr);
13733 check_base_init (current_class_type);
13734 }
13735 current_function_assigns_this = 1;
13736 }
13737
13738 /* Change a static member function definition into a FUNCTION_TYPE, instead
13739 of the METHOD_TYPE that we create when it's originally parsed.
13740
13741 WARNING: DO NOT pass &TREE_TYPE (decl) to FN or &TYPE_ARG_TYPES
13742 (TREE_TYPE (decl)) to ARGTYPES, as doing so will corrupt the types of
13743 other decls. Either pass the addresses of local variables or NULL. */
13744
13745 void
13746 revert_static_member_fn (decl, fn, argtypes)
13747 tree *decl, *fn, *argtypes;
13748 {
13749 tree tmp;
13750 tree function = fn ? *fn : TREE_TYPE (*decl);
13751 tree args = argtypes ? *argtypes : TYPE_ARG_TYPES (function);
13752
13753 if (TYPE_READONLY (TREE_TYPE (TREE_VALUE (args))))
13754 cp_error ("static member function `%#D' declared const", *decl);
13755 if (TYPE_VOLATILE (TREE_TYPE (TREE_VALUE (args))))
13756 cp_error ("static member function `%#D' declared volatile", *decl);
13757
13758 args = TREE_CHAIN (args);
13759 tmp = build_function_type (TREE_TYPE (function), args);
13760 tmp = build_type_variant (tmp, TYPE_READONLY (function),
13761 TYPE_VOLATILE (function));
13762 tmp = build_exception_variant (tmp,
13763 TYPE_RAISES_EXCEPTIONS (function));
13764 TREE_TYPE (*decl) = tmp;
13765 if (DECL_ARGUMENTS (*decl))
13766 DECL_ARGUMENTS (*decl) = TREE_CHAIN (DECL_ARGUMENTS (*decl));
13767 DECL_STATIC_FUNCTION_P (*decl) = 1;
13768 if (fn)
13769 *fn = tmp;
13770 if (argtypes)
13771 *argtypes = args;
13772 }
13773
13774 int
13775 id_in_current_class (id)
13776 tree id;
13777 {
13778 return !!purpose_member (id, class_binding_level->class_shadowed);
13779 }
13780
13781 struct cp_function
13782 {
13783 int returns_value;
13784 int returns_null;
13785 int warn_about_return_type;
13786 int assigns_this;
13787 int just_assigned_this;
13788 int parms_stored;
13789 int temp_name_counter;
13790 tree named_labels;
13791 tree shadowed_labels;
13792 tree ctor_label;
13793 tree dtor_label;
13794 rtx last_dtor_insn;
13795 rtx last_parm_cleanup_insn;
13796 tree base_init_list;
13797 tree member_init_list;
13798 tree base_init_expr;
13799 tree current_class_ptr;
13800 tree current_class_ref;
13801 rtx result_rtx;
13802 struct cp_function *next;
13803 struct binding_level *binding_level;
13804 int static_labelno;
13805 };
13806
13807 static struct cp_function *cp_function_chain;
13808
13809 extern int temp_name_counter;
13810
13811 /* Save and reinitialize the variables
13812 used during compilation of a C++ function. */
13813
13814 void
13815 push_cp_function_context (context)
13816 tree context;
13817 {
13818 struct cp_function *p
13819 = (struct cp_function *) xmalloc (sizeof (struct cp_function));
13820
13821 push_function_context_to (context);
13822
13823 p->next = cp_function_chain;
13824 cp_function_chain = p;
13825
13826 p->named_labels = named_labels;
13827 p->shadowed_labels = shadowed_labels;
13828 p->returns_value = current_function_returns_value;
13829 p->returns_null = current_function_returns_null;
13830 p->warn_about_return_type = warn_about_return_type;
13831 p->binding_level = current_binding_level;
13832 p->ctor_label = ctor_label;
13833 p->dtor_label = dtor_label;
13834 p->last_dtor_insn = last_dtor_insn;
13835 p->last_parm_cleanup_insn = last_parm_cleanup_insn;
13836 p->assigns_this = current_function_assigns_this;
13837 p->just_assigned_this = current_function_just_assigned_this;
13838 p->parms_stored = current_function_parms_stored;
13839 p->result_rtx = original_result_rtx;
13840 p->base_init_expr = base_init_expr;
13841 p->temp_name_counter = temp_name_counter;
13842 p->base_init_list = current_base_init_list;
13843 p->member_init_list = current_member_init_list;
13844 p->current_class_ptr = current_class_ptr;
13845 p->current_class_ref = current_class_ref;
13846 p->static_labelno = static_labelno;
13847 }
13848
13849 /* Restore the variables used during compilation of a C++ function. */
13850
13851 void
13852 pop_cp_function_context (context)
13853 tree context;
13854 {
13855 struct cp_function *p = cp_function_chain;
13856 tree link;
13857
13858 /* Bring back all the labels that were shadowed. */
13859 for (link = shadowed_labels; link; link = TREE_CHAIN (link))
13860 if (DECL_NAME (TREE_VALUE (link)) != 0)
13861 SET_IDENTIFIER_LABEL_VALUE (DECL_NAME (TREE_VALUE (link)),
13862 TREE_VALUE (link));
13863
13864 pop_function_context_from (context);
13865
13866 cp_function_chain = p->next;
13867
13868 named_labels = p->named_labels;
13869 shadowed_labels = p->shadowed_labels;
13870 current_function_returns_value = p->returns_value;
13871 current_function_returns_null = p->returns_null;
13872 warn_about_return_type = p->warn_about_return_type;
13873 current_binding_level = p->binding_level;
13874 ctor_label = p->ctor_label;
13875 dtor_label = p->dtor_label;
13876 last_dtor_insn = p->last_dtor_insn;
13877 last_parm_cleanup_insn = p->last_parm_cleanup_insn;
13878 current_function_assigns_this = p->assigns_this;
13879 current_function_just_assigned_this = p->just_assigned_this;
13880 current_function_parms_stored = p->parms_stored;
13881 original_result_rtx = p->result_rtx;
13882 base_init_expr = p->base_init_expr;
13883 temp_name_counter = p->temp_name_counter;
13884 current_base_init_list = p->base_init_list;
13885 current_member_init_list = p->member_init_list;
13886 current_class_ptr = p->current_class_ptr;
13887 current_class_ref = p->current_class_ref;
13888 static_labelno = p->static_labelno;
13889
13890 free (p);
13891 }
13892
13893 int
13894 in_function_p ()
13895 {
13896 return function_depth != 0;
13897 }