[clang][modules] Don't prevent translation of FW_Private includes when explicitly...
[llvm-project.git] / clang / test / CodeGenCXX / attr-annotate2.cpp
blobdca6c009d107aded2f287bbee14031e85c76bd22
1 // NOTE: Assertions have been autogenerated by utils/update_cc_test_checks.py
2 // RUN: %clang_cc1 %s -S -emit-llvm -triple x86_64-unknown-linux-gnu -o - | FileCheck %s
4 // CHECK: @[[STR:.*]] = private unnamed_addr constant [45 x i8] c"_Generic selection expression should be fine\00", section "llvm.metadata"
5 // CHECK-NEXT: @[[FILENAME:.*]] = private unnamed_addr constant {{.*}}, section "llvm.metadata"
6 // CHECK-NEXT: @[[ARGS:.*]] = private unnamed_addr constant { i32 } zeroinitializer, section "llvm.metadata"
8 // CHECK-LABEL: @_Z1fv(
9 // CHECK-NEXT: entry:
10 // CHECK-NEXT: [[N:%.*]] = alloca i32, align 4
11 // CHECK-NEXT: [[J:%.*]] = alloca i32, align 4
12 // CHECK-NEXT: store i32 10, ptr [[N]], align 4
13 // CHECK-NEXT: call void @llvm.var.annotation.p0.p0(ptr [[J]], ptr @[[STR]], ptr @[[FILENAME]], i32 {{.*}}, ptr @[[ARGS]])
14 // CHECK-NEXT: store i32 0, ptr [[J]], align 4
15 // CHECK-NEXT: ret void
17 void f() {
18 int n = 10;
19 [[clang::annotate("_Generic selection expression should be fine", _Generic(n, int : 0, default : 1))]]
20 int j = 0; // second arg should resolve to 0 fine