diff options
Diffstat (limited to 'test/ASTMerge/class')
-rw-r--r-- | test/ASTMerge/class/Inputs/class1.cpp | 48 | ||||
-rw-r--r-- | test/ASTMerge/class/Inputs/class2.cpp | 40 | ||||
-rw-r--r-- | test/ASTMerge/class/test.cpp | 24 |
3 files changed, 0 insertions, 112 deletions
diff --git a/test/ASTMerge/class/Inputs/class1.cpp b/test/ASTMerge/class/Inputs/class1.cpp deleted file mode 100644 index 2bd5503ecf..0000000000 --- a/test/ASTMerge/class/Inputs/class1.cpp +++ /dev/null @@ -1,48 +0,0 @@ -struct A { - public: - int x; -}; - -struct B : A { - float y; - float foo(); -}; - -struct C { - C(int i = 10); - C(const C&); - C &operator=(C&); - ~C(); -}; - -enum E { - b = 1 -}; - -//Friend import tests -void f(); -int g(int a); -struct X; -struct Y; - -struct F1 { -public: - int x; - friend struct X; - friend int g(int); - friend void f(); -}; - -struct F2 { -public: - int x; - friend struct X; - friend void f(); -}; - -struct F3 { -public: - int x; - friend int g(int); - friend void f(); -}; diff --git a/test/ASTMerge/class/Inputs/class2.cpp b/test/ASTMerge/class/Inputs/class2.cpp deleted file mode 100644 index 6fe38b9206..0000000000 --- a/test/ASTMerge/class/Inputs/class2.cpp +++ /dev/null @@ -1,40 +0,0 @@ -struct A { - public: - int x; -}; - -struct B : A { - int y; - int foo(); -}; - -enum E { - a = 0, - b = 1 -}; - -//Friend import tests -void f(); -int g(int a); -struct X; -struct Y; - -struct F1 { -public: - int x; - friend struct X; - friend int g(int); - friend void f(); -}; - -struct F2 { -public: - int x; - friend struct X; -}; - -struct F3 { -public: - int x; - friend void f(); -}; diff --git a/test/ASTMerge/class/test.cpp b/test/ASTMerge/class/test.cpp deleted file mode 100644 index ba553af407..0000000000 --- a/test/ASTMerge/class/test.cpp +++ /dev/null @@ -1,24 +0,0 @@ -// RUN: %clang_cc1 -emit-pch -o %t.1.ast %S/Inputs/class1.cpp -// RUN: %clang_cc1 -emit-pch -o %t.2.ast %S/Inputs/class2.cpp -// RUN: %clang_cc1 -ast-merge %t.1.ast -ast-merge %t.2.ast -fsyntax-only %s 2>&1 | FileCheck %s -// RUN: %clang_cc1 -ast-merge %t.1.ast -ast-merge %t.2.ast -fsyntax-only %s 2>&1 -Wno-odr -Werror - -// CHECK: class1.cpp:6:8: warning: type 'B' has incompatible definitions in different translation units -// CHECK: class1.cpp:7:9: note: field 'y' has type 'float' here -// CHECK: class2.cpp:7:7: note: field 'y' has type 'int' here - -// FIXME: we should also complain about mismatched types on the method - -// CHECK: class1.cpp:18:6: warning: type 'E' has incompatible definitions in different translation units -// CHECK: class1.cpp:19:3: note: enumerator 'b' with value 1 here -// CHECK: class2.cpp:12:3: note: enumerator 'a' with value 0 here - -// CHECK: class1.cpp:43:8: warning: type 'F3' has incompatible definitions in different translation units -// CHECK: class1.cpp:46:3: note: friend declared here -// CHECK: class2.cpp:36:8: note: no corresponding friend here - -// CHECK: class1.cpp:36:8: warning: type 'F2' has incompatible definitions in different translation units -// CHECK: class1.cpp:39:3: note: friend declared here -// CHECK: class2.cpp:30:8: note: no corresponding friend here - -// CHECK: 4 warnings generated. |