AdapterLoaders.h 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. #pragma once
  2. /*
  3. * AdapterLoaders.h, part of VCMI engine
  4. *
  5. * Authors: listed in file AUTHORS in main folder
  6. *
  7. * License: GNU General Public License v2.0 or later
  8. * Full text of license available in license.txt file, in main folder
  9. *
  10. */
  11. #include "ISimpleResourceLoader.h"
  12. #include "ResourceID.h"
  13. class CInputStream;
  14. class JsonNode;
  15. /**
  16. * Class that implements file mapping (aka *nix symbolic links)
  17. * Uses json file as input, content is map:
  18. * "fileA.txt" : "fileB.txt"
  19. * Note that extension is necessary, but used only to determine type
  20. *
  21. * fileA - file which will be replaced
  22. * fileB - file which will be used as replacement
  23. */
  24. class DLL_LINKAGE CMappedFileLoader : public ISimpleResourceLoader
  25. {
  26. public:
  27. /**
  28. * Ctor.
  29. *
  30. * @param config Specifies filesystem configuration
  31. */
  32. explicit CMappedFileLoader(const std::string &mountPoint, const JsonNode & config);
  33. /// Interface implementation
  34. /// @see ISimpleResourceLoader
  35. std::unique_ptr<CInputStream> load(const ResourceID & resourceName) const override;
  36. bool existsResource(const ResourceID & resourceName) const override;
  37. std::string getMountPoint() const override;
  38. boost::optional<boost::filesystem::path> getResourceName(const ResourceID & resourceName) const override;
  39. std::unordered_set<ResourceID> getFilteredFiles(std::function<bool(const ResourceID &)> filter) const override;
  40. private:
  41. /** A list of files in this map
  42. * key = ResourceID for resource loader
  43. * value = ResourceID to which file this request will be redirected
  44. */
  45. std::unordered_map<ResourceID, ResourceID> fileList;
  46. };
  47. class DLL_LINKAGE CFilesystemList : public ISimpleResourceLoader
  48. {
  49. std::vector<std::unique_ptr<ISimpleResourceLoader> > loaders;
  50. std::set<ISimpleResourceLoader *> writeableLoaders;
  51. //FIXME: this is only compile fix, should be removed in the end
  52. CFilesystemList(CFilesystemList &)
  53. {
  54. //class is not copyable
  55. }
  56. CFilesystemList &operator=(CFilesystemList &)
  57. {
  58. //class is not copyable
  59. return *this;
  60. }
  61. public:
  62. CFilesystemList();
  63. ~CFilesystemList();
  64. /// Interface implementation
  65. /// @see ISimpleResourceLoader
  66. std::unique_ptr<CInputStream> load(const ResourceID & resourceName) const override;
  67. bool existsResource(const ResourceID & resourceName) const override;
  68. std::string getMountPoint() const override;
  69. boost::optional<boost::filesystem::path> getResourceName(const ResourceID & resourceName) const override;
  70. std::unordered_set<ResourceID> getFilteredFiles(std::function<bool(const ResourceID &)> filter) const override;
  71. bool createResource(std::string filename, bool update = false) override;
  72. std::vector<const ISimpleResourceLoader *> getResourcesWithName(const ResourceID & resourceName) const override;
  73. /**
  74. * Adds a resource loader to the loaders list
  75. * Passes loader ownership to this object
  76. *
  77. * @param loader The simple resource loader object to add
  78. * @param writeable - resource shall be treated as writeable
  79. */
  80. void addLoader(ISimpleResourceLoader * loader, bool writeable);
  81. };