summaryrefslogtreecommitdiff
path: root/lib/Basic/SourceManager.cpp
diff options
context:
space:
mode:
authorArgyrios Kyrtzidis <akyrtzi@gmail.com>2011-12-10 00:30:38 +0000
committerArgyrios Kyrtzidis <akyrtzi@gmail.com>2011-12-10 00:30:38 +0000
commitd575254dcd061ad9e6661598f4443d85a7bd1d8b (patch)
tree1e9f8854448afdb477acdefe2ae35f79574e5aa0 /lib/Basic/SourceManager.cpp
parent006e42f0c8b65b783d565ef10b938a9e82fc02e3 (diff)
downloadclang-d575254dcd061ad9e6661598f4443d85a7bd1d8b.tar.gz
Add a sanity check in SourceManager::getColumnNumber, make sure
we don't try to access beyond the buffer. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@146305 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Basic/SourceManager.cpp')
-rw-r--r--lib/Basic/SourceManager.cpp9
1 files changed, 8 insertions, 1 deletions
diff --git a/lib/Basic/SourceManager.cpp b/lib/Basic/SourceManager.cpp
index cdaff2f008..85fe474d66 100644
--- a/lib/Basic/SourceManager.cpp
+++ b/lib/Basic/SourceManager.cpp
@@ -947,13 +947,20 @@ const char *SourceManager::getCharacterData(SourceLocation SL,
unsigned SourceManager::getColumnNumber(FileID FID, unsigned FilePos,
bool *Invalid) const {
bool MyInvalid = false;
- const char *Buf = getBuffer(FID, &MyInvalid)->getBufferStart();
+ const llvm::MemoryBuffer *MemBuf = getBuffer(FID, &MyInvalid);
if (Invalid)
*Invalid = MyInvalid;
if (MyInvalid)
return 1;
+ const char *Buf = MemBuf->getBufferStart();
+ if (Buf + FilePos >= MemBuf->getBufferEnd()) {
+ if (Invalid)
+ *Invalid = MyInvalid;
+ return 1;
+ }
+
unsigned LineStart = FilePos;
while (LineStart && Buf[LineStart-1] != '\n' && Buf[LineStart-1] != '\r')
--LineStart;