summaryrefslogtreecommitdiffstats
path: root/clang/Lex/Lexer.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2007-07-20 16:52:03 +0000
committerChris Lattner <sabre@nondot.org>2007-07-20 16:52:03 +0000
commit77e9de50a112dc3f0bee0d43469db4bde47225c9 (patch)
tree839d0805434f98057a49f5216acde711300486d3 /clang/Lex/Lexer.cpp
parentdc5c055fd1b31a0f5b11030a4e6ea5d6f2ed7d86 (diff)
downloadbcm5719-llvm-77e9de50a112dc3f0bee0d43469db4bde47225c9.tar.gz
bcm5719-llvm-77e9de50a112dc3f0bee0d43469db4bde47225c9.zip
simplify the lexer ctor to take a SLoc instead of a sloc and a redundant buffer*.
llvm-svn: 40104
Diffstat (limited to 'clang/Lex/Lexer.cpp')
-rw-r--r--clang/Lex/Lexer.cpp18
1 files changed, 11 insertions, 7 deletions
diff --git a/clang/Lex/Lexer.cpp b/clang/Lex/Lexer.cpp
index a1db060c3e6..4efd62113d4 100644
--- a/clang/Lex/Lexer.cpp
+++ b/clang/Lex/Lexer.cpp
@@ -34,20 +34,24 @@ using namespace clang;
static void InitCharacterInfo();
-Lexer::Lexer(const llvm::MemoryBuffer *File, SourceLocation fileloc,
- Preprocessor &pp, const char *BufStart, const char *BufEnd)
- : BufferEnd(BufEnd ? BufEnd : File->getBufferEnd()),
- InputFile(File), FileLoc(fileloc), PP(pp), Features(PP.getLangOptions()) {
+Lexer::Lexer(SourceLocation fileloc, Preprocessor &pp,
+ const char *BufStart, const char *BufEnd)
+ : FileLoc(fileloc), PP(pp), Features(PP.getLangOptions()) {
+
+ SourceManager &SourceMgr = PP.getSourceManager();
+ InputFile =SourceMgr.getBuffer(SourceMgr.getPhysicalLoc(FileLoc).getFileID());
+
Is_PragmaLexer = false;
IsMainFile = false;
InitCharacterInfo();
+ BufferPtr = BufStart ? BufStart : InputFile->getBufferStart();
+ BufferEnd = BufEnd ? BufEnd : InputFile->getBufferEnd();
+
assert(BufferEnd[0] == 0 &&
"We assume that the input buffer has a null character at the end"
" to simplify lexing!");
-
- BufferPtr = BufStart ? BufStart : File->getBufferStart();
-
+
// Start of the file is a start of line.
IsAtStartOfLine = true;
OpenPOWER on IntegriCloud