
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
30 lines
773 B
C++
30 lines
773 B
C++
// RUN: %clang_cc1 -no-opaque-pointers -emit-llvm %s -o - | FileCheck %s
|
|
|
|
namespace Common {
|
|
enum RenderMode {
|
|
kRenderEGA,
|
|
kRenderCGA
|
|
};
|
|
class C;
|
|
class A {
|
|
A();
|
|
C *_vm;
|
|
unsigned char _highlightColorTableVGA[];
|
|
static const unsigned char b[];
|
|
};
|
|
// CHECK: [[Common_A_b:@[^ ]+]] = {{(dso_local )?}}constant [1 x i8] zeroinitializer
|
|
class B {
|
|
public:
|
|
Common::RenderMode _configRenderMode;
|
|
};
|
|
class C : public B {};
|
|
A::A() {
|
|
0 == Common::kRenderCGA || _vm->_configRenderMode == Common::kRenderEGA
|
|
? b
|
|
: _highlightColorTableVGA;
|
|
// Make sure the PHI value is casted correctly to the PHI type
|
|
// CHECK: %{{.*}} = phi [0 x i8]* [ bitcast ([1 x i8]* [[Common_A_b]] to [0 x i8]*), %{{.*}} ], [ %{{.*}}, %{{.*}} ]
|
|
}
|
|
const unsigned char A::b[] = { 0 };
|
|
}
|