
As outlined in a previous RFC, the test/ASTMerge/Inputs folder is getting full and the tests are starting to become interdependent. This is undesirable because - it makes it harder to write new tests - it makes it harder to figure out at a glance what old tests are doing, and - it adds the risk of breaking one test while changing a different one, because of the interdependencies. To fix this, according to the conversation in the RFC, I have changed the layout from a.c Inputs/a1.c Inputs/a2.c to a/test.c a/Inputs/a1.c a/Inputs/a2.c for all existing tests. I have also eliminated interdependencies by replicating the input files for each test that uses them. https://reviews.llvm.org/D26571 llvm-svn: 287129
16 lines
1.1 KiB
C
16 lines
1.1 KiB
C
// RUN: %clang_cc1 -emit-pch -o %t.1.ast %S/Inputs/function1.c
|
|
// RUN: %clang_cc1 -emit-pch -o %t.2.ast %S/Inputs/function2.c
|
|
// RUN: not %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 -verify %s
|
|
|
|
// CHECK: function2.c:3:6: error: external function 'f1' declared with incompatible types in different translation units ('void (Int, double)' (aka 'void (int, double)') vs. 'void (int, float)')
|
|
// CHECK: function1.c:2:6: note: declared here with type 'void (int, float)'
|
|
// CHECK: function2.c:5:6: error: external function 'f3' declared with incompatible types in different translation units ('void (int)' vs. 'void (void)')
|
|
// CHECK: function1.c:4:6: note: declared here with type 'void (void)'
|
|
// CHECK: 2 errors generated
|
|
|
|
// expected-error@Inputs/function2.c:3 {{external function 'f1' declared with incompatible types}}
|
|
// expected-note@Inputs/function1.c:2 {{declared here}}
|
|
// expected-error@Inputs/function2.c:5 {{external function 'f3' declared with incompatible types}}
|
|
// expected-note@Inputs/function1.c:4 {{declared here}}
|