annotate gcc/c/c-objc-common.c @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children 84e7813d76e9
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.
kono
parents:
diff changeset
2 Copyright (C) 2001-2017 Free Software Foundation, Inc.
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"
kono
parents:
diff changeset
30
kono
parents:
diff changeset
31 static bool c_tree_printer (pretty_printer *, text_info *, const char *,
kono
parents:
diff changeset
32 int, bool, bool, bool, bool, const char **);
kono
parents:
diff changeset
33
kono
parents:
diff changeset
34 bool
kono
parents:
diff changeset
35 c_missing_noreturn_ok_p (tree decl)
kono
parents:
diff changeset
36 {
kono
parents:
diff changeset
37 /* A missing noreturn is not ok for freestanding implementations and
kono
parents:
diff changeset
38 ok for the `main' function in hosted implementations. */
kono
parents:
diff changeset
39 return flag_hosted && MAIN_NAME_P (DECL_ASSEMBLER_NAME (decl));
kono
parents:
diff changeset
40 }
kono
parents:
diff changeset
41
kono
parents:
diff changeset
42 /* Called from check_global_declaration. */
kono
parents:
diff changeset
43
kono
parents:
diff changeset
44 bool
kono
parents:
diff changeset
45 c_warn_unused_global_decl (const_tree decl)
kono
parents:
diff changeset
46 {
kono
parents:
diff changeset
47 if (TREE_CODE (decl) == FUNCTION_DECL && DECL_DECLARED_INLINE_P (decl))
kono
parents:
diff changeset
48 return false;
kono
parents:
diff changeset
49 if (DECL_IN_SYSTEM_HEADER (decl))
kono
parents:
diff changeset
50 return false;
kono
parents:
diff changeset
51
kono
parents:
diff changeset
52 return true;
kono
parents:
diff changeset
53 }
kono
parents:
diff changeset
54
kono
parents:
diff changeset
55 /* Initialization common to C and Objective-C front ends. */
kono
parents:
diff changeset
56 bool
kono
parents:
diff changeset
57 c_objc_common_init (void)
kono
parents:
diff changeset
58 {
kono
parents:
diff changeset
59 c_init_decl_processing ();
kono
parents:
diff changeset
60
kono
parents:
diff changeset
61 return c_common_init ();
kono
parents:
diff changeset
62 }
kono
parents:
diff changeset
63
kono
parents:
diff changeset
64 /* Called during diagnostic message formatting process to print a
kono
parents:
diff changeset
65 source-level entity onto BUFFER. The meaning of the format specifiers
kono
parents:
diff changeset
66 is as follows:
kono
parents:
diff changeset
67 %D: a general decl,
kono
parents:
diff changeset
68 %E: an identifier or expression,
kono
parents:
diff changeset
69 %F: a function declaration,
kono
parents:
diff changeset
70 %G: a Gimple call statement,
kono
parents:
diff changeset
71 %K: a CALL_EXPR,
kono
parents:
diff changeset
72 %T: a type.
kono
parents:
diff changeset
73 %V: a list of type qualifiers from a tree.
kono
parents:
diff changeset
74 %v: an explicit list of type qualifiers
kono
parents:
diff changeset
75 %#v: an explicit list of type qualifiers of a function type.
kono
parents:
diff changeset
76
kono
parents:
diff changeset
77 Please notice when called, the `%' part was already skipped by the
kono
parents:
diff changeset
78 diagnostic machinery. */
kono
parents:
diff changeset
79 static bool
kono
parents:
diff changeset
80 c_tree_printer (pretty_printer *pp, text_info *text, const char *spec,
kono
parents:
diff changeset
81 int precision, bool wide, bool set_locus, bool hash,
kono
parents:
diff changeset
82 bool, const char **)
kono
parents:
diff changeset
83 {
kono
parents:
diff changeset
84 tree t = NULL_TREE;
kono
parents:
diff changeset
85 tree name;
kono
parents:
diff changeset
86 // FIXME: the next cast should be a dynamic_cast, when it is permitted.
kono
parents:
diff changeset
87 c_pretty_printer *cpp = (c_pretty_printer *) pp;
kono
parents:
diff changeset
88 pp->padding = pp_none;
kono
parents:
diff changeset
89
kono
parents:
diff changeset
90 if (precision != 0 || wide)
kono
parents:
diff changeset
91 return false;
kono
parents:
diff changeset
92
kono
parents:
diff changeset
93 if (*spec == 'G')
kono
parents:
diff changeset
94 {
kono
parents:
diff changeset
95 percent_G_format (text);
kono
parents:
diff changeset
96 return true;
kono
parents:
diff changeset
97 }
kono
parents:
diff changeset
98
kono
parents:
diff changeset
99 if (*spec == 'K')
kono
parents:
diff changeset
100 {
kono
parents:
diff changeset
101 t = va_arg (*text->args_ptr, tree);
kono
parents:
diff changeset
102 percent_K_format (text, t);
kono
parents:
diff changeset
103 return true;
kono
parents:
diff changeset
104 }
kono
parents:
diff changeset
105
kono
parents:
diff changeset
106 if (*spec != 'v')
kono
parents:
diff changeset
107 {
kono
parents:
diff changeset
108 t = va_arg (*text->args_ptr, tree);
kono
parents:
diff changeset
109 if (set_locus)
kono
parents:
diff changeset
110 text->set_location (0, DECL_SOURCE_LOCATION (t), true);
kono
parents:
diff changeset
111 }
kono
parents:
diff changeset
112
kono
parents:
diff changeset
113 switch (*spec)
kono
parents:
diff changeset
114 {
kono
parents:
diff changeset
115 case 'D':
kono
parents:
diff changeset
116 if (VAR_P (t) && DECL_HAS_DEBUG_EXPR_P (t))
kono
parents:
diff changeset
117 {
kono
parents:
diff changeset
118 t = DECL_DEBUG_EXPR (t);
kono
parents:
diff changeset
119 if (!DECL_P (t))
kono
parents:
diff changeset
120 {
kono
parents:
diff changeset
121 cpp->expression (t);
kono
parents:
diff changeset
122 return true;
kono
parents:
diff changeset
123 }
kono
parents:
diff changeset
124 }
kono
parents:
diff changeset
125 /* FALLTHRU */
kono
parents:
diff changeset
126
kono
parents:
diff changeset
127 case 'F':
kono
parents:
diff changeset
128 if (DECL_NAME (t))
kono
parents:
diff changeset
129 {
kono
parents:
diff changeset
130 pp_identifier (cpp, lang_hooks.decl_printable_name (t, 2));
kono
parents:
diff changeset
131 return true;
kono
parents:
diff changeset
132 }
kono
parents:
diff changeset
133 break;
kono
parents:
diff changeset
134
kono
parents:
diff changeset
135 case 'T':
kono
parents:
diff changeset
136 {
kono
parents:
diff changeset
137 gcc_assert (TYPE_P (t));
kono
parents:
diff changeset
138 struct obstack *ob = pp_buffer (cpp)->obstack;
kono
parents:
diff changeset
139 char *p = (char *) obstack_base (ob);
kono
parents:
diff changeset
140 /* Remember the end of the initial dump. */
kono
parents:
diff changeset
141 int len = obstack_object_size (ob);
kono
parents:
diff changeset
142
kono
parents:
diff changeset
143 name = TYPE_NAME (t);
kono
parents:
diff changeset
144 if (name && TREE_CODE (name) == TYPE_DECL && DECL_NAME (name))
kono
parents:
diff changeset
145 pp_identifier (cpp, lang_hooks.decl_printable_name (name, 2));
kono
parents:
diff changeset
146 else
kono
parents:
diff changeset
147 cpp->type_id (t);
kono
parents:
diff changeset
148
kono
parents:
diff changeset
149 /* If we're printing a type that involves typedefs, also print the
kono
parents:
diff changeset
150 stripped version. But sometimes the stripped version looks
kono
parents:
diff changeset
151 exactly the same, so we don't want it after all. To avoid
kono
parents:
diff changeset
152 printing it in that case, we play ugly obstack games. */
kono
parents:
diff changeset
153 if (TYPE_CANONICAL (t) && t != TYPE_CANONICAL (t))
kono
parents:
diff changeset
154 {
kono
parents:
diff changeset
155 c_pretty_printer cpp2;
kono
parents:
diff changeset
156 /* Print the stripped version into a temporary printer. */
kono
parents:
diff changeset
157 cpp2.type_id (TYPE_CANONICAL (t));
kono
parents:
diff changeset
158 struct obstack *ob2 = cpp2.buffer->obstack;
kono
parents:
diff changeset
159 /* Get the stripped version from the temporary printer. */
kono
parents:
diff changeset
160 const char *aka = (char *) obstack_base (ob2);
kono
parents:
diff changeset
161 int aka_len = obstack_object_size (ob2);
kono
parents:
diff changeset
162 int type1_len = obstack_object_size (ob) - len;
kono
parents:
diff changeset
163
kono
parents:
diff changeset
164 /* If they are identical, bail out. */
kono
parents:
diff changeset
165 if (aka_len == type1_len && memcmp (p + len, aka, aka_len) == 0)
kono
parents:
diff changeset
166 return true;
kono
parents:
diff changeset
167
kono
parents:
diff changeset
168 /* They're not, print the stripped version now. */
kono
parents:
diff changeset
169 pp_c_whitespace (cpp);
kono
parents:
diff changeset
170 pp_left_brace (cpp);
kono
parents:
diff changeset
171 pp_c_ws_string (cpp, _("aka"));
kono
parents:
diff changeset
172 pp_c_whitespace (cpp);
kono
parents:
diff changeset
173 cpp->type_id (TYPE_CANONICAL (t));
kono
parents:
diff changeset
174 pp_right_brace (cpp);
kono
parents:
diff changeset
175 }
kono
parents:
diff changeset
176 return true;
kono
parents:
diff changeset
177 }
kono
parents:
diff changeset
178
kono
parents:
diff changeset
179 case 'E':
kono
parents:
diff changeset
180 if (TREE_CODE (t) == IDENTIFIER_NODE)
kono
parents:
diff changeset
181 pp_identifier (cpp, IDENTIFIER_POINTER (t));
kono
parents:
diff changeset
182 else
kono
parents:
diff changeset
183 cpp->expression (t);
kono
parents:
diff changeset
184 return true;
kono
parents:
diff changeset
185
kono
parents:
diff changeset
186 case 'V':
kono
parents:
diff changeset
187 pp_c_type_qualifier_list (cpp, t);
kono
parents:
diff changeset
188 return true;
kono
parents:
diff changeset
189
kono
parents:
diff changeset
190 case 'v':
kono
parents:
diff changeset
191 pp_c_cv_qualifiers (cpp, va_arg (*text->args_ptr, int), hash);
kono
parents:
diff changeset
192 return true;
kono
parents:
diff changeset
193
kono
parents:
diff changeset
194 default:
kono
parents:
diff changeset
195 return false;
kono
parents:
diff changeset
196 }
kono
parents:
diff changeset
197
kono
parents:
diff changeset
198 pp_string (cpp, _("({anonymous})"));
kono
parents:
diff changeset
199 return true;
kono
parents:
diff changeset
200 }
kono
parents:
diff changeset
201
kono
parents:
diff changeset
202 /* In C and ObjC, all decls have "C" linkage. */
kono
parents:
diff changeset
203 bool
kono
parents:
diff changeset
204 has_c_linkage (const_tree decl ATTRIBUTE_UNUSED)
kono
parents:
diff changeset
205 {
kono
parents:
diff changeset
206 return true;
kono
parents:
diff changeset
207 }
kono
parents:
diff changeset
208
kono
parents:
diff changeset
209 void
kono
parents:
diff changeset
210 c_initialize_diagnostics (diagnostic_context *context)
kono
parents:
diff changeset
211 {
kono
parents:
diff changeset
212 pretty_printer *base = context->printer;
kono
parents:
diff changeset
213 c_pretty_printer *pp = XNEW (c_pretty_printer);
kono
parents:
diff changeset
214 context->printer = new (pp) c_pretty_printer ();
kono
parents:
diff changeset
215
kono
parents:
diff changeset
216 /* It is safe to free this object because it was previously XNEW()'d. */
kono
parents:
diff changeset
217 base->~pretty_printer ();
kono
parents:
diff changeset
218 XDELETE (base);
kono
parents:
diff changeset
219
kono
parents:
diff changeset
220 c_common_diagnostics_set_defaults (context);
kono
parents:
diff changeset
221 diagnostic_format_decoder (context) = &c_tree_printer;
kono
parents:
diff changeset
222 }
kono
parents:
diff changeset
223
kono
parents:
diff changeset
224 int
kono
parents:
diff changeset
225 c_types_compatible_p (tree x, tree y)
kono
parents:
diff changeset
226 {
kono
parents:
diff changeset
227 return comptypes (TYPE_MAIN_VARIANT (x), TYPE_MAIN_VARIANT (y));
kono
parents:
diff changeset
228 }
kono
parents:
diff changeset
229
kono
parents:
diff changeset
230 /* Determine if the type is a vla type for the backend. */
kono
parents:
diff changeset
231
kono
parents:
diff changeset
232 bool
kono
parents:
diff changeset
233 c_vla_unspec_p (tree x, tree fn ATTRIBUTE_UNUSED)
kono
parents:
diff changeset
234 {
kono
parents:
diff changeset
235 return c_vla_type_p (x);
kono
parents:
diff changeset
236 }