blob: 6c94152b737eaae39278ae5dd9a35492cd948f2a [file] [log] [blame]
Daniel Dunbara5728872009-12-15 20:14:24 +00001// RUN: %clang_cc1 %s -emit-llvm -o - | FileCheck %s
Stephen Hines6bcf27b2014-05-29 04:14:42 -07002// RUN: %clang_cc1 -fms-extensions %s -emit-llvm -o - | FileCheck %s
Anders Carlsson3a082d82009-09-08 18:24:21 +00003
Rafael Espindola1257bc62011-01-10 22:34:03 +00004// CHECK: @__func__.plainFunction = private unnamed_addr constant [14 x i8] c"plainFunction\00"
5// CHECK: @__PRETTY_FUNCTION__.plainFunction = private unnamed_addr constant [21 x i8] c"void plainFunction()\00"
6// CHECK: @__func__.externFunction = private unnamed_addr constant [15 x i8] c"externFunction\00"
7// CHECK: @__PRETTY_FUNCTION__.externFunction = private unnamed_addr constant [22 x i8] c"void externFunction()\00"
8// CHECK: @__func__.privateExternFunction = private unnamed_addr constant [22 x i8] c"privateExternFunction\00"
9// CHECK: @__PRETTY_FUNCTION__.privateExternFunction = private unnamed_addr constant [29 x i8] c"void privateExternFunction()\00"
Wei Pan15b26742013-08-26 14:27:34 +000010// CHECK: @__func__.__captured_stmt = private unnamed_addr constant [25 x i8] c"functionWithCapturedStmt\00"
11// CHECK: @__PRETTY_FUNCTION__.__captured_stmt = private unnamed_addr constant [32 x i8] c"void functionWithCapturedStmt()\00"
Rafael Espindola1257bc62011-01-10 22:34:03 +000012// CHECK: @__func__.staticFunction = private unnamed_addr constant [15 x i8] c"staticFunction\00"
13// CHECK: @__PRETTY_FUNCTION__.staticFunction = private unnamed_addr constant [22 x i8] c"void staticFunction()\00"
Anders Carlsson3a082d82009-09-08 18:24:21 +000014
Daniel Dunbar23afaad2009-11-17 08:57:36 +000015int printf(const char *, ...);
Anders Carlsson3a082d82009-09-08 18:24:21 +000016
17void plainFunction() {
18 printf("__func__ %s\n", __func__);
19 printf("__FUNCTION__ %s\n", __FUNCTION__);
20 printf("__PRETTY_FUNCTION__ %s\n\n", __PRETTY_FUNCTION__);
21}
22
23extern void externFunction() {
24 printf("__func__ %s\n", __func__);
25 printf("__FUNCTION__ %s\n", __FUNCTION__);
26 printf("__PRETTY_FUNCTION__ %s\n\n", __PRETTY_FUNCTION__);
27}
28
29__private_extern__ void privateExternFunction() {
30 printf("__func__ %s\n", __func__);
31 printf("__FUNCTION__ %s\n", __FUNCTION__);
32 printf("__PRETTY_FUNCTION__ %s\n\n", __PRETTY_FUNCTION__);
33}
34
Wei Pan15b26742013-08-26 14:27:34 +000035void functionWithCapturedStmt() {
36 #pragma clang __debug captured
37 {
38 printf("__func__ %s\n", __func__);
39 printf("__FUNCTION__ %s\n", __FUNCTION__);
40 printf("__PRETTY_FUNCTION__ %s\n\n", __PRETTY_FUNCTION__);
41 }
42}
43
Anders Carlsson3a082d82009-09-08 18:24:21 +000044static void staticFunction() {
45 printf("__func__ %s\n", __func__);
46 printf("__FUNCTION__ %s\n", __FUNCTION__);
47 printf("__PRETTY_FUNCTION__ %s\n\n", __PRETTY_FUNCTION__);
48}
49
50int main() {
51 plainFunction();
52 externFunction();
53 privateExternFunction();
Wei Pan15b26742013-08-26 14:27:34 +000054 functionWithCapturedStmt();
Anders Carlsson3a082d82009-09-08 18:24:21 +000055 staticFunction();
56
57 return 0;
58}