llvm-project/clang/test/Lexer/string-literal-encoding.c

19 lines
1.0 KiB
C
Raw Normal View History

// RUN: %clang_cc1 -x c++ -std=c++0x -fsyntax-only -verify %s
// This file should be encoded using ISO-8859-1, the string literals should
// contain the ISO-8859-1 encoding for the code points U+00C0 U+00E9 U+00EE
// U+00F5 U+00FC
void f() {
wchar_t const *a = L"<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>"; // expected-error {{illegal character encoding in string literal}}
char16_t const *b = u"<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>"; // expected-error {{illegal character encoding in string literal}}
char32_t const *c = U"<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>"; // expected-error {{illegal character encoding in string literal}}
wchar_t const *d = LR"(<28><><EFBFBD><EFBFBD><EFBFBD>)"; // expected-error {{illegal character encoding in string literal}}
char16_t const *e = uR"(<28><><EFBFBD><EFBFBD><EFBFBD>)"; // expected-error {{illegal character encoding in string literal}}
char32_t const *f = UR"(<28><><EFBFBD><EFBFBD><EFBFBD>)"; // expected-error {{illegal character encoding in string literal}}
char const *g = "<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>"; // expected-warning {{illegal character encoding in string literal}}
char const *h = u8"<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>"; // expected-error {{illegal character encoding in string literal}}
}