mirror of
https://github.com/Gericom/teak-llvm.git
synced 2025-06-23 13:35:42 -04:00

"FileID" a concept that is now enforced by the compiler's type checker instead of yet-another-random-unsigned floating around. This is an important distinction from the "FileID" currently tracked by SourceLocation. *That* FileID may refer to the start of a file or to a chunk within it. The new FileID *only* refers to the file (and its #include stack and eventually #line data), it cannot refer to a chunk. FileID is a completely opaque datatype to all clients, only SourceManager is allowed to poke and prod it. llvm-svn: 62407
46 lines
1.5 KiB
C++
46 lines
1.5 KiB
C++
//===--- 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))
|
|
PP->Diag(FilenameTok.getLocation(), diag::err_pp_expects_filename);
|
|
}
|
|
|
|
/// getFileEntry - Return the FileEntry corresponding to this FileID. Like
|
|
/// getFileID(), this only works for lexers with attached preprocessors.
|
|
const FileEntry *PreprocessorLexer::getFileEntry() const {
|
|
return PP->getSourceManager().getFileEntryForID(getFileID());
|
|
}
|