mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-25 14:26:36 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			49 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			49 lines
		
	
	
	
		
			2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #ifndef COMPONENTS_FILES_FILELIBRARY_HPP
 | |
| #define COMPONENTS_FILES_FILELIBRARY_HPP
 | |
| 
 | |
| #include <components/files/fileops.hpp>
 | |
| 
 | |
| namespace Files
 | |
| {
 | |
|     typedef std::map<std::string, PathContainer> StringPathContMap;
 | |
|     typedef std::vector<std::string> StringVector;
 | |
| 
 | |
|     /// Looks for a string in a vector of strings
 | |
|     bool containsVectorString(const StringVector& list, const std::string& str);
 | |
| 
 | |
|     /// \brief Searches directories and makes lists of files according to folder name
 | |
|     class FileLibrary
 | |
|     {
 | |
|         private:
 | |
|             StringPathContMap mMap;
 | |
|             PathContainer mEmptyPath;
 | |
|             PathContainer mPriorityList;
 | |
| 
 | |
|         public:
 | |
|             /// Searches a path and adds the results to the library
 | |
|             /// Recursive search and fs strict options are available
 | |
|             /// Takes a vector of acceptable files extensions, if none is given it lists everything.
 | |
|             void add(const boost::filesystem::path &root, bool recursive, bool strict,
 | |
|                      const StringVector &acceptableExtensions);
 | |
| 
 | |
|             /// Returns true if the named section exists
 | |
|             /// You can run this check before running section()
 | |
|             bool containsSection(std::string sectionName, bool strict);
 | |
| 
 | |
|             /// Returns a pointer to const for a section of the library
 | |
|             /// which is essentially a PathContainer.
 | |
|             /// If the section does not exists it returns a pointer to an empty path.
 | |
|             const PathContainer* section(std::string sectionName, bool strict);
 | |
| 
 | |
|             /// Searches the library for an item and returns a boost path to it
 | |
|             /// Optionally you can provide a specific section
 | |
|             /// The result is the first that comes up according to alphabetical
 | |
|             /// section naming
 | |
|             boost::filesystem::path locate(std::string item, bool strict, bool ignoreExtensions, std::string sectionName="");
 | |
| 
 | |
|             /// Prints all the available sections, used for debugging
 | |
|             void printSections();
 | |
|     };
 | |
| }
 | |
| 
 | |
| #endif
 |