annotate gcc/c/c-objc-common.c @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children 1830386684a0
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* Some code common to C and ObjC front ends.
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
2 Copyright (C) 2001-2018 Free Software Foundation, Inc.
111
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 This file is part of GCC.
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 GCC is free software; you can redistribute it and/or modify it under
kono
parents:
diff changeset
7 the terms of the GNU General Public License as published by the Free
kono
parents:
diff changeset
8 Software Foundation; either version 3, or (at your option) any later
kono
parents:
diff changeset
9 version.
kono
parents:
diff changeset
10
kono
parents:
diff changeset
11 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
kono
parents:
diff changeset
12 WARRANTY; without even the implied warranty of MERCHANTABILITY or
kono
parents:
diff changeset
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
kono
parents:
diff changeset
14 for more details.
kono
parents:
diff changeset
15
kono
parents:
diff changeset
16 You should have received a copy of the GNU General Public License
kono
parents:
diff changeset
17 along with GCC; see the file COPYING3. If not see
kono
parents:
diff changeset
18 <http://www.gnu.org/licenses/>. */
kono
parents:
diff changeset
19
kono
parents:
diff changeset
20 #include "config.h"
kono
parents:
diff changeset
21 #include "system.h"
kono
parents:
diff changeset
22 #include "coretypes.h"
kono
parents:
diff changeset
23 #include "c-tree.h"
kono
parents:
diff changeset
24 #include "intl.h"
kono
parents:
diff changeset
25 #include "c-family/c-pretty-print.h"
kono
parents:
diff changeset
26 #include "tree-pretty-print.h"
kono
parents:
diff changeset
27 #include "gimple-pretty-print.h"
kono
parents:
diff changeset
28 #include "langhooks.h"
kono
parents:
diff changeset
29 #include "c-objc-common.h"
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
30 #include "gcc-rich-location.h"
111
kono
parents:
diff changeset
31
kono
parents:
diff changeset
32 static bool c_tree_printer (pretty_printer *, text_info *, const char *,
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
33 int, bool, bool, bool, bool *, const char **);
111
kono
parents:
diff changeset
34
kono
parents:
diff changeset
35 bool
kono
parents:
diff changeset
36 c_missing_noreturn_ok_p (tree decl)
kono
parents:
diff changeset
37 {
kono
parents:
diff changeset
38 /* A missing noreturn is not ok for freestanding implementations and
kono
parents:
diff changeset
39 ok for the `main' function in hosted implementations. */
kono
parents:
diff changeset
40 return flag_hosted && MAIN_NAME_P (DECL_ASSEMBLER_NAME (decl));
kono
parents:
diff changeset
41 }
kono
parents:
diff changeset
42
kono
parents:
diff changeset
43 /* Called from check_global_declaration. */
kono
parents:
diff changeset
44
kono
parents:
diff changeset
45 bool
kono
parents:
diff changeset
46 c_warn_unused_global_decl (const_tree decl)
kono
parents:
diff changeset
47 {
kono
parents:
diff changeset
48 if (TREE_CODE (decl) == FUNCTION_DECL && DECL_DECLARED_INLINE_P (decl))
kono
parents:
diff changeset
49 return false;
kono
parents:
diff changeset
50 if (DECL_IN_SYSTEM_HEADER (decl))
kono
parents:
diff changeset
51 return false;
kono
parents:
diff changeset
52
kono
parents:
diff changeset
53 return true;
kono
parents:
diff changeset
54 }
kono
parents:
diff changeset
55
kono
parents:
diff changeset
56 /* Initialization common to C and Objective-C front ends. */
kono
parents:
diff changeset
57 bool
kono
parents:
diff changeset
58 c_objc_common_init (void)
kono
parents:
diff changeset
59 {
kono
parents:
diff changeset
60 c_init_decl_processing ();
kono
parents:
diff changeset
61
kono
parents:
diff changeset
62 return c_common_init ();
kono
parents:
diff changeset
63 }
kono
parents:
diff changeset
64
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
65 /* Print T to CPP. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
66
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
67 static void
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
68 print_type (c_pretty_printer *cpp, tree t, bool *quoted)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
69 {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
70 gcc_assert (TYPE_P (t));
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
71 struct obstack *ob = pp_buffer (cpp)->obstack;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
72 char *p = (char *) obstack_base (ob);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
73 /* Remember the end of the initial dump. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
74 int len = obstack_object_size (ob);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
75
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
76 tree name = TYPE_NAME (t);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
77 if (name && TREE_CODE (name) == TYPE_DECL && DECL_NAME (name))
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
78 pp_identifier (cpp, lang_hooks.decl_printable_name (name, 2));
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
79 else
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
80 cpp->type_id (t);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
81
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
82 /* If we're printing a type that involves typedefs, also print the
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
83 stripped version. But sometimes the stripped version looks
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
84 exactly the same, so we don't want it after all. To avoid
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
85 printing it in that case, we play ugly obstack games. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
86 if (TYPE_CANONICAL (t) && t != TYPE_CANONICAL (t))
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
87 {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
88 c_pretty_printer cpp2;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
89 /* Print the stripped version into a temporary printer. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
90 cpp2.type_id (TYPE_CANONICAL (t));
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
91 struct obstack *ob2 = cpp2.buffer->obstack;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
92 /* Get the stripped version from the temporary printer. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
93 const char *aka = (char *) obstack_base (ob2);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
94 int aka_len = obstack_object_size (ob2);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
95 int type1_len = obstack_object_size (ob) - len;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
96
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
97 /* If they are identical, bail out. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
98 if (aka_len == type1_len && memcmp (p + len, aka, aka_len) == 0)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
99 return;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
100
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
101 /* They're not, print the stripped version now. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
102 if (*quoted)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
103 pp_end_quote (cpp, pp_show_color (cpp));
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
104 pp_c_whitespace (cpp);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
105 pp_left_brace (cpp);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
106 pp_c_ws_string (cpp, _("aka"));
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
107 pp_c_whitespace (cpp);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
108 if (*quoted)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
109 pp_begin_quote (cpp, pp_show_color (cpp));
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
110 cpp->type_id (TYPE_CANONICAL (t));
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
111 if (*quoted)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
112 pp_end_quote (cpp, pp_show_color (cpp));
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
113 pp_right_brace (cpp);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
114 /* No further closing quotes are needed. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
115 *quoted = false;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
116 }
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
117 }
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
118
111
kono
parents:
diff changeset
119 /* Called during diagnostic message formatting process to print a
kono
parents:
diff changeset
120 source-level entity onto BUFFER. The meaning of the format specifiers
kono
parents:
diff changeset
121 is as follows:
kono
parents:
diff changeset
122 %D: a general decl,
kono
parents:
diff changeset
123 %E: an identifier or expression,
kono
parents:
diff changeset
124 %F: a function declaration,
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
125 %G: a Gimple statement,
111
kono
parents:
diff changeset
126 %K: a CALL_EXPR,
kono
parents:
diff changeset
127 %T: a type.
kono
parents:
diff changeset
128 %V: a list of type qualifiers from a tree.
kono
parents:
diff changeset
129 %v: an explicit list of type qualifiers
kono
parents:
diff changeset
130 %#v: an explicit list of type qualifiers of a function type.
kono
parents:
diff changeset
131
kono
parents:
diff changeset
132 Please notice when called, the `%' part was already skipped by the
kono
parents:
diff changeset
133 diagnostic machinery. */
kono
parents:
diff changeset
134 static bool
kono
parents:
diff changeset
135 c_tree_printer (pretty_printer *pp, text_info *text, const char *spec,
kono
parents:
diff changeset
136 int precision, bool wide, bool set_locus, bool hash,
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
137 bool *quoted, const char **)
111
kono
parents:
diff changeset
138 {
kono
parents:
diff changeset
139 tree t = NULL_TREE;
kono
parents:
diff changeset
140 // FIXME: the next cast should be a dynamic_cast, when it is permitted.
kono
parents:
diff changeset
141 c_pretty_printer *cpp = (c_pretty_printer *) pp;
kono
parents:
diff changeset
142 pp->padding = pp_none;
kono
parents:
diff changeset
143
kono
parents:
diff changeset
144 if (precision != 0 || wide)
kono
parents:
diff changeset
145 return false;
kono
parents:
diff changeset
146
kono
parents:
diff changeset
147 if (*spec == 'G')
kono
parents:
diff changeset
148 {
kono
parents:
diff changeset
149 percent_G_format (text);
kono
parents:
diff changeset
150 return true;
kono
parents:
diff changeset
151 }
kono
parents:
diff changeset
152
kono
parents:
diff changeset
153 if (*spec == 'K')
kono
parents:
diff changeset
154 {
kono
parents:
diff changeset
155 t = va_arg (*text->args_ptr, tree);
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
156 percent_K_format (text, EXPR_LOCATION (t), TREE_BLOCK (t));
111
kono
parents:
diff changeset
157 return true;
kono
parents:
diff changeset
158 }
kono
parents:
diff changeset
159
kono
parents:
diff changeset
160 if (*spec != 'v')
kono
parents:
diff changeset
161 {
kono
parents:
diff changeset
162 t = va_arg (*text->args_ptr, tree);
kono
parents:
diff changeset
163 if (set_locus)
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
164 text->set_location (0, DECL_SOURCE_LOCATION (t),
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
165 SHOW_RANGE_WITH_CARET);
111
kono
parents:
diff changeset
166 }
kono
parents:
diff changeset
167
kono
parents:
diff changeset
168 switch (*spec)
kono
parents:
diff changeset
169 {
kono
parents:
diff changeset
170 case 'D':
kono
parents:
diff changeset
171 if (VAR_P (t) && DECL_HAS_DEBUG_EXPR_P (t))
kono
parents:
diff changeset
172 {
kono
parents:
diff changeset
173 t = DECL_DEBUG_EXPR (t);
kono
parents:
diff changeset
174 if (!DECL_P (t))
kono
parents:
diff changeset
175 {
kono
parents:
diff changeset
176 cpp->expression (t);
kono
parents:
diff changeset
177 return true;
kono
parents:
diff changeset
178 }
kono
parents:
diff changeset
179 }
kono
parents:
diff changeset
180 /* FALLTHRU */
kono
parents:
diff changeset
181
kono
parents:
diff changeset
182 case 'F':
kono
parents:
diff changeset
183 if (DECL_NAME (t))
kono
parents:
diff changeset
184 {
kono
parents:
diff changeset
185 pp_identifier (cpp, lang_hooks.decl_printable_name (t, 2));
kono
parents:
diff changeset
186 return true;
kono
parents:
diff changeset
187 }
kono
parents:
diff changeset
188 break;
kono
parents:
diff changeset
189
kono
parents:
diff changeset
190 case 'T':
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
191 print_type (cpp, t, quoted);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
192 return true;
111
kono
parents:
diff changeset
193
kono
parents:
diff changeset
194 case 'E':
kono
parents:
diff changeset
195 if (TREE_CODE (t) == IDENTIFIER_NODE)
kono
parents:
diff changeset
196 pp_identifier (cpp, IDENTIFIER_POINTER (t));
kono
parents:
diff changeset
197 else
kono
parents:
diff changeset
198 cpp->expression (t);
kono
parents:
diff changeset
199 return true;
kono
parents:
diff changeset
200
kono
parents:
diff changeset
201 case 'V':
kono
parents:
diff changeset
202 pp_c_type_qualifier_list (cpp, t);
kono
parents:
diff changeset
203 return true;
kono
parents:
diff changeset
204
kono
parents:
diff changeset
205 case 'v':
kono
parents:
diff changeset
206 pp_c_cv_qualifiers (cpp, va_arg (*text->args_ptr, int), hash);
kono
parents:
diff changeset
207 return true;
kono
parents:
diff changeset
208
kono
parents:
diff changeset
209 default:
kono
parents:
diff changeset
210 return false;
kono
parents:
diff changeset
211 }
kono
parents:
diff changeset
212
kono
parents:
diff changeset
213 pp_string (cpp, _("({anonymous})"));
kono
parents:
diff changeset
214 return true;
kono
parents:
diff changeset
215 }
kono
parents:
diff changeset
216
131
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
217 /* C-specific implementation of range_label::get_text () vfunc for
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
218 range_label_for_type_mismatch. */
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
219
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
220 label_text
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
221 range_label_for_type_mismatch::get_text (unsigned /*range_idx*/) const
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
222 {
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
223 if (m_labelled_type == NULL_TREE)
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
224 return label_text (NULL, false);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
225
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
226 c_pretty_printer cpp;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
227 bool quoted = false;
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
228 print_type (&cpp, m_labelled_type, &quoted);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
229 return label_text (xstrdup (pp_formatted_text (&cpp)), true);
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
230 }
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
231
84e7813d76e9 gcc-8.2
mir3636
parents: 111
diff changeset
232
111
kono
parents:
diff changeset
233 /* In C and ObjC, all decls have "C" linkage. */
kono
parents:
diff changeset
234 bool
kono
parents:
diff changeset
235 has_c_linkage (const_tree decl ATTRIBUTE_UNUSED)
kono
parents:
diff changeset
236 {
kono
parents:
diff changeset
237 return true;
kono
parents:
diff changeset
238 }
kono
parents:
diff changeset
239
kono
parents:
diff changeset
240 void
kono
parents:
diff changeset
241 c_initialize_diagnostics (diagnostic_context *context)
kono
parents:
diff changeset
242 {
kono
parents:
diff changeset
243 pretty_printer *base = context->printer;
kono
parents:
diff changeset
244 c_pretty_printer *pp = XNEW (c_pretty_printer);
kono
parents:
diff changeset
245 context->printer = new (pp) c_pretty_printer ();
kono
parents:
diff changeset
246
kono
parents:
diff changeset
247 /* It is safe to free this object because it was previously XNEW()'d. */
kono
parents:
diff changeset
248 base->~pretty_printer ();
kono
parents:
diff changeset
249 XDELETE (base);
kono
parents:
diff changeset
250
kono
parents:
diff changeset
251 c_common_diagnostics_set_defaults (context);
kono
parents:
diff changeset
252 diagnostic_format_decoder (context) = &c_tree_printer;
kono
parents:
diff changeset
253 }
kono
parents:
diff changeset
254
kono
parents:
diff changeset
255 int
kono
parents:
diff changeset
256 c_types_compatible_p (tree x, tree y)
kono
parents:
diff changeset
257 {
kono
parents:
diff changeset
258 return comptypes (TYPE_MAIN_VARIANT (x), TYPE_MAIN_VARIANT (y));
kono
parents:
diff changeset
259 }
kono
parents:
diff changeset
260
kono
parents:
diff changeset
261 /* Determine if the type is a vla type for the backend. */
kono
parents:
diff changeset
262
kono
parents:
diff changeset
263 bool
kono
parents:
diff changeset
264 c_vla_unspec_p (tree x, tree fn ATTRIBUTE_UNUSED)
kono
parents:
diff changeset
265 {
kono
parents:
diff changeset
266 return c_vla_type_p (x);
kono
parents:
diff changeset
267 }