2009-12-16 04:14:24 +08:00
|
|
|
// RUN: %clang_cc1 %s -emit-llvm -o - | FileCheck %s
|
2009-09-09 02:24:21 +08:00
|
|
|
|
2011-01-11 06:34:03 +08:00
|
|
|
// CHECK: @__func__.plainFunction = private unnamed_addr constant [14 x i8] c"plainFunction\00"
|
|
|
|
// CHECK: @__PRETTY_FUNCTION__.plainFunction = private unnamed_addr constant [21 x i8] c"void plainFunction()\00"
|
|
|
|
// CHECK: @__func__.externFunction = private unnamed_addr constant [15 x i8] c"externFunction\00"
|
|
|
|
// CHECK: @__PRETTY_FUNCTION__.externFunction = private unnamed_addr constant [22 x i8] c"void externFunction()\00"
|
|
|
|
// CHECK: @__func__.privateExternFunction = private unnamed_addr constant [22 x i8] c"privateExternFunction\00"
|
|
|
|
// CHECK: @__PRETTY_FUNCTION__.privateExternFunction = private unnamed_addr constant [29 x i8] c"void privateExternFunction()\00"
|
2013-08-26 22:27:34 +08:00
|
|
|
// CHECK: @__func__.__captured_stmt = private unnamed_addr constant [25 x i8] c"functionWithCapturedStmt\00"
|
|
|
|
// CHECK: @__PRETTY_FUNCTION__.__captured_stmt = private unnamed_addr constant [32 x i8] c"void functionWithCapturedStmt()\00"
|
2011-01-11 06:34:03 +08:00
|
|
|
// CHECK: @__func__.staticFunction = private unnamed_addr constant [15 x i8] c"staticFunction\00"
|
|
|
|
// CHECK: @__PRETTY_FUNCTION__.staticFunction = private unnamed_addr constant [22 x i8] c"void staticFunction()\00"
|
2009-09-09 02:24:21 +08:00
|
|
|
|
2009-11-17 16:57:36 +08:00
|
|
|
int printf(const char *, ...);
|
2009-09-09 02:24:21 +08:00
|
|
|
|
|
|
|
void plainFunction() {
|
|
|
|
printf("__func__ %s\n", __func__);
|
|
|
|
printf("__FUNCTION__ %s\n", __FUNCTION__);
|
|
|
|
printf("__PRETTY_FUNCTION__ %s\n\n", __PRETTY_FUNCTION__);
|
|
|
|
}
|
|
|
|
|
|
|
|
extern void externFunction() {
|
|
|
|
printf("__func__ %s\n", __func__);
|
|
|
|
printf("__FUNCTION__ %s\n", __FUNCTION__);
|
|
|
|
printf("__PRETTY_FUNCTION__ %s\n\n", __PRETTY_FUNCTION__);
|
|
|
|
}
|
|
|
|
|
|
|
|
__private_extern__ void privateExternFunction() {
|
|
|
|
printf("__func__ %s\n", __func__);
|
|
|
|
printf("__FUNCTION__ %s\n", __FUNCTION__);
|
|
|
|
printf("__PRETTY_FUNCTION__ %s\n\n", __PRETTY_FUNCTION__);
|
|
|
|
}
|
|
|
|
|
2013-08-26 22:27:34 +08:00
|
|
|
void functionWithCapturedStmt() {
|
|
|
|
#pragma clang __debug captured
|
|
|
|
{
|
|
|
|
printf("__func__ %s\n", __func__);
|
|
|
|
printf("__FUNCTION__ %s\n", __FUNCTION__);
|
|
|
|
printf("__PRETTY_FUNCTION__ %s\n\n", __PRETTY_FUNCTION__);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2009-09-09 02:24:21 +08:00
|
|
|
static void staticFunction() {
|
|
|
|
printf("__func__ %s\n", __func__);
|
|
|
|
printf("__FUNCTION__ %s\n", __FUNCTION__);
|
|
|
|
printf("__PRETTY_FUNCTION__ %s\n\n", __PRETTY_FUNCTION__);
|
|
|
|
}
|
|
|
|
|
|
|
|
int main() {
|
|
|
|
plainFunction();
|
|
|
|
externFunction();
|
|
|
|
privateExternFunction();
|
2013-08-26 22:27:34 +08:00
|
|
|
functionWithCapturedStmt();
|
2009-09-09 02:24:21 +08:00
|
|
|
staticFunction();
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|