40 lines
2.0 KiB
C
40 lines
2.0 KiB
C
// RUN: not %clang_cc1 -fsyntax-only -fmessage-length=75 -o /dev/null -x c < %s 2>&1 | FileCheck %s -strict-whitespace
|
||
// REQUIRES: utf8-capable-terminal
|
||
|
||
// Test case for the text diagnostics source column conversion crash.
|
||
|
||
// This test case tries to check the error diagnostic message printer, which is
|
||
// responsible to create the code snippet shorter than the message-length (in
|
||
// number of columns.)
|
||
//
|
||
// The error diagnostic message printer should be able to handle the non-ascii
|
||
// characters without any segmentation fault or assertion failure. If your
|
||
// changes to clang frontend crashes this case, it is likely that you are mixing
|
||
// column index with byte index which are two totally different concepts.
|
||
|
||
// NOTE: This file is encoded in UTF-8 and intentionally contains some
|
||
// non-ASCII characters.
|
||
|
||
__attribute__((format(printf, 1, 2)))
|
||
extern int printf(const char *fmt, ...);
|
||
|
||
void test1(Unknown* b); // αααα αααα αααα αααα αααα αααα αααα αααα αααα αααα αααα
|
||
// CHECK: unknown type name 'Unknown'
|
||
// CHECK-NEXT: void test1(Unknown* b); // αααα αααα αααα αααα αααα αααα αααα ααα...
|
||
// CHECK-NEXT: {{^ \^$}}
|
||
|
||
void test2(Unknown* b); // αααα αααα αααα αααα αααα αααα αααα αααα αααα
|
||
|
||
// CHECK: unknown type name 'Unknown'
|
||
// CHECK-NEXT: void test2(Unknown* b); // αααα αααα αααα αααα αααα αααα αααα αααα αααα
|
||
// CHECK-NEXT: {{^ \^$}}
|
||
|
||
void test3() {
|
||
/* αααα αααα αααα αααα αααα αααα αααα αααα αααα αααα */ printf("%d", "s");
|
||
}
|
||
// CHECK: format specifies type 'int' but the argument has
|
||
// CHECK: type 'char *'
|
||
// CHECK-NEXT: ...αααα αααα αααα αααα αααα αααα αααα αααα αααα */ printf("%d", "s");
|
||
// CHECK-NEXT: {{^ ~~ \^~~$}}
|
||
// CHECK-NEXT: {{^ %s$}}
|