mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	Add new -d option to tblgen. It writes a make(1)-style dependency file.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@132395 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -106,7 +106,9 @@ public: | ||||
|   /// AddIncludeFile - Search for a file with the specified name in the current | ||||
|   /// directory or in one of the IncludeDirs.  If no file is found, this returns | ||||
|   /// ~0, otherwise it returns the buffer ID of the stacked file. | ||||
|   unsigned AddIncludeFile(const std::string &Filename, SMLoc IncludeLoc); | ||||
|   /// The full path to the included file can be found in IncludedFile. | ||||
|   unsigned AddIncludeFile(const std::string &Filename, SMLoc IncludeLoc, | ||||
|                           std::string &IncludedFile); | ||||
|  | ||||
|   /// FindBufferContainingLoc - Return the ID of the buffer containing the | ||||
|   /// specified location, returning -1 if not found. | ||||
|   | ||||
| @@ -391,7 +391,8 @@ bool AsmParser::Error(SMLoc L, const Twine &Msg) { | ||||
| } | ||||
|  | ||||
| bool AsmParser::EnterIncludeFile(const std::string &Filename) { | ||||
|   int NewBuf = SrcMgr.AddIncludeFile(Filename, Lexer.getLoc()); | ||||
|   std::string IncludedFile; | ||||
|   int NewBuf = SrcMgr.AddIncludeFile(Filename, Lexer.getLoc(), IncludedFile); | ||||
|   if (NewBuf == -1) | ||||
|     return true; | ||||
|  | ||||
|   | ||||
| @@ -49,14 +49,16 @@ SourceMgr::~SourceMgr() { | ||||
| /// directory or in one of the IncludeDirs.  If no file is found, this returns | ||||
| /// ~0, otherwise it returns the buffer ID of the stacked file. | ||||
| unsigned SourceMgr::AddIncludeFile(const std::string &Filename, | ||||
|                                    SMLoc IncludeLoc) { | ||||
|                                    SMLoc IncludeLoc, | ||||
|                                    std::string &IncludedFile) { | ||||
|   OwningPtr<MemoryBuffer> NewBuf; | ||||
|   MemoryBuffer::getFile(Filename.c_str(), NewBuf); | ||||
|   IncludedFile = Filename; | ||||
|   MemoryBuffer::getFile(IncludedFile.c_str(), NewBuf); | ||||
|  | ||||
|   // If the file didn't exist directly, see if it's in an include path. | ||||
|   for (unsigned i = 0, e = IncludeDirectories.size(); i != e && !NewBuf; ++i) { | ||||
|     std::string IncFile = IncludeDirectories[i] + "/" + Filename; | ||||
|     MemoryBuffer::getFile(IncFile.c_str(), NewBuf); | ||||
|     IncludedFile = IncludeDirectories[i] + "/" + Filename; | ||||
|     MemoryBuffer::getFile(IncludedFile.c_str(), NewBuf); | ||||
|   } | ||||
|  | ||||
|   if (NewBuf == 0) return ~0U; | ||||
|   | ||||
| @@ -267,14 +267,17 @@ bool TGLexer::LexInclude() { | ||||
|  | ||||
|   // Get the string. | ||||
|   std::string Filename = CurStrVal; | ||||
|   std::string IncludedFile; | ||||
|  | ||||
|    | ||||
|   CurBuffer = SrcMgr.AddIncludeFile(Filename, SMLoc::getFromPointer(CurPtr)); | ||||
|   CurBuffer = SrcMgr.AddIncludeFile(Filename, SMLoc::getFromPointer(CurPtr), | ||||
|                                     IncludedFile); | ||||
|   if (CurBuffer == -1) { | ||||
|     PrintError(getLoc(), "Could not find include file '" + Filename + "'"); | ||||
|     return true; | ||||
|   } | ||||
|    | ||||
|   Dependencies.push_back(IncludedFile); | ||||
|   // Save the line number and lex buffer of the includer. | ||||
|   CurBuf = SrcMgr.getMemoryBuffer(CurBuffer); | ||||
|   CurPtr = CurBuf->getBufferStart(); | ||||
|   | ||||
| @@ -16,6 +16,7 @@ | ||||
|  | ||||
| #include "llvm/Support/DataTypes.h" | ||||
| #include <string> | ||||
| #include <vector> | ||||
| #include <cassert> | ||||
|  | ||||
| namespace llvm { | ||||
| @@ -71,6 +72,8 @@ class TGLexer { | ||||
|   /// CurBuffer - This is the current buffer index we're lexing from as managed | ||||
|   /// by the SourceMgr object. | ||||
|   int CurBuffer; | ||||
|   /// Dependencies - This is the list of all included files. | ||||
|   std::vector<std::string> Dependencies; | ||||
|    | ||||
| public: | ||||
|   TGLexer(SourceMgr &SrcMgr); | ||||
| @@ -79,6 +82,10 @@ public: | ||||
|   tgtok::TokKind Lex() { | ||||
|     return CurCode = LexToken(); | ||||
|   } | ||||
|  | ||||
|   const std::vector<std::string> &getDependencies() const { | ||||
|     return Dependencies; | ||||
|   } | ||||
|    | ||||
|   tgtok::TokKind getCode() const { return CurCode; } | ||||
|  | ||||
|   | ||||
| @@ -66,6 +66,9 @@ public: | ||||
|   bool TokError(const Twine &Msg) const { | ||||
|     return Error(Lex.getLoc(), Msg); | ||||
|   } | ||||
|   const std::vector<std::string> &getDependencies() const { | ||||
|     return Lex.getDependencies(); | ||||
|   } | ||||
| private:  // Semantic analysis methods. | ||||
|   bool AddValue(Record *TheRec, SMLoc Loc, const RecordVal &RV); | ||||
|   bool SetValue(Record *TheRec, SMLoc Loc, const std::string &ValName,  | ||||
|   | ||||
| @@ -172,6 +172,10 @@ namespace { | ||||
|   OutputFilename("o", cl::desc("Output filename"), cl::value_desc("filename"), | ||||
|                  cl::init("-")); | ||||
|  | ||||
|   cl::opt<std::string> | ||||
|   DependFilename("d", cl::desc("Dependency filename"), cl::value_desc("filename"), | ||||
|                  cl::init("")); | ||||
|  | ||||
|   cl::opt<std::string> | ||||
|   InputFilename(cl::Positional, cl::desc("<input file>"), cl::init("-")); | ||||
|  | ||||
| @@ -192,34 +196,6 @@ void llvm::PrintError(SMLoc ErrorLoc, const Twine &Msg) { | ||||
|   SrcMgr.PrintMessage(ErrorLoc, Msg, "error"); | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| /// ParseFile - this function begins the parsing of the specified tablegen | ||||
| /// file. | ||||
| static bool ParseFile(const std::string &Filename, | ||||
|                       const std::vector<std::string> &IncludeDirs, | ||||
|                       SourceMgr &SrcMgr, | ||||
|                       RecordKeeper &Records) { | ||||
|   OwningPtr<MemoryBuffer> File; | ||||
|   if (error_code ec = MemoryBuffer::getFileOrSTDIN(Filename.c_str(), File)) { | ||||
|     errs() << "Could not open input file '" << Filename << "': " | ||||
|            << ec.message() <<"\n"; | ||||
|     return true; | ||||
|   } | ||||
|   MemoryBuffer *F = File.take(); | ||||
|  | ||||
|   // Tell SrcMgr about this buffer, which is what TGParser will pick up. | ||||
|   SrcMgr.AddNewSourceBuffer(F, SMLoc()); | ||||
|  | ||||
|   // Record the location of the include directory so that the lexer can find | ||||
|   // it later. | ||||
|   SrcMgr.setIncludeDirs(IncludeDirs); | ||||
|  | ||||
|   TGParser Parser(SrcMgr, Records); | ||||
|  | ||||
|   return Parser.ParseFile(); | ||||
| } | ||||
|  | ||||
| int main(int argc, char **argv) { | ||||
|   RecordKeeper Records; | ||||
|  | ||||
| @@ -230,7 +206,24 @@ int main(int argc, char **argv) { | ||||
|  | ||||
|   try { | ||||
|     // Parse the input file. | ||||
|     if (ParseFile(InputFilename, IncludeDirs, SrcMgr, Records)) | ||||
|     OwningPtr<MemoryBuffer> File; | ||||
|     if (error_code ec = MemoryBuffer::getFileOrSTDIN(InputFilename.c_str(), File)) { | ||||
|       errs() << "Could not open input file '" << InputFilename << "': " | ||||
|              << ec.message() <<"\n"; | ||||
|       return 1; | ||||
|     } | ||||
|     MemoryBuffer *F = File.take(); | ||||
|  | ||||
|     // Tell SrcMgr about this buffer, which is what TGParser will pick up. | ||||
|     SrcMgr.AddNewSourceBuffer(F, SMLoc()); | ||||
|  | ||||
|     // Record the location of the include directory so that the lexer can find | ||||
|     // it later. | ||||
|     SrcMgr.setIncludeDirs(IncludeDirs); | ||||
|  | ||||
|     TGParser Parser(SrcMgr, Records); | ||||
|  | ||||
|     if (Parser.ParseFile()) | ||||
|       return 1; | ||||
|  | ||||
|     std::string Error; | ||||
| @@ -240,6 +233,27 @@ int main(int argc, char **argv) { | ||||
|         << ":" << Error << "\n"; | ||||
|       return 1; | ||||
|     } | ||||
|     if (!DependFilename.empty()) { | ||||
|       if (OutputFilename == "-") { | ||||
|         errs() << argv[0] << ": the option -d must be used together with -o\n"; | ||||
|         return 1; | ||||
|       } | ||||
|       tool_output_file DepOut(DependFilename.c_str(), Error); | ||||
|       if (!Error.empty()) { | ||||
|         errs() << argv[0] << ": error opening " << DependFilename | ||||
|           << ":" << Error << "\n"; | ||||
|         return 1; | ||||
|       } | ||||
|       DepOut.os() << DependFilename << ":"; | ||||
|       const std::vector<std::string> &Dependencies = Parser.getDependencies(); | ||||
|       for (std::vector<std::string>::const_iterator I = Dependencies.begin(), | ||||
|                                                           E = Dependencies.end(); | ||||
|            I != E; ++I) { | ||||
|         DepOut.os() << " " << (*I); | ||||
|       } | ||||
|       DepOut.os() << "\n"; | ||||
|       DepOut.keep(); | ||||
|     } | ||||
|  | ||||
|     switch (Action) { | ||||
|     case PrintRecords: | ||||
|   | ||||
		Reference in New Issue
	
	Block a user