From: Reid Kleckner Date: Tue, 23 May 2017 16:09:13 +0000 (+0000) Subject: Add test coverage for recent behavior change in GNU line marker pre-processing X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=8fd9b54c24fd06763856ff5265350446393743c7;p=clang Add test coverage for recent behavior change in GNU line marker pre-processing git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@303642 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/test/Frontend/Inputs/SystemHeaderPrefix/line.h b/test/Frontend/Inputs/SystemHeaderPrefix/line-directive-in-system.h similarity index 100% rename from test/Frontend/Inputs/SystemHeaderPrefix/line.h rename to test/Frontend/Inputs/SystemHeaderPrefix/line-directive-in-system.h diff --git a/test/Frontend/Inputs/line-directive.h b/test/Frontend/Inputs/line-directive.h new file mode 100644 index 0000000000..e05e9f5167 --- /dev/null +++ b/test/Frontend/Inputs/line-directive.h @@ -0,0 +1,2 @@ +#line 10 "foo.h" +foo(); // will warn if not treated as a system header diff --git a/test/Frontend/system-header-line-directive.c b/test/Frontend/system-header-line-directive.c index 16dde643a5..9d4f09885f 100644 --- a/test/Frontend/system-header-line-directive.c +++ b/test/Frontend/system-header-line-directive.c @@ -1,20 +1,23 @@ -// RUN: %clang_cc1 -Wall %s -isystem %S/Inputs/SystemHeaderPrefix -verify -// RUN: %clang_cc1 %s -E -o - -isystem %S/Inputs/SystemHeaderPrefix | FileCheck %s +// RUN: %clang_cc1 -Wall %s -I %S/Inputs -isystem %S/Inputs/SystemHeaderPrefix -verify +// RUN: %clang_cc1 %s -E -o - -I %S/Inputs -isystem %S/Inputs/SystemHeaderPrefix | FileCheck %s #include -#include +#include + +// expected-warning@line-directive.h:* {{type specifier missing, defaults to 'int'}} +#include "line-directive.h" // This tests that "#line" directives in system headers preserve system // header-ness just like GNU line markers that don't have filenames. This was // PR30752. -// expected-no-diagnostics - // CHECK: # {{[0-9]+}} "{{.*}}system-header-line-directive.c" 2 // CHECK: # 1 "{{.*}}noline.h" 1 3 // CHECK: foo(); // CHECK: # 4 "{{.*}}system-header-line-directive.c" 2 -// CHECK: # 1 "{{.*}}line.h" 1 3 +// CHECK: # 1 "{{.*}}line-directive-in-system.h" 1 3 // The "3" below indicates that "foo.h" is considered a system header. // CHECK: # 1 "foo.h" 3 // CHECK: foo(); // CHECK: # {{[0-9]+}} "{{.*}}system-header-line-directive.c" 2 +// CHECK: # 1 "{{.*}}line-directive.h" 1 +// CHECK: # 10 "foo.h"{{$}} diff --git a/test/Preprocessor/line-directive-output.c b/test/Preprocessor/line-directive-output.c index 5c0aef8b32..caeb88dd85 100644 --- a/test/Preprocessor/line-directive-output.c +++ b/test/Preprocessor/line-directive-output.c @@ -76,3 +76,10 @@ extern int z; // CHECK: # 50 "a\n.c" # 50 "a\012.c" + +# 1 "system.h" 3 +# 2 +void sys_foo(void); +// CHECK: # 1 "system.h" 3 +// CHECK-NEXT: # 2 "system.h" 3 +// CHECK-NEXT: void sys_foo(void);