]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blame - gdb/typeprint.h
Update copyright year range in all GDB files
[thirdparty/binutils-gdb.git] / gdb / typeprint.h
CommitLineData
c906108c 1/* Language independent support for printing types for GDB, the GNU debugger.
3666a048 2 Copyright (C) 1986-2021 Free Software Foundation, Inc.
c906108c 3
c5aa993b 4 This file is part of GDB.
c906108c 5
c5aa993b
JM
6 This program is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
a9762ec7 8 the Free Software Foundation; either version 3 of the License, or
c5aa993b 9 (at your option) any later version.
c906108c 10
c5aa993b
JM
11 This program is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
c906108c 15
c5aa993b 16 You should have received a copy of the GNU General Public License
a9762ec7 17 along with this program. If not, see <http://www.gnu.org/licenses/>. */
c906108c 18
17732724
AC
19#ifndef TYPEPRINT_H
20#define TYPEPRINT_H
21
c819b2c0
TT
22#include "gdb_obstack.h"
23
94af9270 24enum language;
da3331ec 25struct ui_file;
bd69fc68 26struct typedef_hash_table;
6dddc817 27struct ext_lang_type_printers;
da3331ec 28
7c161838
SDJ
29struct print_offset_data
30{
31 /* The offset to be applied to bitpos when PRINT_OFFSETS is true.
32 This is needed for when we are printing nested structs and want
33 to make sure that the printed offset for each field carries over
34 the offset of the outter struct. */
35 unsigned int offset_bitpos = 0;
36
37 /* END_BITPOS is the one-past-the-end bit position of the previous
38 field (where we expect the current field to be if there is no
39 hole). */
40 unsigned int end_bitpos = 0;
e0c547d1
TT
41
42 /* Print information about field at index FIELD_IDX of the struct type
43 TYPE and update this object.
44
45 If the field is static, it simply prints the correct number of
46 spaces.
47
48 The output is strongly based on pahole(1). */
49 void update (struct type *type, unsigned int field_idx,
50 struct ui_file *stream);
51
52 /* Call when all fields have been printed. This will print
53 information about any padding that may exist. LEVEL is the
54 desired indentation level. */
55 void finish (struct type *type, int level, struct ui_file *stream);
56
57 /* When printing the offsets of a struct and its fields (i.e.,
58 'ptype /o'; type_print_options::print_offsets), we use this many
59 characters when printing the offset information at the beginning
60 of the line. This is needed in order to generate the correct
61 amount of whitespaces when no offset info should be printed for a
62 certain field. */
63 static const int indentation;
64
65private:
66
67 /* Helper function for ptype/o implementation that prints
68 information about a hole, if necessary. STREAM is where to
69 print. BITPOS is the bitpos of the current field. FOR_WHAT is a
70 string describing the purpose of the hole. */
71
72 void maybe_print_hole (struct ui_file *stream, unsigned int bitpos,
73 const char *for_what);
7c161838
SDJ
74};
75
79d43c61
TT
76struct type_print_options
77{
78 /* True means that no special printing flags should apply. */
79 unsigned int raw : 1;
53342f27
TT
80
81 /* True means print methods in a class. */
82 unsigned int print_methods : 1;
83
84 /* True means print typedefs in a class. */
85 unsigned int print_typedefs : 1;
bd69fc68 86
7c161838
SDJ
87 /* True means to print offsets, a la 'pahole'. */
88 unsigned int print_offsets : 1;
89
883fd55a
KS
90 /* The number of nested type definitions to print. -1 == all. */
91 int print_nested_type_limit;
92
bd69fc68
TT
93 /* If not NULL, a local typedef hash table used when printing a
94 type. */
c819b2c0 95 typedef_hash_table *local_typedefs;
18a9fc12
TT
96
97 /* If not NULL, a global typedef hash table used when printing a
98 type. */
c819b2c0 99 typedef_hash_table *global_typedefs;
18a9fc12
TT
100
101 /* The list of type printers associated with the global typedef
102 table. This is intentionally opaque. */
6dddc817 103 struct ext_lang_type_printers *global_printers;
79d43c61
TT
104};
105
106extern const struct type_print_options type_print_raw_options;
107
c819b2c0
TT
108/* A hash table holding typedef_field objects. This is more
109 complicated than an ordinary hash because it must also track the
110 lifetime of some -- but not all -- of the contained objects. */
111
112class typedef_hash_table
113{
114public:
115
116 /* Create a new typedef-lookup hash table. */
117 typedef_hash_table ();
118
c819b2c0
TT
119 /* Copy a typedef hash. */
120 typedef_hash_table (const typedef_hash_table &);
bd69fc68 121
c819b2c0 122 typedef_hash_table &operator= (const typedef_hash_table &) = delete;
bd69fc68 123
c819b2c0
TT
124 /* Add typedefs from T to the hash table TABLE. */
125 void recursively_update (struct type *);
bd69fc68 126
c819b2c0
TT
127 /* Add template parameters from T to the typedef hash TABLE. */
128 void add_template_parameters (struct type *t);
bd69fc68 129
c819b2c0
TT
130 /* Look up the type T in the typedef hash tables contained in FLAGS.
131 The local table is searched first, then the global table (either
132 table can be NULL, in which case it is skipped). If T is in a
133 table, return its short (class-relative) typedef name. Otherwise
134 return NULL. */
135 static const char *find_typedef (const struct type_print_options *flags,
136 struct type *t);
bd69fc68 137
c819b2c0
TT
138private:
139
140 static const char *find_global_typedef (const struct type_print_options *flags,
141 struct type *t);
142
143
144 /* The actual hash table. */
fa9b1164 145 htab_up m_table;
c819b2c0
TT
146
147 /* Storage for typedef_field objects that must be synthesized. */
148 auto_obstack m_storage;
149};
bd69fc68 150
bd69fc68 151
d9fcf2fb 152void print_type_scalar (struct type * type, LONGEST, struct ui_file *);
c906108c 153
0c9150e4
JB
154/* Assuming the TYPE is a fixed point type, print its type description
155 on STREAM. */
156
157void print_type_fixed_point (struct type *type, struct ui_file *stream);
158
79d43c61
TT
159void c_type_print_args (struct type *, struct ui_file *, int, enum language,
160 const struct type_print_options *);
94af9270 161
7022349d
PA
162/* Print <unknown return type> to stream STREAM. */
163
164void type_print_unknown_return_type (struct ui_file *stream);
165
46a4882b
PA
166/* Throw an error indicating that the user tried to use a symbol that
167 has unknown type. SYM_PRINT_NAME is the name of the symbol, to be
168 included in the error message. */
169extern void error_unknown_type (const char *sym_print_name);
170
3f2f83dd
KB
171extern void val_print_not_allocated (struct ui_file *stream);
172
173extern void val_print_not_associated (struct ui_file *stream);
174
17732724 175#endif