mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-31 08:16:47 +00:00 
			
		
		
		
	git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@9903 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			103 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			103 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| //===- Support/FileUtilities.h - File System Utilities ----------*- C++ -*-===//
 | |
| // 
 | |
| //                     The LLVM Compiler Infrastructure
 | |
| //
 | |
| // This file was developed by the LLVM research group and is distributed under
 | |
| // the University of Illinois Open Source License. See LICENSE.TXT for details.
 | |
| // 
 | |
| //===----------------------------------------------------------------------===//
 | |
| //
 | |
| // This file defines a family of utility functions which are useful for doing
 | |
| // various things with files.
 | |
| //
 | |
| //===----------------------------------------------------------------------===//
 | |
| 
 | |
| #ifndef SUPPORT_FILEUTILITIES_H
 | |
| #define SUPPORT_FILEUTILITIES_H
 | |
| 
 | |
| #include <string>
 | |
| 
 | |
| namespace llvm {
 | |
| 
 | |
| /// CheckMagic - Returns true IFF the file named FN begins with Magic. FN must
 | |
| /// name a readable file.
 | |
| ///
 | |
| bool CheckMagic (const std::string &FN, const std::string &Magic);
 | |
| 
 | |
| /// IsArchive - Returns true IFF the file named FN appears to be a "ar" library
 | |
| /// archive. The file named FN must exist.
 | |
| ///
 | |
| bool IsArchive (const std::string &FN);
 | |
| 
 | |
| /// IsBytecode - Returns true IFF the file named FN appears to be an LLVM
 | |
| /// bytecode file. The file named FN must exist.
 | |
| ///
 | |
| bool IsBytecode (const std::string &FN);
 | |
| 
 | |
| /// FileOpenable - Returns true IFF Filename names an existing regular file
 | |
| /// which we can successfully open.
 | |
| ///
 | |
| bool FileOpenable (const std::string &Filename);
 | |
| 
 | |
| /// DiffFiles - Compare the two files specified, returning true if they are
 | |
| /// different or if there is a file error.  If you specify a string to fill in
 | |
| /// for the error option, it will set the string to an error message if an error
 | |
| /// occurs, allowing the caller to distinguish between a failed diff and a file
 | |
| /// system error.
 | |
| ///
 | |
| bool DiffFiles(const std::string &FileA, const std::string &FileB,
 | |
|                std::string *Error = 0);
 | |
| 
 | |
| 
 | |
| /// MoveFileOverIfUpdated - If the file specified by New is different than Old,
 | |
| /// or if Old does not exist, move the New file over the Old file.  Otherwise,
 | |
| /// remove the New file.
 | |
| ///
 | |
| void MoveFileOverIfUpdated(const std::string &New, const std::string &Old);
 | |
|  
 | |
| /// removeFile - Delete the specified file
 | |
| ///
 | |
| void removeFile(const std::string &Filename);
 | |
| 
 | |
| /// getUniqueFilename - Return a filename with the specified prefix.  If the
 | |
| /// file does not exist yet, return it, otherwise add a suffix to make it
 | |
| /// unique.
 | |
| ///
 | |
| std::string getUniqueFilename(const std::string &FilenameBase);
 | |
| 
 | |
| ///
 | |
| /// Method: MakeFileExecutable()
 | |
| ///
 | |
| /// Description:
 | |
| ///	This method turns on whatever access attributes are needed to make the
 | |
| ///	specified file executable.
 | |
| ///
 | |
| /// Return value:
 | |
| ///	True  - The operation succeeded.
 | |
| ///	False - The operation failed.
 | |
| ///
 | |
| /// Notes:
 | |
| ///	In case of failure, the file's access attributes are unspecified.
 | |
| ///
 | |
| bool MakeFileExecutable (const std::string & Filename);
 | |
| 
 | |
| ///
 | |
| /// Method: MakeFileReadable()
 | |
| ///
 | |
| /// Description:
 | |
| ///	This method turns on whatever access attributes are needed to make the
 | |
| ///	specified file readable.
 | |
| ///
 | |
| /// Return value:
 | |
| ///	True  - The operation succeeded.
 | |
| ///	False - The operation failed.
 | |
| ///
 | |
| /// Notes:
 | |
| ///	In case of failure, the file's access attributes are unspecified.
 | |
| ///
 | |
| bool MakeFileReadable (const std::string & Filename);
 | |
| 
 | |
| } // End llvm namespace
 | |
| 
 | |
| #endif
 |