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
33 lines
751 B
C++
33 lines
751 B
C++
// RUN: %clang_cc1 -no-opaque-pointers -std=c++14 %s -triple=x86_64-linux -emit-llvm -o - | FileCheck %s
|
|
|
|
struct f {
|
|
void operator()() const {}
|
|
};
|
|
|
|
template <typename T> auto vtemplate = f{};
|
|
|
|
int main() { vtemplate<int>(); }
|
|
|
|
// CHECK: @_Z9vtemplateIiE = linkonce_odr global %struct.f undef, comdat
|
|
|
|
// CHECK: define{{.*}} i32 @main()
|
|
// CHECK: call void @_ZNK1fclEv(%struct.f* {{[^,]*}} @_Z9vtemplateIiE)
|
|
|
|
template <typename>
|
|
struct pack {
|
|
template <typename T>
|
|
constexpr static auto some_boolean_cx_value = true;
|
|
};
|
|
|
|
auto usage() {
|
|
return pack<char>::some_boolean_cx_value<int>;
|
|
}
|
|
|
|
// CHECK: define{{.*}} i1 @_Z5usagev()
|
|
|
|
auto otherusage() {
|
|
return pack<char>{}.some_boolean_cx_value<int>;
|
|
}
|
|
|
|
// CHECK: define{{.*}} i1 @_Z10otherusagev()
|