diff options
author | David Blaikie <dblaikie@gmail.com> | 2012-06-14 17:36:05 +0000 |
---|---|---|
committer | David Blaikie <dblaikie@gmail.com> | 2012-06-14 17:36:05 +0000 |
commit | bae2b31822e3c2139b5f8fbb127e4c5674cce6db (patch) | |
tree | 7adc0d8169f76c980acddde989b0366edb6e489c | |
parent | 60ad16b7e24cdb88c577c107b69da85458000858 (diff) |
Fix crash on missing header in -rewrite-includes.
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@158459 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Rewrite/InclusionRewriter.cpp | 3 | ||||
-rw-r--r-- | test/Frontend/rewrite-includes-missing.c | 7 |
2 files changed, 9 insertions, 1 deletions
diff --git a/lib/Rewrite/InclusionRewriter.cpp b/lib/Rewrite/InclusionRewriter.cpp index 2dd6b34f61..3dfc3b0089 100644 --- a/lib/Rewrite/InclusionRewriter.cpp +++ b/lib/Rewrite/InclusionRewriter.cpp @@ -250,7 +250,8 @@ bool InclusionRewriter::Process(FileID FileId, { bool Invalid; const MemoryBuffer &FromFile = *SM.getBuffer(FileId, &Invalid); - assert(!Invalid && "Invalid FileID while trying to rewrite includes"); + if (Invalid) // invalid inclusion + return true; const char *FileName = FromFile.getBufferIdentifier(); Lexer RawLex(FileId, &FromFile, PP.getSourceManager(), PP.getLangOpts()); RawLex.SetCommentRetentionState(false); diff --git a/test/Frontend/rewrite-includes-missing.c b/test/Frontend/rewrite-includes-missing.c new file mode 100644 index 0000000000..d16fbebea6 --- /dev/null +++ b/test/Frontend/rewrite-includes-missing.c @@ -0,0 +1,7 @@ +// RUN: %clang_cc1 -verify -E -frewrite-includes %s -o - | FileCheck -strict-whitespace %s + +#include "foobar.h" // expected-error {{'foobar.h' file not found}} +// CHECK: {{^}}#if 0 /* expanded by -frewrite-includes */{{$}} +// CHECK-NEXT: {{^}}#include "foobar.h" +// CHECK-NEXT: {{^}}#endif /* expanded by -frewrite-includes */{{$}} +// CHECK-NEXT: {{^}}# 4 "/usr/local/google/home/blaikie/Development/llvm/src/tools/clang/test/Frontend/rewrite-includes-missing.c" 2{{$}} |