aboutsummaryrefslogtreecommitdiff
path: root/libcpp/lex.cc
diff options
context:
space:
mode:
authorJoseph Myers <joseph@codesourcery.com>2022-12-07 19:18:06 +0000
committerJoseph Myers <joseph@codesourcery.com>2022-12-07 19:18:06 +0000
commitce53cf7b61ea6bce05570e2fd1f8c10eee308ab0 (patch)
treed347aafe958f5980ac1294dd4d40d8a33041b5b0 /libcpp/lex.cc
parenteb9491baf5a5672888809f8b5932a99d91804a52 (diff)
downloadgcc-ce53cf7b61ea6bce05570e2fd1f8c10eee308ab0.zip
gcc-ce53cf7b61ea6bce05570e2fd1f8c10eee308ab0.tar.gz
gcc-ce53cf7b61ea6bce05570e2fd1f8c10eee308ab0.tar.bz2
preprocessor: Enable __VA_OPT__ for C2x
C2x supports __VA_OPT__, so adjust libcpp not to pedwarn for uses of it (or of not passing any variable arguments to a variable-arguments macro) in standard C2x mode. I didn't try to duplicate existing tests for the details of the feature, just verified -pedantic-errors handling is as expected. And there's a reasonable argument (bug 98859) that __VA_OPT__ shouldn't be diagnosed in older standard modes at all (as opposed to not passing any variable arguments to a variable-arguments macro, for which older versions of the C standard require a diagnostic as a constraint violation); that argument applies to C as much as to C++, but I haven't made any changes in that regard. Bootstrapped with no regressions for x86_64-pc-linux-gnu. libcpp/ * init.cc (lang_defaults): Enable va_opt for STDC2X. * lex.cc (maybe_va_opt_error): Adjust diagnostic message for C. * macro.cc (_cpp_arguments_ok): Update comment. gcc/testsuite/ * gcc.dg/cpp/c11-vararg-1.c, gcc.dg/cpp/c2x-va-opt-1.c: New tests.
Diffstat (limited to 'libcpp/lex.cc')
-rw-r--r--libcpp/lex.cc10
1 files changed, 8 insertions, 2 deletions
diff --git a/libcpp/lex.cc b/libcpp/lex.cc
index b110792..9a21a3e 100644
--- a/libcpp/lex.cc
+++ b/libcpp/lex.cc
@@ -2135,8 +2135,14 @@ maybe_va_opt_error (cpp_reader *pfile)
/* __VA_OPT__ should not be accepted at all, but allow it in
system headers. */
if (!_cpp_in_system_header (pfile))
- cpp_error (pfile, CPP_DL_PEDWARN,
- "__VA_OPT__ is not available until C++20");
+ {
+ if (CPP_OPTION (pfile, cplusplus))
+ cpp_error (pfile, CPP_DL_PEDWARN,
+ "__VA_OPT__ is not available until C++20");
+ else
+ cpp_error (pfile, CPP_DL_PEDWARN,
+ "__VA_OPT__ is not available until C2X");
+ }
}
else if (!pfile->state.va_args_ok)
{