1 /* Declarations and definitions dealing with attribute handling.
2 Copyright (C) 2013-2020 Free Software Foundation, Inc.
4 This file is part of GCC.
6 GCC is free software; you can redistribute it and/or modify it under
7 the terms of the GNU General Public License as published by the Free
8 Software Foundation; either version 3, or (at your option) any later
11 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
12 WARRANTY; without even the implied warranty of MERCHANTABILITY or
13 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16 You should have received a copy of the GNU General Public License
17 along with GCC; see the file COPYING3. If not see
18 <http://www.gnu.org/licenses/>. */
23 extern const struct attribute_spec
*lookup_attribute_spec (const_tree
);
24 extern void init_attributes (void);
26 /* Process the attributes listed in ATTRIBUTES and install them in *NODE,
27 which is either a DECL (including a TYPE_DECL) or a TYPE. If a DECL,
28 it should be modified in place; if a TYPE, a copy should be created
29 unless ATTR_FLAG_TYPE_IN_PLACE is set in FLAGS. FLAGS gives further
30 information, in the form of a bitwise OR of flags in enum attribute_flags
31 from tree.h. Depending on these flags, some attributes may be
32 returned to be applied at a later stage (for example, to apply
33 a decl attribute to the declaration rather than to its type). */
34 extern tree
decl_attributes (tree
*, tree
, int, tree
= NULL_TREE
);
36 extern bool cxx11_attribute_p (const_tree
);
37 extern tree
get_attribute_name (const_tree
);
38 extern tree
get_attribute_namespace (const_tree
);
39 extern void apply_tm_attr (tree
, tree
);
40 extern tree
make_attribute (const char *, const char *, tree
);
42 extern struct scoped_attributes
* register_scoped_attributes (const struct attribute_spec
*,
45 extern char *sorted_attr_string (tree
);
46 extern bool common_function_versions (tree
, tree
);
47 extern char *make_unique_name (tree
, const char *, bool);
48 extern tree
make_dispatcher_decl (const tree
);
49 extern bool is_function_default_version (const tree
);
51 /* Return a type like TTYPE except that its TYPE_ATTRIBUTES
54 Such modified types already made are recorded so that duplicates
57 extern tree
build_type_attribute_variant (tree
, tree
);
58 extern tree
build_decl_attribute_variant (tree
, tree
);
59 extern tree
build_type_attribute_qual_variant (tree
, tree
, int);
61 extern bool attribute_value_equal (const_tree
, const_tree
);
63 /* Return 0 if the attributes for two types are incompatible, 1 if they
64 are compatible, and 2 if they are nearly compatible (which causes a
65 warning to be generated). */
66 extern int comp_type_attributes (const_tree
, const_tree
);
68 /* Default versions of target-overridable functions. */
69 extern tree
merge_decl_attributes (tree
, tree
);
70 extern tree
merge_type_attributes (tree
, tree
);
72 /* Remove any instances of attribute ATTR_NAME in LIST and return the
75 extern tree
remove_attribute (const char *, tree
);
77 /* Given two attributes lists, return a list of their union. */
79 extern tree
merge_attributes (tree
, tree
);
81 /* Duplicate all attributes with name NAME in ATTR list to *ATTRS if
82 they are missing there. */
84 extern void duplicate_one_attribute (tree
*, tree
, const char *);
86 /* Duplicate all attributes from user DECL to the corresponding
87 builtin that should be propagated. */
89 extern void copy_attributes_to_builtin (tree
);
91 /* Given two Windows decl attributes lists, possibly including
92 dllimport, return a list of their union . */
93 extern tree
merge_dllimport_decl_attributes (tree
, tree
);
95 /* Handle a "dllimport" or "dllexport" attribute. */
96 extern tree
handle_dll_attribute (tree
*, tree
, tree
, int, bool *);
98 extern int attribute_list_equal (const_tree
, const_tree
);
99 extern int attribute_list_contained (const_tree
, const_tree
);
101 /* The backbone of lookup_attribute(). ATTR_LEN is the string length
102 of ATTR_NAME, and LIST is not NULL_TREE.
104 The function is called from lookup_attribute in order to optimize
106 extern tree
private_lookup_attribute (const char *attr_name
, size_t attr_len
,
109 extern unsigned decls_mismatched_attributes (tree
, tree
, tree
,
113 extern void maybe_diag_alias_attributes (tree
, tree
);
115 /* For a given IDENTIFIER_NODE, strip leading and trailing '_' characters
116 so that we have a canonical form of attribute names. */
119 canonicalize_attr_name (tree attr_name
)
121 const size_t l
= IDENTIFIER_LENGTH (attr_name
);
122 const char *s
= IDENTIFIER_POINTER (attr_name
);
124 if (l
> 4 && s
[0] == '_' && s
[1] == '_' && s
[l
- 1] == '_' && s
[l
- 2] == '_')
125 return get_identifier_with_length (s
+ 2, l
- 4);
130 /* Compare attribute identifiers ATTR1 and ATTR2 with length ATTR1_LEN and
134 cmp_attribs (const char *attr1
, size_t attr1_len
,
135 const char *attr2
, size_t attr2_len
)
137 return attr1_len
== attr2_len
&& strncmp (attr1
, attr2
, attr1_len
) == 0;
140 /* Compare attribute identifiers ATTR1 and ATTR2. */
143 cmp_attribs (const char *attr1
, const char *attr2
)
145 return cmp_attribs (attr1
, strlen (attr1
), attr2
, strlen (attr2
));
148 /* Given an identifier node IDENT and a string ATTR_NAME, return true
149 if the identifier node is a valid attribute name for the string. */
152 is_attribute_p (const char *attr_name
, const_tree ident
)
154 return cmp_attribs (attr_name
, strlen (attr_name
),
155 IDENTIFIER_POINTER (ident
), IDENTIFIER_LENGTH (ident
));
158 /* Given an attribute name ATTR_NAME and a list of attributes LIST,
159 return a pointer to the attribute's list element if the attribute
160 is part of the list, or NULL_TREE if not found. If the attribute
161 appears more than once, this only returns the first occurrence; the
162 TREE_CHAIN of the return value should be passed back in if further
163 occurrences are wanted. ATTR_NAME must be in the form 'text' (not
167 lookup_attribute (const char *attr_name
, tree list
)
169 gcc_checking_assert (attr_name
[0] != '_');
170 /* In most cases, list is NULL_TREE. */
171 if (list
== NULL_TREE
)
175 size_t attr_len
= strlen (attr_name
);
176 /* Do the strlen() before calling the out-of-line implementation.
177 In most cases attr_name is a string constant, and the compiler
178 will optimize the strlen() away. */
179 return private_lookup_attribute (attr_name
, attr_len
, list
);
183 /* Given an attribute name ATTR_NAME and a list of attributes LIST,
184 return a pointer to the attribute's list first element if the attribute
185 starts with ATTR_NAME. ATTR_NAME must be in the form 'text' (not
189 lookup_attribute_by_prefix (const char *attr_name
, tree list
)
191 gcc_checking_assert (attr_name
[0] != '_');
192 /* In most cases, list is NULL_TREE. */
193 if (list
== NULL_TREE
)
197 size_t attr_len
= strlen (attr_name
);
200 size_t ident_len
= IDENTIFIER_LENGTH (get_attribute_name (list
));
202 if (attr_len
> ident_len
)
204 list
= TREE_CHAIN (list
);
208 const char *p
= IDENTIFIER_POINTER (get_attribute_name (list
));
209 gcc_checking_assert (attr_len
== 0 || p
[0] != '_');
211 if (strncmp (attr_name
, p
, attr_len
) == 0)
214 list
= TREE_CHAIN (list
);
221 /* Description of a function argument declared with attribute access.
222 Used as an "iterator" over all such arguments in a function declaration
227 /* The attribute pointer argument. */
229 /* The size of the pointed-to object or NULL when not specified. */
232 /* The zero-based number of each of the formal function arguments. */
236 /* The access mode. */
237 enum access_mode
{ none
, read_only
, write_only
, read_write
};
241 /* Used to define rdwr_map below. */
242 struct rdwr_access_hash
: int_hash
<int, -1> { };
244 /* A mapping between argument number corresponding to attribute access
245 mode (read_only, write_only, or read_write) and operands. */
247 typedef hash_map
<rdwr_access_hash
, attr_access
> rdwr_map
;
249 extern void init_attr_rdwr_indices (rdwr_map
*, tree
);
251 #endif // GCC_ATTRIBS_H