2009-01-08 Kai Tietz <kai.tietz@onevision.com>
[deliverable/binutils-gdb.git] / gdb / ada-lang.h
CommitLineData
14f9c5c9 1/* Ada language support definitions for GDB, the GNU debugger.
a2bd3dcd 2
6aba47ca 3 Copyright (C) 1992, 1997, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005,
0fb0cc75 4 2007, 2008, 2009 Free Software Foundation, Inc.
14f9c5c9 5
a9762ec7 6 This file is part of GDB.
14f9c5c9 7
a9762ec7
JB
8 This program is free software; you can redistribute it and/or modify
9 it under the terms of the GNU General Public License as published by
10 the Free Software Foundation; either version 3 of the License, or
11 (at your option) any later version.
14f9c5c9 12
a9762ec7
JB
13 This program is distributed in the hope that it will be useful,
14 but WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 GNU General Public License for more details.
14f9c5c9 17
a9762ec7
JB
18 You should have received a copy of the GNU General Public License
19 along with this program. If not, see <http://www.gnu.org/licenses/>. */
14f9c5c9
AS
20
21#if !defined (ADA_LANG_H)
22#define ADA_LANG_H 1
23
da3331ec 24struct partial_symbol;
19c1ef65 25struct frame_info;
da3331ec 26
14f9c5c9
AS
27#include "value.h"
28#include "gdbtypes.h"
4c4b4cd2
PH
29#include "breakpoint.h"
30
31/* Names of specific files known to be part of the runtime
32 system and that might consider (confusing) debugging information.
33 Each name (a basic regular expression string) is followed by a
34 comma. FIXME: Should be part of a configuration file. */
e84ecc99 35#if defined(__alpha__) && defined(__osf__)
4c4b4cd2
PH
36#define ADA_KNOWN_RUNTIME_FILE_NAME_PATTERNS \
37 "^[agis]-.*\\.ad[bs]$", \
38 "/usr/shlib/libpthread\\.so",
39#elif defined (__linux__)
40#define ADA_KNOWN_RUNTIME_FILE_NAME_PATTERNS \
41 "^[agis]-.*\\.ad[bs]$", \
42 "/lib.*/libpthread\\.so[.0-9]*$", "/lib.*/libpthread\\.a$", \
43 "/lib.*/libc\\.so[.0-9]*$", "/lib.*/libc\\.a$",
44#endif
14f9c5c9 45
4c4b4cd2
PH
46#if !defined (ADA_KNOWN_RUNTIME_FILE_NAME_PATTERNS)
47#define ADA_KNOWN_RUNTIME_FILE_NAME_PATTERNS \
48 "^[agis]-.*\\.ad[bs]$",
49#endif
50
51/* Names of compiler-generated auxiliary functions probably of no
52 interest to users. Each name (a basic regular expression string)
53 is followed by a comma. */
54#define ADA_KNOWN_AUXILIARY_FUNCTION_NAME_PATTERNS \
529cad9c 55 "___clean[.$a-zA-Z0-9_]*$",
fe898f56 56
4c4b4cd2
PH
57/* The maximum number of frame levels searched for non-local,
58 * non-global symbols. This limit exists as a precaution to prevent
59 * infinite search loops when the stack is screwed up. */
60#define MAX_ENCLOSING_FRAME_LEVELS 7
14f9c5c9 61
4c4b4cd2
PH
62/* Maximum number of steps followed in looking for the ultimate
63 referent of a renaming. This prevents certain infinite loops that
64 can otherwise result. */
65#define MAX_RENAMING_CHAIN_LENGTH 10
14f9c5c9 66
4c4b4cd2
PH
67struct block;
68
69/* Corresponding encoded/decoded names and opcodes for Ada user-definable
14f9c5c9 70 operators. */
d2e4a39e
AS
71struct ada_opname_map
72{
4c4b4cd2
PH
73 const char *encoded;
74 const char *decoded;
14f9c5c9
AS
75 enum exp_opcode op;
76};
77
4c4b4cd2 78/* Table of Ada operators in encoded and decoded forms. */
14f9c5c9
AS
79/* Defined in ada-lang.c */
80extern const struct ada_opname_map ada_opname_table[];
81
4c4b4cd2
PH
82enum ada_operator
83 {
84 /* X IN A'RANGE(N). N is an immediate operand, surrounded by
85 BINOP_IN_BOUNDS before and after. A is an array, X an index
86 value. Evaluates to true iff X is within range of the Nth
87 dimension (1-based) of A. (A multi-dimensional array
88 type is represented as array of array of ...) */
89 BINOP_IN_BOUNDS = OP_EXTENDED0,
90
91 /* X IN L .. U. True iff L <= X <= U. */
92 TERNOP_IN_RANGE,
93
94 /* Ada attributes ('Foo). */
95 OP_ATR_FIRST,
96 OP_ATR_LAST,
97 OP_ATR_LENGTH,
98 OP_ATR_IMAGE,
99 OP_ATR_MAX,
100 OP_ATR_MIN,
101 OP_ATR_MODULUS,
102 OP_ATR_POS,
103 OP_ATR_SIZE,
104 OP_ATR_TAG,
105 OP_ATR_VAL,
106
107 /* Ada type qualification. It is encoded as for UNOP_CAST, above,
108 and denotes the TYPE'(EXPR) construct. */
109 UNOP_QUAL,
110
111 /* X IN TYPE. The `TYPE' argument is immediate, with
112 UNOP_IN_RANGE before and after it. True iff X is a member of
113 type TYPE (typically a subrange). */
114 UNOP_IN_RANGE,
115
52ce6436
PH
116 /* An aggregate. A single immediate operand, N>0, gives
117 the number of component specifications that follow. The
118 immediate operand is followed by a second OP_AGGREGATE.
119 Next come N component specifications. A component
120 specification is either an OP_OTHERS (others=>...), an
121 OP_CHOICES (for named associations), or other expression (for
122 positional aggregates only). Aggregates currently
123 occur only as the right sides of assignments. */
124 OP_AGGREGATE,
125
126 /* An others clause. Followed by a single expression. */
127 OP_OTHERS,
128
129 /* An aggregate component association. A single immediate operand, N,
130 gives the number of choices that follow. This is followed by a second
131 OP_CHOICES operator. Next come N operands, each of which is an
132 expression, an OP_DISCRETE_RANGE, or an OP_NAME---the latter
133 for a simple name that must be a record component name and does
134 not correspond to a single existing symbol. After the N choice
135 indicators comes an expression giving the value.
136
137 In an aggregate such as (X => E1, ...), where X is a simple
138 name, X could syntactically be either a component_selector_name
139 or an expression used as a discrete_choice, depending on the
140 aggregate's type context. Since this is not known at parsing
141 time, we don't attempt to disambiguate X if it has multiple
142 definitions, but instead supply an OP_NAME. If X has a single
143 definition, we represent it with an OP_VAR_VALUE, even though
144 it may turn out to be within a record aggregate. Aggregate
145 evaluation can use either OP_NAMEs or OP_VAR_VALUEs to get a
146 record field name, and can evaluate OP_VAR_VALUE normally to
147 get its value as an expression. Unfortunately, we lose out in
148 cases where X has multiple meanings and is part of an array
149 aggregate. I hope these are not common enough to annoy users,
150 who can work around the problem in any case by putting
151 parentheses around X. */
152 OP_CHOICES,
153
154 /* A positional aggregate component association. The operator is
155 followed by a single integer indicating the position in the
156 aggregate (0-based), followed by a second OP_POSITIONAL. Next
157 follows a single expression giving the component value. */
158 OP_POSITIONAL,
159
160 /* A range of values. Followed by two expressions giving the
161 upper and lower bounds of the range. */
162 OP_DISCRETE_RANGE,
163
4c4b4cd2
PH
164 /* End marker */
165 OP_ADA_LAST
166 };
167
2570f2b7 168/* A tuple, (symbol, block), representing one instance of a
4c4b4cd2
PH
169 * symbol-lookup operation. */
170struct ada_symbol_info {
171 struct symbol* sym;
172 struct block* block;
14f9c5c9
AS
173};
174
aeb5907d
JB
175/* Denotes a type of renaming symbol (see ada_parse_renaming). */
176enum ada_renaming_category
177 {
178 /* Indicates a symbol that does not encode a renaming. */
179 ADA_NOT_RENAMING,
180
181 /* For symbols declared
182 Foo : TYPE renamed OBJECT; */
183 ADA_OBJECT_RENAMING,
184
185 /* For symbols declared
186 Foo : exception renames EXCEPTION; */
187 ADA_EXCEPTION_RENAMING,
188 /* For packages declared
189 package Foo renames PACKAGE; */
190 ADA_PACKAGE_RENAMING,
191 /* For subprograms declared
192 SUBPROGRAM_SPEC renames SUBPROGRAM;
193 (Currently not used). */
194 ADA_SUBPROGRAM_RENAMING
195 };
196
96d887e8
PH
197/* Ada task structures. */
198
0ef643c8 199struct ada_task_info
96d887e8 200{
0ef643c8
JB
201 /* The PTID of the thread that this task runs on. This ptid is computed
202 in a target-dependent way from the associated Task Control Block. */
203 ptid_t ptid;
204
205 /* The ID of the task. */
206 CORE_ADDR task_id;
207
208 /* The name of the task. */
209 char name[257];
210
211 /* The current state of the task. */
212 int state;
213
214 /* The priority associated to the task. */
96d887e8 215 int priority;
96d887e8 216
0ef643c8
JB
217 /* If non-zero, the task ID of the parent task. */
218 CORE_ADDR parent;
96d887e8 219
0ef643c8
JB
220 /* If the task is waiting on a task entry, this field contains
221 the ID of the other task. Zero otherwise. */
222 CORE_ADDR called_task;
96d887e8 223
0ef643c8
JB
224 /* If the task is accepting a rendezvous with another task, this field
225 contains the ID of the calling task. Zero otherwise. */
226 CORE_ADDR caller_task;
227};
96d887e8 228
0ef643c8 229int ada_task_is_alive (struct ada_task_info *task);
96d887e8 230
4c4b4cd2 231/* Assuming V points to an array of S objects, make sure that it contains at
14f9c5c9
AS
232 least M objects, updating V and S as necessary. */
233
4c4b4cd2 234#define GROW_VECT(v, s, m) \
f27cf670 235 if ((s) < (m)) (v) = grow_vect (v, &(s), m, sizeof *(v));
14f9c5c9 236
f27cf670 237extern void *grow_vect (void *, size_t *, size_t, int);
14f9c5c9 238
4c4b4cd2
PH
239extern int ada_get_field_index (const struct type *type,
240 const char *field_name,
241 int maybe_missing);
14f9c5c9 242
4c4b4cd2 243extern int ada_parse (void); /* Defined in ada-exp.y */
14f9c5c9 244
4c4b4cd2
PH
245extern void ada_error (char *); /* Defined in ada-exp.y */
246
247 /* Defined in ada-typeprint.c */
d2e4a39e 248extern void ada_print_type (struct type *, char *, struct ui_file *, int,
4c4b4cd2 249 int);
14f9c5c9 250
fc1a4b47 251extern int ada_val_print (struct type *, const gdb_byte *, int, CORE_ADDR,
79a45b7d
TT
252 struct ui_file *, int,
253 const struct value_print_options *);
14f9c5c9 254
79a45b7d
TT
255extern int ada_value_print (struct value *, struct ui_file *,
256 const struct value_print_options *);
14f9c5c9 257
4c4b4cd2 258 /* Defined in ada-lang.c */
14f9c5c9 259
14f9c5c9
AS
260extern void ada_emit_char (int, struct ui_file *, int, int);
261
d2e4a39e 262extern void ada_printchar (int, struct ui_file *);
14f9c5c9 263
fc1a4b47 264extern void ada_printstr (struct ui_file *, const gdb_byte *,
79a45b7d
TT
265 unsigned int, int, int,
266 const struct value_print_options *);
14f9c5c9 267
a93c0eb6
JB
268struct value *ada_convert_actual (struct value *actual,
269 struct type *formal_type0,
270 CORE_ADDR *sp);
14f9c5c9 271
d2e4a39e 272extern struct value *ada_value_subscript (struct value *, int,
4c4b4cd2 273 struct value **);
14f9c5c9 274
d2e4a39e 275extern struct type *ada_array_element_type (struct type *, int);
14f9c5c9 276
d2e4a39e 277extern int ada_array_arity (struct type *);
14f9c5c9 278
d2e4a39e 279struct type *ada_type_of_array (struct value *, int);
14f9c5c9 280
d2e4a39e 281extern struct value *ada_coerce_to_simple_array_ptr (struct value *);
14f9c5c9 282
4c4b4cd2 283extern int ada_is_simple_array_type (struct type *);
14f9c5c9 284
4c4b4cd2 285extern int ada_is_array_descriptor_type (struct type *);
14f9c5c9 286
d2e4a39e 287extern int ada_is_bogus_array_descriptor (struct type *);
14f9c5c9 288
d2e4a39e 289extern struct type *ada_index_type (struct type *, int);
14f9c5c9 290
d2e4a39e 291extern struct value *ada_array_bound (struct value *, int, int);
14f9c5c9 292
4c4b4cd2 293extern char *ada_decode_symbol (const struct general_symbol_info*);
14f9c5c9 294
4c4b4cd2 295extern const char *ada_decode (const char*);
14f9c5c9 296
4c4b4cd2
PH
297extern enum language ada_update_initial_language (enum language,
298 struct partial_symtab*);
14f9c5c9 299
4c4b4cd2 300extern void clear_ada_sym_cache (void);
14f9c5c9 301
4c4b4cd2
PH
302extern int ada_lookup_symbol_list (const char *, const struct block *,
303 domain_enum, struct ada_symbol_info**);
304
305extern char *ada_fold_name (const char *);
306
307extern struct symbol *ada_lookup_symbol (const char *, const struct block *,
21b556f4 308 domain_enum, int *);
4c4b4cd2 309
aeb5907d
JB
310extern struct symbol *
311ada_lookup_encoded_symbol (const char *, const struct block *,
21b556f4 312 domain_enum namespace, struct block **);
aeb5907d 313
4c4b4cd2 314extern struct minimal_symbol *ada_lookup_simple_minsym (const char *);
14f9c5c9 315
d2e4a39e 316extern void ada_fill_in_ada_prototype (struct symbol *);
14f9c5c9 317
4c4b4cd2 318extern int user_select_syms (struct ada_symbol_info *, int, int);
14f9c5c9 319
d2e4a39e 320extern int get_selections (int *, int, int, int, char *);
14f9c5c9 321
d2e4a39e 322extern char *ada_start_decode_line_1 (char *);
14f9c5c9 323
d2e4a39e 324extern struct symtabs_and_lines ada_finish_decode_line_1 (char **,
4c4b4cd2
PH
325 struct symtab *,
326 int, char ***);
327
328extern struct symtabs_and_lines ada_sals_for_line (const char*, int,
329 int, char***, int);
14f9c5c9 330
d2e4a39e 331extern int ada_scan_number (const char *, int, LONGEST *, int *);
14f9c5c9 332
d2e4a39e 333extern struct type *ada_parent_type (struct type *);
14f9c5c9 334
d2e4a39e 335extern int ada_is_ignored_field (struct type *, int);
14f9c5c9 336
d2e4a39e 337extern int ada_is_packed_array_type (struct type *);
14f9c5c9 338
a2bd3dcd 339extern struct value *ada_value_primitive_packed_val (struct value *,
fc1a4b47 340 const gdb_byte *,
4c4b4cd2
PH
341 long, int, int,
342 struct type *);
14f9c5c9 343
d2e4a39e 344extern struct type *ada_coerce_to_simple_array_type (struct type *);
14f9c5c9 345
d2e4a39e 346extern int ada_is_character_type (struct type *);
14f9c5c9 347
d2e4a39e 348extern int ada_is_string_type (struct type *);
14f9c5c9 349
4c4b4cd2
PH
350extern int ada_is_tagged_type (struct type *, int);
351
352extern int ada_is_tag_type (struct type *);
14f9c5c9 353
d2e4a39e 354extern struct type *ada_tag_type (struct value *);
14f9c5c9 355
d2e4a39e 356extern struct value *ada_value_tag (struct value *);
14f9c5c9 357
4c4b4cd2
PH
358extern const char *ada_tag_name (struct value *);
359
d2e4a39e 360extern int ada_is_parent_field (struct type *, int);
14f9c5c9 361
d2e4a39e 362extern int ada_is_wrapper_field (struct type *, int);
14f9c5c9 363
d2e4a39e 364extern int ada_is_variant_part (struct type *, int);
14f9c5c9 365
d2e4a39e 366extern struct type *ada_variant_discrim_type (struct type *, struct type *);
14f9c5c9 367
d2e4a39e 368extern int ada_is_others_clause (struct type *, int);
14f9c5c9 369
d2e4a39e 370extern int ada_in_variant (LONGEST, struct type *, int);
14f9c5c9 371
d2e4a39e 372extern char *ada_variant_discrim_name (struct type *);
14f9c5c9 373
03ee6b2e 374extern struct value *ada_value_struct_elt (struct value *, char *, int);
14f9c5c9 375
d2e4a39e 376extern int ada_is_aligner_type (struct type *);
14f9c5c9 377
d2e4a39e 378extern struct type *ada_aligned_type (struct type *);
14f9c5c9 379
fc1a4b47
AC
380extern const gdb_byte *ada_aligned_value_addr (struct type *,
381 const gdb_byte *);
14f9c5c9 382
4c4b4cd2 383extern const char *ada_attribute_name (enum exp_opcode);
14f9c5c9 384
d2e4a39e 385extern int ada_is_fixed_point_type (struct type *);
14f9c5c9 386
4c4b4cd2
PH
387extern int ada_is_system_address_type (struct type *);
388
d2e4a39e 389extern DOUBLEST ada_delta (struct type *);
14f9c5c9
AS
390
391extern DOUBLEST ada_fixed_to_float (struct type *, LONGEST);
392
d2e4a39e 393extern LONGEST ada_float_to_fixed (struct type *, DOUBLEST);
14f9c5c9 394
d2e4a39e 395extern int ada_is_vax_floating_type (struct type *);
14f9c5c9 396
d2e4a39e 397extern int ada_vax_float_type_suffix (struct type *);
14f9c5c9 398
d2e4a39e 399extern struct value *ada_vax_float_print_function (struct type *);
14f9c5c9 400
d2e4a39e 401extern struct type *ada_system_address_type (void);
14f9c5c9 402
a2bd3dcd 403extern int ada_which_variant_applies (struct type *, struct type *,
fc1a4b47 404 const gdb_byte *);
14f9c5c9 405
fc1a4b47 406extern struct type *ada_to_fixed_type (struct type *, const gdb_byte *,
1ed6ede0
JB
407 CORE_ADDR, struct value *,
408 int check_tag);
4c4b4cd2 409
10a2c479 410extern struct type *ada_template_to_fixed_record_type_1 (struct type *type,
fc1a4b47 411 const gdb_byte *valaddr,
10a2c479
AC
412 CORE_ADDR address,
413 struct value *dval0,
414 int keep_dynamic_fields);
14f9c5c9 415
d2e4a39e 416extern int ada_name_prefix_len (const char *);
14f9c5c9 417
d2e4a39e 418extern char *ada_type_name (struct type *);
14f9c5c9 419
d2e4a39e 420extern struct type *ada_find_parallel_type (struct type *,
4c4b4cd2
PH
421 const char *suffix);
422
423extern LONGEST get_int_var_value (char *, int *);
14f9c5c9 424
4c4b4cd2 425extern struct symbol *ada_find_any_symbol (const char *name);
14f9c5c9 426
d2e4a39e 427extern struct type *ada_find_any_type (const char *name);
14f9c5c9 428
4c4b4cd2
PH
429extern struct symbol *ada_find_renaming_symbol (const char *name,
430 struct block *block);
431
d2e4a39e 432extern int ada_prefer_type (struct type *, struct type *);
14f9c5c9 433
d2e4a39e 434extern struct type *ada_get_base_type (struct type *);
14f9c5c9 435
61ee279c 436extern struct type *ada_check_typedef (struct type *);
14f9c5c9 437
4c4b4cd2 438extern char *ada_encode (const char *);
14f9c5c9 439
d2e4a39e 440extern const char *ada_enum_name (const char *);
14f9c5c9 441
d2e4a39e 442extern int ada_is_modular_type (struct type *);
14f9c5c9 443
61ee279c 444extern ULONGEST ada_modulus (struct type *);
14f9c5c9 445
d2e4a39e 446extern struct value *ada_value_ind (struct value *);
14f9c5c9 447
d2e4a39e 448extern void ada_print_scalar (struct type *, LONGEST, struct ui_file *);
14f9c5c9 449
d2e4a39e 450extern int ada_is_range_type_name (const char *);
14f9c5c9 451
aeb5907d
JB
452extern enum ada_renaming_category ada_parse_renaming (struct symbol *,
453 const char **,
454 int *, const char **);
14f9c5c9 455
0ef643c8
JB
456extern void ada_find_printable_frame (struct frame_info *fi);
457
d2e4a39e 458extern char *ada_breakpoint_rewrite (char *, int *);
14f9c5c9 459
4c4b4cd2
PH
460extern char *ada_main_name (void);
461
14f9c5c9
AS
462/* Tasking-related: ada-tasks.c */
463
464extern int valid_task_id (int);
465
0ef643c8
JB
466typedef void (ada_task_list_iterator_ftype) (struct ada_task_info *task);
467extern void iterate_over_live_ada_tasks
468 (ada_task_list_iterator_ftype *iterator);
4c4b4cd2
PH
469
470extern void ada_adjust_exception_stop (bpstat bs);
14f9c5c9 471
4c4b4cd2 472extern void ada_print_exception_stop (bpstat bs);
14f9c5c9 473
4c4b4cd2 474extern int ada_get_current_task (ptid_t);
14f9c5c9 475
4c4b4cd2
PH
476extern int breakpoint_ada_task_match (CORE_ADDR, ptid_t);
477
478extern int ada_print_exception_breakpoint_nontask (struct breakpoint *);
479
480extern void ada_print_exception_breakpoint_task (struct breakpoint *);
14f9c5c9 481
4c4b4cd2 482extern void ada_reset_thread_registers (void);
14f9c5c9 483
0ef643c8 484extern int ada_build_task_list (int warn_if_null);
96d887e8 485
f7f9143b
JB
486extern int ada_exception_catchpoint_p (struct breakpoint *b);
487
488extern struct symtab_and_line
489 ada_decode_exception_location (char *args, char **addr_string,
490 char **exp_string, char **cond_string,
491 struct expression **cond,
492 struct breakpoint_ops **ops);
493
494extern struct symtab_and_line
495 ada_decode_assert_location (char *args, char **addr_string,
496 struct breakpoint_ops **ops);
497
498
14f9c5c9 499#endif
This page took 0.384321 seconds and 4 git commands to generate.