Magic_Game/src/kiwano/platform/FileSystem.h

116 lines
3.2 KiB
C
Raw Normal View History

2019-04-11 14:40:54 +08:00
// Copyright (c) 2016-2018 Kiwano - Nomango
2020-01-21 10:09:55 +08:00
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
2020-01-21 10:09:55 +08:00
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
2020-01-21 10:09:55 +08:00
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE.
#pragma once
2019-11-13 14:33:15 +08:00
#include <kiwano/core/Resource.h>
2019-04-11 14:40:54 +08:00
namespace kiwano
{
2020-01-21 10:09:55 +08:00
/**
* \~chinese
* @brief <EFBFBD>ļ<EFBFBD>ϵͳ<EFBFBD><EFBFBD>Ϊ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ģ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
2020-01-21 10:09:55 +08:00
*/
class KGE_API FileSystem : public Singleton<FileSystem>
{
friend Singleton<FileSystem>;
2019-10-11 21:12:29 +08:00
2020-01-21 10:09:55 +08:00
public:
/**
* \~chinese
* @brief <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>·<EFBFBD><EFBFBD>
* @param path <EFBFBD>ļ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>·<EFBFBD><EFBFBD>
2020-01-21 10:09:55 +08:00
*/
2020-02-19 12:09:50 +08:00
void AddSearchPath(const String& path);
2019-10-11 21:12:29 +08:00
2020-01-21 10:09:55 +08:00
/**
* \~chinese
* @brief <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>·<EFBFBD><EFBFBD>
* @param paths <EFBFBD><EFBFBD><EFBFBD><EFBFBD>·<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
2020-01-21 10:09:55 +08:00
*/
2020-02-19 12:09:50 +08:00
void SetSearchPaths(const Vector<String>& paths);
2019-10-11 21:12:29 +08:00
2020-01-21 10:09:55 +08:00
/**
* \~chinese
* @brief <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>б<EFBFBD><EFBFBD>в<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ȡ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>·<EFBFBD><EFBFBD>
* @param file <EFBFBD>ļ<EFBFBD>·<EFBFBD><EFBFBD>
* @return <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD>·<EFBFBD><EFBFBD>
2020-01-21 10:09:55 +08:00
*/
2020-02-19 12:09:50 +08:00
String GetFullPathForFile(const String& file) const;
2019-10-11 21:12:29 +08:00
2020-01-21 10:09:55 +08:00
/**
* \~chinese
* @brief <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD>·<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֵ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
* @param key <EFBFBD>ļ<EFBFBD><EFBFBD>ؼ<EFBFBD><EFBFBD><EFBFBD>
* @param file_path <EFBFBD>ļ<EFBFBD>·<EFBFBD><EFBFBD>
2020-01-21 10:09:55 +08:00
*/
2020-02-19 12:09:50 +08:00
void AddFileLookupRule(const String& key, const String& file_path);
2019-10-11 21:12:29 +08:00
2020-01-21 10:09:55 +08:00
/**
* \~chinese
* @brief <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD>·<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֵ<EFBFBD>
* @param dict <EFBFBD>ļ<EFBFBD>·<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>ֵ<EFBFBD>
2020-01-21 10:09:55 +08:00
*/
2020-02-19 12:09:50 +08:00
void SetFileLookupDictionary(const UnorderedMap<String, String>& dict);
2019-10-11 21:12:29 +08:00
2020-01-21 10:09:55 +08:00
/**
* \~chinese
* @brief <EFBFBD>ļ<EFBFBD><EFBFBD>Ƿ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>
* @param file_path <EFBFBD>ļ<EFBFBD>·<EFBFBD><EFBFBD>
* @return <EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ڣ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> true
2020-01-21 10:09:55 +08:00
*/
2020-02-19 12:09:50 +08:00
bool IsFileExists(const String& file_path) const;
2019-10-11 21:12:29 +08:00
2020-01-21 10:09:55 +08:00
/**
* \~chinese
* @brief <EFBFBD>ж<EFBFBD>·<EFBFBD><EFBFBD><EFBFBD>Ƿ<EFBFBD><EFBFBD>Ǿ<EFBFBD><EFBFBD><EFBFBD>·<EFBFBD><EFBFBD>
* @param path <EFBFBD>ļ<EFBFBD>·<EFBFBD><EFBFBD>
* @return <EFBFBD><EFBFBD><EFBFBD>Ǿ<EFBFBD><EFBFBD><EFBFBD>·<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD> true
2020-01-21 10:09:55 +08:00
*/
2020-02-19 12:09:50 +08:00
bool IsAbsolutePath(const String& path) const;
2019-10-11 21:12:29 +08:00
2020-01-21 10:09:55 +08:00
/**
* \~chinese
* @brief ɾ<EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD>
* @param file_path <EFBFBD>ļ<EFBFBD>·<EFBFBD><EFBFBD>
* @return ɾ<EFBFBD><EFBFBD><EFBFBD>Ƿ<EFBFBD><EFBFBD>ɹ<EFBFBD>
2020-01-21 10:09:55 +08:00
*/
2020-02-19 12:09:50 +08:00
bool RemoveFile(const String& file_path) const;
2020-01-21 10:09:55 +08:00
/**
* \~chinese
* @brief <EFBFBD>ͷŶ<EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Դ<EFBFBD><EFBFBD><EFBFBD><EFBFBD>ʱ<EFBFBD>ļ<EFBFBD>Ŀ¼
* @param res <EFBFBD><EFBFBD>Դ
* @param dest_file_name Ŀ<EFBFBD><EFBFBD><EFBFBD>ļ<EFBFBD><EFBFBD><EFBFBD>
* @return <EFBFBD><EFBFBD><EFBFBD><EFBFBD><EFBFBD>Ƿ<EFBFBD><EFBFBD>ɹ<EFBFBD>
2020-01-21 10:09:55 +08:00
*/
2020-02-19 12:09:50 +08:00
bool ExtractResourceToFile(const Resource& res, const String& dest_file_name) const;
2020-06-08 20:20:06 +08:00
~FileSystem();
2020-01-21 10:09:55 +08:00
private:
FileSystem();
2019-10-11 21:12:29 +08:00
2020-01-21 10:09:55 +08:00
private:
Vector<String> search_paths_;
UnorderedMap<String, String> file_lookup_dict_;
mutable UnorderedMap<String, String> file_lookup_cache_;
};
} // namespace kiwano