aboutsummaryrefslogtreecommitdiff
path: root/clang/lib/Basic/SourceManager.cpp
diff options
context:
space:
mode:
authorArgyrios Kyrtzidis <akyrtzi@gmail.com>2013-03-01 03:26:00 +0000
committerArgyrios Kyrtzidis <akyrtzi@gmail.com>2013-03-01 03:26:00 +0000
commit7dc4f33c77acd90b3217b94e50965bbcefbcd55f (patch)
tree6ef52e0629033d8fe6a4cc3650075f7510a31747 /clang/lib/Basic/SourceManager.cpp
parente9e588dd728ad843129e48237aea0c54a14990e7 (diff)
downloadllvm-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.cpp7
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;
}