mirror of
https://github.com/llvm/llvm-project.git
synced 2025-05-03 20:26:06 +00:00

-trigraphs is now an alias for -ftrigraphs. -fno-trigraphs makes it possible to explicitly disable trigraphs, which couldn't be done before. clang -std=c++11 -fno-trigraphs now builds without GNU extensions, but with trigraphs disabled. Previously, trigraphs were only disabled in GNU modes or with -std=c++1z. Make the new -f flags the cc1 interface too. This requires changing -trigraphs to -ftrigraphs in a few cc1 tests. Related to PR21974. llvm-svn: 224790
18 lines
813 B
C++
18 lines
813 B
C++
// RUN: %clang_cc1 -DSTDCPP11 -std=c++11 -verify -fsyntax-only %s
|
|
// RUN: %clang_cc1 -DSTDGNU11 -std=gnu++11 -verify -fsyntax-only %s
|
|
// RUN: %clang_cc1 -DSTDGNU11TRI -ftrigraphs -std=gnu++11 -verify -fsyntax-only %s
|
|
// RUN: %clang_cc1 -DSTDCPP17 -std=c++1z -verify -fsyntax-only %s
|
|
// RUN: %clang_cc1 -DSTDCPP17TRI -ftrigraphs -std=c++1z -verify -fsyntax-only %s
|
|
// RUN: %clang_cc1 -DMSCOMPAT -fms-compatibility -std=c++11 -verify -fsyntax-only %s
|
|
|
|
void foo() {
|
|
#if defined(NOFLAGS) || defined(STDCPP11) || defined(STDGNU11TRI) || \
|
|
defined(STDCPP17TRI)
|
|
const char c[] = "??/n"; // expected-warning{{trigraph converted to '\' character}}
|
|
#elif defined(STDGNU11) || defined(STDCPP17) || defined(MSCOMPAT)
|
|
const char c[] = "??/n"; // expected-warning{{trigraph ignored}}
|
|
#else
|
|
#error Not handled.
|
|
#endif
|
|
}
|