mirror of
https://github.com/llvm/llvm-project.git
synced 2025-04-26 12:06: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
714 B
C++
23 lines
714 B
C++
// RUN: %clang_cc1 -no-opaque-pointers %s -fno-rtti-data -triple=i386-pc-win32 -o - -emit-llvm | FileCheck %s
|
|
|
|
// vftable shouldn't have RTTI data in it.
|
|
// CHECK-NOT: @"??_R4S@@6B@"
|
|
// CHECK: @"??_7S@@6B@" = linkonce_odr unnamed_addr constant { [1 x i8*] } { [1 x i8*] [i8* bitcast ({{.*}} @"??_GS@@UAEPAXI@Z" to i8*)] }, comdat
|
|
|
|
struct type_info;
|
|
namespace std { using ::type_info; }
|
|
|
|
struct S {
|
|
virtual ~S();
|
|
} s;
|
|
|
|
struct U : S {
|
|
virtual ~U();
|
|
};
|
|
|
|
extern S *getS();
|
|
|
|
const std::type_info &ti = typeid(*getS());
|
|
const U &u = dynamic_cast<U &>(*getS());
|
|
// CHECK: call i8* @__RTDynamicCast(i8* %{{.+}}, i32 0, i8* bitcast ({{.*}} @"??_R0?AUS@@@8" to i8*), i8* bitcast ({{.*}} @"??_R0?AUU@@@8" to i8*), i32 1)
|