diff options
author | Manuel Klimek <klimek@google.com> | 2012-07-31 13:56:54 +0000 |
---|---|---|
committer | Manuel Klimek <klimek@google.com> | 2012-07-31 13:56:54 +0000 |
commit | 98be86038b1e891a05583061c55dfa974150eb2c (patch) | |
tree | d041d4555a73126098095ee3d756390ffcd203b3 /test/Tooling/pch.cpp | |
parent | 94be8ea90795d00fe2a97fea9a9a727911a70997 (diff) |
Fixes a segfault in Tooling when using pch's:
Clear the FileManager's stat cache in between running
translation units, as the stat cache loaded from a pch
is only valid for one compiler invocation.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@161047 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/Tooling/pch.cpp')
-rw-r--r-- | test/Tooling/pch.cpp | 21 |
1 files changed, 21 insertions, 0 deletions
diff --git a/test/Tooling/pch.cpp b/test/Tooling/pch.cpp new file mode 100644 index 0000000000..bfa20d806b --- /dev/null +++ b/test/Tooling/pch.cpp @@ -0,0 +1,21 @@ +// This is a regression test for handling of stat caches within the tooling +// infrastructure. This test reproduces the problem under valgrind: + +// First, create a pch that we can later load. Loading the pch will insert +// a stat cache into the FileManager: +// RUN: %clang -x c++-header %S/Inputs/pch.h -o %t1 + +// Use the generated pch and enforce a subsequent stat miss by by using +// the test file with an unrelated include as second translation unit: +// Do not directly pipe into FileCheck, as that would hide errors from +// valgrind due to pipefail not being set in lit. +// RUN: clang-check "%S/Inputs/pch.cpp" "%s" -- -include-pch %t1 -I "%S" -c >%t2 2>&1 +// RUN: FileCheck %s < %t2 + +#include "Inputs/pch-fail.h" + +// CHECK: Processing + +// FIXME: This is incompatible to -fms-compatibility. +// XFAIL: win32 + |