forked from OSchip/llvm-project
Move LexIncludeFilename from Lexer to PreprocessorLexer.
PreprocessorLexer now has a virtual method "IndirectLex" which allows it to call the lex method of its subclasses. This is not for performance intensive operations. llvm-svn: 59185
This commit is contained in:
parent
f32443cdcd
commit
6c90efb923
|
@ -115,6 +115,10 @@ public:
|
|||
LexTokenInternal(Result);
|
||||
}
|
||||
|
||||
/// IndirectLex - An indirect call to 'Lex' that can be invoked via
|
||||
/// the PreprocessorLexer interface.
|
||||
void IndirectLex(Token &Result) { Lex(Result); }
|
||||
|
||||
/// LexFromRawLexer - Lex a token from a designated raw lexer (one with no
|
||||
/// associated preprocessor object. Return true if the 'next character to
|
||||
/// read' pointer points and the end of the lexer buffer, false otherwise.
|
||||
|
@ -331,11 +335,6 @@ private:
|
|||
bool SkipBCPLComment (Token &Result, const char *CurPtr);
|
||||
bool SkipBlockComment (Token &Result, const char *CurPtr);
|
||||
bool SaveBCPLComment (Token &Result, const char *CurPtr);
|
||||
|
||||
/// LexIncludeFilename - After the preprocessor has parsed a #include, lex and
|
||||
/// (potentially) macro expand the filename. If the sequence parsed is not
|
||||
/// lexically legal, emit a diagnostic and return a result EOM token.
|
||||
void LexIncludeFilename(Token &Result);
|
||||
};
|
||||
|
||||
|
||||
|
|
|
@ -0,0 +1,40 @@
|
|||
//===--- PreprocessorLexer.cpp - C Language Family Lexer ------------------===//
|
||||
//
|
||||
// The LLVM Compiler Infrastructure
|
||||
//
|
||||
// This file is distributed under the University of Illinois Open Source
|
||||
// License. See LICENSE.TXT for details.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
//
|
||||
// This file implements the PreprocessorLexer and Token interfaces.
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#include "clang/Lex/PreprocessorLexer.h"
|
||||
#include "clang/Lex/Preprocessor.h"
|
||||
#include "clang/Basic/Diagnostic.h"
|
||||
#include "clang/Basic/SourceManager.h"
|
||||
|
||||
using namespace clang;
|
||||
|
||||
/// LexIncludeFilename - After the preprocessor has parsed a #include, lex and
|
||||
/// (potentially) macro expand the filename.
|
||||
void PreprocessorLexer::LexIncludeFilename(Token &FilenameTok) {
|
||||
assert(ParsingPreprocessorDirective &&
|
||||
ParsingFilename == false &&
|
||||
"Must be in a preprocessing directive!");
|
||||
|
||||
// We are now parsing a filename!
|
||||
ParsingFilename = true;
|
||||
|
||||
// Lex the filename.
|
||||
IndirectLex(FilenameTok);
|
||||
|
||||
// We should have obtained the filename now.
|
||||
ParsingFilename = false;
|
||||
|
||||
// No filename?
|
||||
if (FilenameTok.is(tok::eom))
|
||||
Diag(FilenameTok.getLocation(), diag::err_pp_expects_filename);
|
||||
}
|
Loading…
Reference in New Issue