BsImporter.cpp 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211
  1. //********************************** Banshee Engine (www.banshee3d.com) **************************************************//
  2. //**************** Copyright (c) 2016 Marko Pintera ([email protected]). All rights reserved. **********************//
  3. #include "Importer/BsImporter.h"
  4. #include "Resources/BsResource.h"
  5. #include "FileSystem/BsFileSystem.h"
  6. #include "Importer/BsSpecificImporter.h"
  7. #include "Importer/BsShaderIncludeImporter.h"
  8. #include "Importer/BsImportOptions.h"
  9. #include "Debug/BsDebug.h"
  10. #include "FileSystem/BsDataStream.h"
  11. #include "Error/BsException.h"
  12. #include "Utility/BsUUID.h"
  13. #include "Resources/BsResources.h"
  14. namespace bs
  15. {
  16. Importer::Importer()
  17. {
  18. _registerAssetImporter(bs_new<ShaderIncludeImporter>());
  19. }
  20. Importer::~Importer()
  21. {
  22. for(auto i = mAssetImporters.begin(); i != mAssetImporters.end(); ++i)
  23. {
  24. if((*i) != nullptr)
  25. bs_delete(*i);
  26. }
  27. mAssetImporters.clear();
  28. }
  29. bool Importer::supportsFileType(const WString& extension) const
  30. {
  31. for(auto iter = mAssetImporters.begin(); iter != mAssetImporters.end(); ++iter)
  32. {
  33. if(*iter != nullptr && (*iter)->isExtensionSupported(extension))
  34. return true;
  35. }
  36. return false;
  37. }
  38. bool Importer::supportsFileType(const UINT8* magicNumber, UINT32 magicNumSize) const
  39. {
  40. for(auto iter = mAssetImporters.begin(); iter != mAssetImporters.end(); ++iter)
  41. {
  42. if(*iter != nullptr && (*iter)->isMagicNumberSupported(magicNumber, magicNumSize))
  43. return true;
  44. }
  45. return false;
  46. }
  47. HResource Importer::import(const Path& inputFilePath, SPtr<const ImportOptions> importOptions, const String& UUID)
  48. {
  49. if(!FileSystem::isFile(inputFilePath))
  50. {
  51. LOGWRN("Trying to import asset that doesn't exists. Asset path: " + inputFilePath.toString());
  52. return HResource();
  53. }
  54. SpecificImporter* importer = getImporterForFile(inputFilePath);
  55. if(importer == nullptr)
  56. return HResource();
  57. if(importOptions == nullptr)
  58. importOptions = importer->getDefaultImportOptions();
  59. else
  60. {
  61. SPtr<const ImportOptions> defaultImportOptions = importer->getDefaultImportOptions();
  62. if(importOptions->getTypeId() != defaultImportOptions->getTypeId())
  63. {
  64. BS_EXCEPT(InvalidParametersException, "Provided import options is not of valid type. " \
  65. "Expected: " + defaultImportOptions->getTypeName() + ". Got: " + importOptions->getTypeName() + ".");
  66. }
  67. }
  68. SPtr<Resource> importedResource = importer->import(inputFilePath, importOptions);
  69. if(UUID.empty())
  70. return gResources()._createResourceHandle(importedResource);
  71. return gResources()._createResourceHandle(importedResource, UUID);
  72. }
  73. Vector<SubResource> Importer::importAll(const Path& inputFilePath, SPtr<const ImportOptions> importOptions)
  74. {
  75. Vector<SubResource> output;
  76. Vector<SubResourceRaw> importedResource = _importAllRaw(inputFilePath, importOptions);
  77. for(auto& entry : importedResource)
  78. {
  79. HResource handle = gResources()._createResourceHandle(entry.value);
  80. output.push_back({ entry.name, handle });
  81. }
  82. return output;
  83. }
  84. Vector<SubResourceRaw> Importer::_importAllRaw(const Path& inputFilePath, SPtr<const ImportOptions> importOptions)
  85. {
  86. if (!FileSystem::isFile(inputFilePath))
  87. {
  88. LOGWRN("Trying to import asset that doesn't exists. Asset path: " + inputFilePath.toString());
  89. return Vector<SubResourceRaw>();
  90. }
  91. SpecificImporter* importer = getImporterForFile(inputFilePath);
  92. if (importer == nullptr)
  93. return Vector<SubResourceRaw>();
  94. if (importOptions == nullptr)
  95. importOptions = importer->getDefaultImportOptions();
  96. else
  97. {
  98. SPtr<const ImportOptions> defaultImportOptions = importer->getDefaultImportOptions();
  99. if (importOptions->getTypeId() != defaultImportOptions->getTypeId())
  100. {
  101. BS_EXCEPT(InvalidParametersException, "Provided import options is not of valid type. " \
  102. "Expected: " + defaultImportOptions->getTypeName() + ". Got: " + importOptions->getTypeName() + ".");
  103. }
  104. }
  105. return importer->importAll(inputFilePath, importOptions);
  106. }
  107. void Importer::reimport(HResource& existingResource, const Path& inputFilePath, SPtr<const ImportOptions> importOptions)
  108. {
  109. if(!FileSystem::isFile(inputFilePath))
  110. {
  111. LOGWRN("Trying to import asset that doesn't exists. Asset path: " + inputFilePath.toString());
  112. return;
  113. }
  114. SpecificImporter* importer = getImporterForFile(inputFilePath);
  115. if(importer == nullptr)
  116. return;
  117. if(importOptions == nullptr)
  118. importOptions = importer->getDefaultImportOptions();
  119. else
  120. {
  121. SPtr<const ImportOptions> defaultImportOptions = importer->getDefaultImportOptions();
  122. if(importOptions->getTypeId() != defaultImportOptions->getTypeId())
  123. {
  124. BS_EXCEPT(InvalidParametersException, "Provided import options is not of valid type. " \
  125. "Expected: " + defaultImportOptions->getTypeName() + ". Got: " + importOptions->getTypeName() + ".");
  126. }
  127. }
  128. SPtr<Resource> importedResource = importer->import(inputFilePath, importOptions);
  129. gResources().update(existingResource, importedResource);
  130. }
  131. SPtr<ImportOptions> Importer::createImportOptions(const Path& inputFilePath)
  132. {
  133. if(!FileSystem::isFile(inputFilePath))
  134. {
  135. LOGWRN("Trying to import asset that doesn't exists. Asset path: " + inputFilePath.toString());
  136. return nullptr;
  137. }
  138. SpecificImporter* importer = getImporterForFile(inputFilePath);
  139. if(importer == nullptr)
  140. return nullptr;
  141. return importer->createImportOptions();
  142. }
  143. void Importer::_registerAssetImporter(SpecificImporter* importer)
  144. {
  145. if(!importer)
  146. {
  147. LOGWRN("Trying to register a null asset importer!");
  148. return;
  149. }
  150. mAssetImporters.push_back(importer);
  151. }
  152. SpecificImporter* Importer::getImporterForFile(const Path& inputFilePath) const
  153. {
  154. WString ext = inputFilePath.getWExtension();
  155. if (ext.empty())
  156. return nullptr;
  157. ext = ext.substr(1, ext.size() - 1); // Remove the .
  158. if(!supportsFileType(ext))
  159. {
  160. LOGWRN("There is no importer for the provided file type. (" + inputFilePath.toString() + ")");
  161. return nullptr;
  162. }
  163. for(auto iter = mAssetImporters.begin(); iter != mAssetImporters.end(); ++iter)
  164. {
  165. if(*iter != nullptr && (*iter)->isExtensionSupported(ext))
  166. {
  167. return *iter;
  168. }
  169. }
  170. return nullptr;
  171. }
  172. BS_CORE_EXPORT Importer& gImporter()
  173. {
  174. return Importer::instance();
  175. }
  176. }