diff options
author | Joseph Myers <jsm28@cam.ac.uk> | 2001-10-02 08:19:47 +0100 |
---|---|---|
committer | Joseph Myers <jsm28@gcc.gnu.org> | 2001-10-02 08:19:47 +0100 |
commit | 80a497e4e967ad5cdf59a1c4d2be2fdbba14ea3f (patch) | |
tree | 08f1b7a84cfb385dccaaf67b7162f37545d3fd09 /gcc/c-common.c | |
parent | b3b5d92c88835a1a64eae771baf053ff4c98dec7 (diff) | |
download | gcc-80a497e4e967ad5cdf59a1c4d2be2fdbba14ea3f.zip gcc-80a497e4e967ad5cdf59a1c4d2be2fdbba14ea3f.tar.gz gcc-80a497e4e967ad5cdf59a1c4d2be2fdbba14ea3f.tar.bz2 |
c-common.c (c_format_attribute_table): Make format and format_arg attributes apply to function types rather than to decls.
* c-common.c (c_format_attribute_table): Make format and
format_arg attributes apply to function types rather than to
decls.
(is_valid_printf_arglist): Construct an attribute list and pass
that to check_function_format rather than a name.
* c-common.h (check_function_format): Adjust prototype.
* c-decl.c (duplicate_decls): Preserve attributes from type of
built-in decl when allowing for harmless conflict in types.
* c-format.c (record_function_format,
record_international_format, function_format_list,
international_format_info, international_format_list): Remove.
(function_format_info): Remove next, name and assembler_name.
Make format_num and first_arg_num be unsigned HOST_WIDE_INT.
(decode_format_attr): New.
(handle_format_attribute): Handle receiving a type rather than a
decl. Call decode_format_attr. Store format information in a
function_format_info.
(handle_format_arg_attribute): Correct comment. Handle receiving
a type rather than a decl. Use unsigned HOST_WIDE_INT for
arg_num.
(check_format_info_recurse, check_format_info_main): Take argument
numbers as unsigned HOST_WIDE_INT.
(check_function_format): Take a list of attributes from the
function type rather than a name or assembler name. Check for
format attributes in that list and the attributes on the type of
the current function rather than looking through
function_format_list.
(check_format_info): Use unsigned HOST_WIDE_INT for argument
numbers.
(check_format_info_recurse): Take format_arg attributes from the
type of the function calls rather than using
international_format_list. Allow for multiple format_arg
attributes.
* c-typeck.c (build_function_call): Pass type attributes to
check_function_format rather than name or assembler name. Don't
require there to be a name or assembler name to check formats.
cp:
* call.c (build_over_call), typeck.c (build_function_call_real):
Pass type attributes to check_function_format rather than name or
assembler name. Don't require there to be a name or assembler
name to check formats.
testsuite:
* g++.dg/warn/format2.C, gcc.dg/format/attr-7.c,
gcc.dg/format/multattr-1.c, gcc.dg/format/multattr-2.c,
gcc.dg/format/multattr-3.c: New tests.
* gcc.dg/format/attr-3.c: Update expected error texts. Remove
tests for format attributes on function pointers being rejected.
From-SVN: r45945
Diffstat (limited to 'gcc/c-common.c')
-rw-r--r-- | gcc/c-common.c | 19 |
1 files changed, 14 insertions, 5 deletions
diff --git a/gcc/c-common.c b/gcc/c-common.c index a3314ff..e6c81c3 100644 --- a/gcc/c-common.c +++ b/gcc/c-common.c @@ -2329,9 +2329,10 @@ c_alignof_expr (expr) static const struct attribute_spec c_format_attribute_table[] = { - { "format", 3, 3, true, false, false, + /* { name, min_len, max_len, decl_req, type_req, fn_type_req, handler } */ + { "format", 3, 3, false, true, true, handle_format_attribute }, - { "format_arg", 1, 1, true, false, false, + { "format_arg", 1, 1, false, true, true, handle_format_arg_attribute }, { NULL, 0, 0, false, false, false, NULL } }; @@ -3551,14 +3552,22 @@ is_valid_printf_arglist (arglist) /* Save this value so we can restore it later. */ const int SAVE_pedantic = pedantic; int diagnostic_occurred = 0; + tree attrs; /* Set this to a known value so the user setting won't affect code generation. */ pedantic = 1; /* Check to make sure there are no format specifier errors. */ - check_function_format (&diagnostic_occurred, - maybe_get_identifier("printf"), - NULL_TREE, arglist); + attrs = tree_cons (get_identifier ("format"), + tree_cons (NULL_TREE, + get_identifier ("printf"), + tree_cons (NULL_TREE, + integer_one_node, + tree_cons (NULL_TREE, + build_int_2 (2, 0), + NULL_TREE))), + NULL_TREE); + check_function_format (&diagnostic_occurred, attrs, arglist); /* Restore the value of `pedantic'. */ pedantic = SAVE_pedantic; |