diff options
author | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2013-03-01 03:26:00 +0000 |
---|---|---|
committer | Argyrios Kyrtzidis <akyrtzi@gmail.com> | 2013-03-01 03:26:00 +0000 |
commit | 7dc4f33c77acd90b3217b94e50965bbcefbcd55f (patch) | |
tree | 6ef52e0629033d8fe6a4cc3650075f7510a31747 /clang/lib/Basic/SourceManager.cpp | |
parent | e9e588dd728ad843129e48237aea0c54a14990e7 (diff) | |
download | llvm-7dc4f33c77acd90b3217b94e50965bbcefbcd55f.zip llvm-7dc4f33c77acd90b3217b94e50965bbcefbcd55f.tar.gz llvm-7dc4f33c77acd90b3217b94e50965bbcefbcd55f.tar.bz2 |
In SourceManager::getFileIDLoaded(), add some sanity checks to make sure we don't enter an infinite loop.
rdar://13120919
llvm-svn: 176331
Diffstat (limited to 'clang/lib/Basic/SourceManager.cpp')
-rw-r--r-- | clang/lib/Basic/SourceManager.cpp | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/clang/lib/Basic/SourceManager.cpp b/clang/lib/Basic/SourceManager.cpp index ea95650..8fa648c 100644 --- a/clang/lib/Basic/SourceManager.cpp +++ b/clang/lib/Basic/SourceManager.cpp @@ -840,10 +840,17 @@ FileID SourceManager::getFileIDLoaded(unsigned SLocOffset) const { ++NumProbes; unsigned MiddleIndex = (LessIndex - GreaterIndex) / 2 + GreaterIndex; const SrcMgr::SLocEntry &E = getLoadedSLocEntry(MiddleIndex); + if (E.getOffset() == 0) + return FileID(); // invalid entry. ++NumProbes; if (E.getOffset() > SLocOffset) { + // Sanity checking, otherwise a bug may lead to hanging in release build. + if (GreaterIndex == MiddleIndex) { + assert(0 && "binary search missed the entry"); + return FileID(); + } GreaterIndex = MiddleIndex; continue; } |