From 9f1dcb3372f3457235b8c37133777df6da5cc1d1 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Tue, 1 Apr 2008 03:59:34 +0000 Subject: [PATCH] rewrite SourceFile to be in terms of MemoryBuffer, not MappedFile. llvm-svn: 49027 --- include/llvm/Debugger/SourceFile.h | 22 ++++++-------------- lib/Debugger/SourceFile.cpp | 32 ++++++++++++++++++------------ 2 files changed, 25 insertions(+), 29 deletions(-) diff --git a/include/llvm/Debugger/SourceFile.h b/include/llvm/Debugger/SourceFile.h index eeff469c03b..66783ce088f 100644 --- a/include/llvm/Debugger/SourceFile.h +++ b/include/llvm/Debugger/SourceFile.h @@ -17,11 +17,12 @@ #define LLVM_DEBUGGER_SOURCEFILE_H #include "llvm/System/Path.h" -#include "llvm/System/MappedFile.h" +#include "llvm/ADT/OwningPtr.h" #include namespace llvm { class GlobalVariable; + class MemoryBuffer; class SourceFile { /// Filename - This is the full path of the file that is loaded. @@ -35,7 +36,7 @@ namespace llvm { const GlobalVariable *Descriptor; /// This is the memory mapping for the file so we can gain access to it. - sys::MappedFile File; + OwningPtr File; /// LineOffset - This vector contains a mapping from source line numbers to /// their offsets in the file. This data is computed lazily, the first time @@ -49,16 +50,9 @@ namespace llvm { /// NOT throw an exception if the file is not found, if there is an error /// reading it, or if the user cancels the operation. Instead, it will just /// be an empty source file. - SourceFile(const std::string &fn, const GlobalVariable *Desc) - : Filename(fn), Descriptor(Desc), File() { - std::string ErrMsg; - if (File.open(Filename, &ErrMsg)) - throw ErrMsg; - readFile(); - } - ~SourceFile() { - File.unmap(); - } + SourceFile(const std::string &fn, const GlobalVariable *Desc); + + ~SourceFile(); /// getDescriptor - Return the debugging decriptor for this source file. /// @@ -84,10 +78,6 @@ namespace llvm { } private: - /// readFile - Load Filename into memory - /// - void readFile(); - /// calculateLineOffsets - Compute the LineOffset vector for the current /// file. void calculateLineOffsets() const; diff --git a/lib/Debugger/SourceFile.cpp b/lib/Debugger/SourceFile.cpp index 75248cd10da..03c60f87f78 100644 --- a/lib/Debugger/SourceFile.cpp +++ b/lib/Debugger/SourceFile.cpp @@ -12,25 +12,32 @@ //===----------------------------------------------------------------------===// #include "llvm/Debugger/SourceFile.h" +#include "llvm/Support/MemoryBuffer.h" #include - using namespace llvm; -/// readFile - Load Filename -/// -void SourceFile::readFile() { - std::string ErrMsg; - if (!File.map(&ErrMsg)) - throw ErrMsg; +static const char EmptyFile = 0; + +SourceFile::SourceFile(const std::string &fn, const GlobalVariable *Desc) + : Filename(fn), Descriptor(Desc) { + File.reset(MemoryBuffer::getFileOrSTDIN(fn)); + + // On error, return an empty buffer. + if (File == 0) + File.reset(MemoryBuffer::getMemBuffer(&EmptyFile, &EmptyFile)); } +SourceFile::~SourceFile() { +} + + /// calculateLineOffsets - Compute the LineOffset vector for the current file. /// void SourceFile::calculateLineOffsets() const { assert(LineOffset.empty() && "Line offsets already computed!"); - const char *BufPtr = (const char *)File.getBase(); + const char *BufPtr = File->getBufferStart(); const char *FileStart = BufPtr; - const char *FileEnd = FileStart + File.size(); + const char *FileEnd = File->getBufferEnd(); do { LineOffset.push_back(BufPtr-FileStart); @@ -54,19 +61,18 @@ void SourceFile::calculateLineOffsets() const { void SourceFile::getSourceLine(unsigned LineNo, const char *&LineStart, const char *&LineEnd) const { LineStart = LineEnd = 0; - if (!File.isMapped()) return; // Couldn't load file, return null pointers if (LineOffset.empty()) calculateLineOffsets(); // Asking for an out-of-range line number? if (LineNo >= LineOffset.size()) return; // Otherwise, they are asking for a valid line, which we can fulfill. - LineStart = (const char *)File.getBase()+LineOffset[LineNo]; + LineStart = File->getBufferStart()+LineOffset[LineNo]; if (LineNo+1 < LineOffset.size()) - LineEnd = (const char *)File.getBase()+LineOffset[LineNo+1]; + LineEnd = File->getBufferStart()+LineOffset[LineNo+1]; else - LineEnd = (const char *)File.getBase() + File.size(); + LineEnd = File->getBufferEnd(); // If the line ended with a newline, strip it off. while (LineEnd != LineStart && (LineEnd[-1] == '\n' || LineEnd[-1] == '\r'))