| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104 | #pragma once/* * Filesystem.h, part of VCMI engine * * Authors: listed in file AUTHORS in main folder * * License: GNU General Public License v2.0 or later * Full text of license available in license.txt file, in main folder * */#include "CInputStream.h"#include "AdapterLoaders.h"#include "ResourceID.h"class JsonNode;/// Helper class that allows generation of a ISimpleResourceLoader entry out of Json config(s)class DLL_LINKAGE CFilesystemGenerator{	typedef boost::function<void(const std::string &, const JsonNode &)> TLoadFunctor;	typedef std::map<std::string, TLoadFunctor> TLoadFunctorMap;	CFilesystemList * filesystem;	std::string prefix;	template<EResType::Type archiveType>	void loadArchive(const std::string & mountPoint, const JsonNode & config);	void loadDirectory(const std::string & mountPoint, const JsonNode & config);	void loadZipArchive(const std::string & mountPoint, const JsonNode & config);	void loadJsonMap(const std::string & mountPoint, const JsonNode & config);	TLoadFunctorMap genFunctorMap();public:	/// prefix = prefix that will be given to file entries in all nodes of this filesystem	CFilesystemGenerator(std::string prefix);	/// loads configuration from json	/// config - configuration to load, using format of "filesystem" entry in config/filesystem.json	void loadConfig(const JsonNode & config);	/// returns generated filesystem	CFilesystemList * getFilesystem();};/** * This class has static methods for a global resource loader access. * * Class is not thread-safe. */class DLL_LINKAGE CResourceHandler{public:	/**	 * Gets an instance of resource loader.	 *	 * Make sure that you've set an instance before using it. It'll throw an exception if no instance was set.	 *	 * @return Returns an instance of resource loader.	 */	static CFilesystemList * get();	static CFilesystemList * getInitial();	static CFilesystemList * getCoreData();	/**	 * Creates instance of initial resource loader.	 * Will not fill filesystem with data	 *	 */	static void initialize();	/**	 * Semi-debug method to track all possible cases of memory leaks	 * Used before exiting application	 *	 */	static void clear();	/**	 * Will load all filesystem data from Json data at this path (normally - config/filesystem.json)	 * @param fsConfigURI - URI from which data will be loaded	 */	static void load(const std::string & fsConfigURI);	/**	 * @brief createModFileSystem - creates filesystem out of config file	 * @param prefix - prefix for all paths in filesystem config	 * @param fsConfig - configuration to load	 * @return generated filesystem that contains all config entries	 */	static CFilesystemList * createFileSystem(const std::string &prefix, const JsonNode & fsConfig);	/**	 * Checks all subfolders of MODS directory for presence of mods	 * If this directory has mod.json file it will be added to resources	 */	static std::vector<std::string> getAvailableMods();private:	/** Instance of resource loader */	static CFilesystemList * resourceLoader;	static CFilesystemList * initialLoader;	static CFilesystemList * coreDataLoader;};
 |