mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-26 22:16:06 +00:00

This adds -no-opaque-pointers to clang tests whose output will change when opaque pointers are enabled by default. This is intended to be part of the migration approach described in https://discourse.llvm.org/t/enabling-opaque-pointers-by-default/61322/9. The patch has been produced by replacing %clang_cc1 with %clang_cc1 -no-opaque-pointers for tests that fail with opaque pointers enabled. Worth noting that this doesn't cover all tests, there's a remaining ~40 tests not using %clang_cc1 that will need a followup change. Differential Revision: https://reviews.llvm.org/D123115
23 lines
777 B
C++
23 lines
777 B
C++
// RUN: %clang_cc1 -no-opaque-pointers -o - -emit-llvm -triple x86_64-linux-pc %s | FileCheck %s
|
|
int(&&intu_rvref)[] {1,2,3,4};
|
|
// CHECK: @_ZGR10intu_rvref_ = internal global [4 x i32] [i32 1, i32 2, i32 3, i32 4]
|
|
// CHECK: @intu_rvref ={{.*}} constant [4 x i32]* @_ZGR10intu_rvref_
|
|
|
|
void foo() {
|
|
static const int(&&intu_rvref)[] {1,2,3,4};
|
|
// CHECK: @_ZZ3foovE10intu_rvref = internal constant [4 x i32]* @_ZGRZ3foovE10intu_rvref_
|
|
// CHECK: @_ZGRZ3foovE10intu_rvref_ = internal constant [4 x i32] [i32 1, i32 2, i32 3, i32 4]
|
|
}
|
|
|
|
// Example given on review, ensure this doesn't crash as well.
|
|
constexpr int f() {
|
|
// CHECK: i32 @_Z1fv()
|
|
int(&&intu_rvref)[]{1, 2, 3, 4};
|
|
// CHECK: %{{.*}} = alloca [4 x i32]*
|
|
return intu_rvref[2];
|
|
}
|
|
|
|
void use_f() {
|
|
int i = f();
|
|
}
|