forked from OSchip/llvm-project
implement .include in the lexer/parser instead of passing it into the streamer.
llvm-svn: 75896
This commit is contained in:
parent
3afa3e1d91
commit
693fbb8fee
|
@ -160,12 +160,6 @@ namespace llvm {
|
|||
/// @param AbortReason - The reason assembly is terminated, if non-NULL.
|
||||
virtual void AbortAssembly(const char *AbortReason) = 0;
|
||||
|
||||
/// SwitchInputAssemblyFile - Assemble the contents of the specified file in
|
||||
/// @param FileName at this point in the assembly.
|
||||
///
|
||||
/// @param FileName - The file to assemble at this point
|
||||
virtual void SwitchInputAssemblyFile(const char *FileName) = 0;
|
||||
|
||||
/// DumpSymbolsandMacros - Dump to the specified file in @param FileName all
|
||||
/// symbols and macros at this point in the assembly.
|
||||
///
|
||||
|
|
|
@ -57,8 +57,6 @@ namespace {
|
|||
|
||||
virtual void AbortAssembly(const char *AbortReason = NULL);
|
||||
|
||||
virtual void SwitchInputAssemblyFile(const char *FileName);
|
||||
|
||||
virtual void DumpSymbolsandMacros(const char *FileName);
|
||||
|
||||
virtual void LoadSymbolsandMacros(const char *FileName);
|
||||
|
@ -143,10 +141,6 @@ void MCAsmStreamer::AbortAssembly(const char *AbortReason) {
|
|||
|
||||
}
|
||||
|
||||
void MCAsmStreamer::SwitchInputAssemblyFile(const char *FileName) {
|
||||
OS << ".include" << ' ' << FileName << '\n';
|
||||
}
|
||||
|
||||
void MCAsmStreamer::DumpSymbolsandMacros(const char *FileName) {
|
||||
OS << ".dump" << ' ' << FileName << '\n';
|
||||
}
|
||||
|
|
|
@ -1,8 +1,9 @@
|
|||
# RUN: llvm-mc %s | FileCheck %s
|
||||
# RUN: llvm-mc %s -I %p | FileCheck %s
|
||||
|
||||
# CHECK: TESTA:
|
||||
# CHECK: TEST0:
|
||||
# CHECK: .include "some/include/file"
|
||||
# CHECK: .include "mary had a little lamb"
|
||||
TEST0:
|
||||
.include "some/include/file"
|
||||
.include "mary had a little lamb"
|
||||
# CHECK: .set a, 0
|
||||
# CHECK: TESTB:
|
||||
TESTA:
|
||||
.include "directive_set.s"
|
||||
TESTB:
|
||||
|
|
|
@ -54,6 +54,21 @@ asmtok::TokKind AsmLexer::ReturnError(const char *Loc, const std::string &Msg) {
|
|||
return asmtok::Error;
|
||||
}
|
||||
|
||||
/// EnterIncludeFile - Enter the specified file. This prints an error and
|
||||
/// returns true on failure.
|
||||
bool AsmLexer::EnterIncludeFile(const std::string &Filename) {
|
||||
int NewBuf = SrcMgr.AddIncludeFile(Filename, SMLoc::getFromPointer(CurPtr));
|
||||
if (NewBuf == -1)
|
||||
return true;
|
||||
|
||||
// Save the line number and lex buffer of the includer.
|
||||
CurBuffer = NewBuf;
|
||||
CurBuf = SrcMgr.getMemoryBuffer(CurBuffer);
|
||||
CurPtr = CurBuf->getBufferStart();
|
||||
return false;
|
||||
}
|
||||
|
||||
|
||||
int AsmLexer::getNextChar() {
|
||||
char CurChar = *CurPtr++;
|
||||
switch (CurChar) {
|
||||
|
@ -72,6 +87,10 @@ int AsmLexer::getNextChar() {
|
|||
CurBuffer = SrcMgr.FindBufferContainingLoc(ParentIncludeLoc);
|
||||
CurBuf = SrcMgr.getMemoryBuffer(CurBuffer);
|
||||
CurPtr = ParentIncludeLoc.getPointer();
|
||||
|
||||
// Reset the token start pointer to the start of the new file.
|
||||
TokStart = CurPtr;
|
||||
|
||||
return getNextChar();
|
||||
}
|
||||
|
||||
|
|
|
@ -97,6 +97,9 @@ public:
|
|||
|
||||
SMLoc getLoc() const;
|
||||
|
||||
/// EnterIncludeFile - Enter the specified file. This returns true on failure.
|
||||
bool EnterIncludeFile(const std::string &Filename);
|
||||
|
||||
void PrintMessage(SMLoc Loc, const std::string &Msg, const char *Type) const;
|
||||
|
||||
private:
|
||||
|
|
|
@ -1168,21 +1168,27 @@ bool AsmParser::ParseDirectiveDarwinLsym() {
|
|||
/// ParseDirectiveInclude
|
||||
/// ::= .include "filename"
|
||||
bool AsmParser::ParseDirectiveInclude() {
|
||||
const char *Str;
|
||||
|
||||
if (Lexer.isNot(asmtok::String))
|
||||
return TokError("expected string in '.include' directive");
|
||||
|
||||
Str = Lexer.getCurStrVal();
|
||||
|
||||
std::string Filename = Lexer.getCurStrVal();
|
||||
SMLoc IncludeLoc = Lexer.getLoc();
|
||||
Lexer.Lex();
|
||||
|
||||
if (Lexer.isNot(asmtok::EndOfStatement))
|
||||
return TokError("unexpected token in '.include' directive");
|
||||
|
||||
Lexer.Lex();
|
||||
|
||||
Out.SwitchInputAssemblyFile(Str);
|
||||
// Strip the quotes.
|
||||
Filename = Filename.substr(1, Filename.size()-2);
|
||||
|
||||
// Attempt to switch the lexer to the included file before consuming the end
|
||||
// of statement to avoid losing it when we switch.
|
||||
if (Lexer.EnterIncludeFile(Filename)) {
|
||||
Lexer.PrintMessage(IncludeLoc,
|
||||
"Could not find include file '" + Filename + "'",
|
||||
"error");
|
||||
return true;
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue