macro.c (warn_of_redefinition): Suppress warnings for builtins that lack the NODE_WARN flag...

libcpp/ChangeLog:

2014-08-29  Manuel López-Ibáñez  <manu@gcc.gnu.org>

	* macro.c (warn_of_redefinition): Suppress warnings for builtins
	that lack the NODE_WARN flag, unless Wbuiltin-macro-redefined.
	(_cpp_create_definition): Use Wbuiltin-macro-redefined for
	builtins that lack the NODE_WARN flag.
	* directives.c (do_undef): Likewise.
	* init.c (cpp_init_special_builtins): Do not change flags
	depending on Wbuiltin-macro-redefined.


gcc/c-family/ChangeLog:

2014-08-29  Manuel López-Ibáñez  <manu@gcc.gnu.org>

	* c.opt (Wbuiltin-macro-redefined): Use CPP, Var and Init.
	* c-opts.c (c_common_handle_option): Do not handle here.

From-SVN: r214730
parent ef0981b8
2014-08-29 Manuel López-Ibáñez <manu@gcc.gnu.org>
* c.opt (Wbuiltin-macro-redefined): Use CPP, Var and Init.
* c-opts.c (c_common_handle_option): Do not handle here.
2014-08-25 Jason Merrill <jason@redhat.com> 2014-08-25 Jason Merrill <jason@redhat.com>
* c.opt: Change -std=c++1y and -std=gnu++1y to be aliases for * c.opt: Change -std=c++1y and -std=gnu++1y to be aliases for
......
...@@ -385,10 +385,6 @@ c_common_handle_option (size_t scode, const char *arg, int value, ...@@ -385,10 +385,6 @@ c_common_handle_option (size_t scode, const char *arg, int value,
cpp_opts->warn_num_sign_change = value; cpp_opts->warn_num_sign_change = value;
break; break;
case OPT_Wbuiltin_macro_redefined:
cpp_opts->warn_builtin_macro_redefined = value;
break;
case OPT_Wc___compat: case OPT_Wc___compat:
cpp_opts->warn_cxx_operator_names = value; cpp_opts->warn_cxx_operator_names = value;
break; break;
......
...@@ -292,7 +292,7 @@ C ObjC C++ ObjC++ Var(warn_bool_compare) Warning LangEnabledBy(C ObjC C++ ObjC++ ...@@ -292,7 +292,7 @@ C ObjC C++ ObjC++ Var(warn_bool_compare) Warning LangEnabledBy(C ObjC C++ ObjC++
Warn about boolean expression compared with an integer value different from true/false Warn about boolean expression compared with an integer value different from true/false
Wbuiltin-macro-redefined Wbuiltin-macro-redefined
C ObjC C++ ObjC++ Warning C ObjC C++ ObjC++ CPP(warn_builtin_macro_redefined) Var(cpp_warn_builtin_macro_redefined) Init(1) Warning
Warn when a built-in preprocessor macro is undefined or redefined Warn when a built-in preprocessor macro is undefined or redefined
Wc90-c99-compat Wc90-c99-compat
......
2014-08-29 Manuel López-Ibáñez <manu@gcc.gnu.org>
* macro.c (warn_of_redefinition): Suppress warnings for builtins
that lack the NODE_WARN flag, unless Wbuiltin-macro-redefined.
(_cpp_create_definition): Use Wbuiltin-macro-redefined for
builtins that lack the NODE_WARN flag.
* directives.c (do_undef): Likewise.
* init.c (cpp_init_special_builtins): Do not change flags
depending on Wbuiltin-macro-redefined.
2014-08-28 Edward Smith-Rowland <3dw4rd@verizon.net> 2014-08-28 Edward Smith-Rowland <3dw4rd@verizon.net>
PR cpp/23827 - standard C++ should not have hex float preprocessor PR cpp/23827 - standard C++ should not have hex float preprocessor
......
...@@ -610,6 +610,11 @@ do_undef (cpp_reader *pfile) ...@@ -610,6 +610,11 @@ do_undef (cpp_reader *pfile)
if (node->flags & NODE_WARN) if (node->flags & NODE_WARN)
cpp_error (pfile, CPP_DL_WARNING, cpp_error (pfile, CPP_DL_WARNING,
"undefining \"%s\"", NODE_NAME (node)); "undefining \"%s\"", NODE_NAME (node));
else if ((node->flags & NODE_BUILTIN)
&& CPP_OPTION (pfile, warn_builtin_macro_redefined))
cpp_warning_with_line (pfile, CPP_W_BUILTIN_MACRO_REDEFINED,
pfile->directive_line, 0,
"undefining \"%s\"", NODE_NAME (node));
if (CPP_OPTION (pfile, warn_unused_macros)) if (CPP_OPTION (pfile, warn_unused_macros))
_cpp_warn_if_unused_macro (pfile, node, NULL); _cpp_warn_if_unused_macro (pfile, node, NULL);
......
...@@ -470,8 +470,7 @@ cpp_init_special_builtins (cpp_reader *pfile) ...@@ -470,8 +470,7 @@ cpp_init_special_builtins (cpp_reader *pfile)
cpp_hashnode *hp = cpp_lookup (pfile, b->name, b->len); cpp_hashnode *hp = cpp_lookup (pfile, b->name, b->len);
hp->type = NT_MACRO; hp->type = NT_MACRO;
hp->flags |= NODE_BUILTIN; hp->flags |= NODE_BUILTIN;
if (b->always_warn_if_redefined if (b->always_warn_if_redefined)
|| CPP_OPTION (pfile, warn_builtin_macro_redefined))
hp->flags |= NODE_WARN; hp->flags |= NODE_WARN;
hp->value.builtin = (enum cpp_builtin_type) b->value; hp->value.builtin = (enum cpp_builtin_type) b->value;
} }
......
...@@ -2699,13 +2699,12 @@ warn_of_redefinition (cpp_reader *pfile, cpp_hashnode *node, ...@@ -2699,13 +2699,12 @@ warn_of_redefinition (cpp_reader *pfile, cpp_hashnode *node,
if (node->flags & NODE_WARN) if (node->flags & NODE_WARN)
return true; return true;
/* Suppress warnings for builtins that lack the NODE_WARN flag. */ /* Suppress warnings for builtins that lack the NODE_WARN flag,
if (node->flags & NODE_BUILTIN) unless Wbuiltin-macro-redefined. */
{ if (node->flags & NODE_BUILTIN
if (!pfile->cb.user_builtin_macro && (!pfile->cb.user_builtin_macro
|| !pfile->cb.user_builtin_macro (pfile, node)) || !pfile->cb.user_builtin_macro (pfile, node)))
return false; return CPP_OPTION (pfile, warn_builtin_macro_redefined);
}
/* Redefinitions of conditional (context-sensitive) macros, on /* Redefinitions of conditional (context-sensitive) macros, on
the other hand, must be allowed silently. */ the other hand, must be allowed silently. */
...@@ -3181,14 +3180,14 @@ _cpp_create_definition (cpp_reader *pfile, cpp_hashnode *node) ...@@ -3181,14 +3180,14 @@ _cpp_create_definition (cpp_reader *pfile, cpp_hashnode *node)
if (warn_of_redefinition (pfile, node, macro)) if (warn_of_redefinition (pfile, node, macro))
{ {
const int reason = (node->flags & NODE_BUILTIN) const int reason = ((node->flags & NODE_BUILTIN)
&& !(node->flags & NODE_WARN))
? CPP_W_BUILTIN_MACRO_REDEFINED : CPP_W_NONE; ? CPP_W_BUILTIN_MACRO_REDEFINED : CPP_W_NONE;
bool warned;
warned = cpp_pedwarning_with_line (pfile, reason, bool warned =
pfile->directive_line, 0, cpp_pedwarning_with_line (pfile, reason,
"\"%s\" redefined", pfile->directive_line, 0,
NODE_NAME (node)); "\"%s\" redefined", NODE_NAME (node));
if (warned && node->type == NT_MACRO && !(node->flags & NODE_BUILTIN)) if (warned && node->type == NT_MACRO && !(node->flags & NODE_BUILTIN))
cpp_error_with_line (pfile, CPP_DL_NOTE, cpp_error_with_line (pfile, CPP_DL_NOTE,
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment