blob: e5d242d67758f2624bf4a1b42f4f0de0a0b5c0d0 [file] [log] [blame]
// RUN: %clang_extdef_map %s -- | FileCheck --implicit-check-not "c:@y" --implicit-check-not "c:@z" %s
// RUN: %clang -emit-ast %s -o %t.ast
// RUN: %clang_extdef_map %t.ast -- | FileCheck --implicit-check-not "c:@y" --implicit-check-not "c:@z" %s
int f(int) {
return 0;
}
// CHECK-DAG: 9:c:@F@f#I#
extern const int x = 5;
// CHECK-DAG: 4:c:@x
// Non-const variables should not be collected.
int y = 5;
// In C++, const implies internal linkage, so not collected.
const int z = 5;
struct S {
int a;
};
extern S const s = {.a = 2};
// CHECK-DAG: 4:c:@s
struct SF {
const int a;
};
extern const SF sf = {.a = 2};
// CHECK-DAG: 5:c:@sf
struct SStatic {
static const int a = 4;
};
const int SStatic::a;
// CHECK-DAG: 14:c:@S@SStatic@a
extern int const arr[5] = { 0, 1 };
// CHECK-DAG: 6:c:@arr
union U {
const int a;
const unsigned int b;
};
extern const U u = {.a = 6};
// CHECK-DAG: 4:c:@u
// No USR can be generated for this.
// Check for no crash in this case.
static union {
float uf;
const int ui;
};
void f(int (*)(char));
void f(bool (*)(char));
struct G {
G() {
f([](char) -> int { return 42; });
// CHECK-DAG: 41:c:@S@G@F@G#@Sa@F@operator int (*)(char)#1
f([](char) -> bool { return true; });
// CHECK-DAG: 42:c:@S@G@F@G#@Sa@F@operator bool (*)(char)#1
}
};