BsImporter.cpp 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209
  1. //********************************** Banshee Engine (www.banshee3d.com) **************************************************//
  2. //**************** Copyright (c) 2016 Marko Pintera ([email protected]). All rights reserved. **********************//
  3. #include "BsImporter.h"
  4. #include "BsResource.h"
  5. #include "BsFileSystem.h"
  6. #include "BsSpecificImporter.h"
  7. #include "BsShaderIncludeImporter.h"
  8. #include "BsImportOptions.h"
  9. #include "BsDebug.h"
  10. #include "BsDataStream.h"
  11. #include "BsException.h"
  12. #include "BsUUID.h"
  13. #include "BsResources.h"
  14. namespace BansheeEngine
  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, ConstImportOptionsPtr importOptions)
  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. ConstImportOptionsPtr 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. ResourcePtr importedResource = importer->import(inputFilePath, importOptions);
  69. return gResources()._createResourceHandle(importedResource);
  70. }
  71. Vector<SubResource> Importer::importAll(const Path& inputFilePath, ConstImportOptionsPtr importOptions)
  72. {
  73. Vector<SubResource> output;
  74. Vector<SubResourceRaw> importedResource = _importAllRaw(inputFilePath, importOptions);
  75. for(auto& entry : importedResource)
  76. {
  77. HResource handle = gResources()._createResourceHandle(entry.value);
  78. output.push_back({ entry.name, handle });
  79. }
  80. return output;
  81. }
  82. Vector<SubResourceRaw> Importer::_importAllRaw(const Path& inputFilePath, ConstImportOptionsPtr importOptions)
  83. {
  84. if (!FileSystem::isFile(inputFilePath))
  85. {
  86. LOGWRN("Trying to import asset that doesn't exists. Asset path: " + inputFilePath.toString());
  87. return Vector<SubResourceRaw>();
  88. }
  89. SpecificImporter* importer = getImporterForFile(inputFilePath);
  90. if (importer == nullptr)
  91. return Vector<SubResourceRaw>();
  92. if (importOptions == nullptr)
  93. importOptions = importer->getDefaultImportOptions();
  94. else
  95. {
  96. ConstImportOptionsPtr defaultImportOptions = importer->getDefaultImportOptions();
  97. if (importOptions->getTypeId() != defaultImportOptions->getTypeId())
  98. {
  99. BS_EXCEPT(InvalidParametersException, "Provided import options is not of valid type. " \
  100. "Expected: " + defaultImportOptions->getTypeName() + ". Got: " + importOptions->getTypeName() + ".");
  101. }
  102. }
  103. return importer->importAll(inputFilePath, importOptions);
  104. }
  105. void Importer::reimport(HResource& existingResource, const Path& inputFilePath, ConstImportOptionsPtr importOptions)
  106. {
  107. if(!FileSystem::isFile(inputFilePath))
  108. {
  109. LOGWRN("Trying to import asset that doesn't exists. Asset path: " + inputFilePath.toString());
  110. return;
  111. }
  112. SpecificImporter* importer = getImporterForFile(inputFilePath);
  113. if(importer == nullptr)
  114. return;
  115. if(importOptions == nullptr)
  116. importOptions = importer->getDefaultImportOptions();
  117. else
  118. {
  119. ConstImportOptionsPtr defaultImportOptions = importer->getDefaultImportOptions();
  120. if(importOptions->getTypeId() != defaultImportOptions->getTypeId())
  121. {
  122. BS_EXCEPT(InvalidParametersException, "Provided import options is not of valid type. " \
  123. "Expected: " + defaultImportOptions->getTypeName() + ". Got: " + importOptions->getTypeName() + ".");
  124. }
  125. }
  126. ResourcePtr importedResource = importer->import(inputFilePath, importOptions);
  127. gResources().update(existingResource, importedResource);
  128. }
  129. ImportOptionsPtr Importer::createImportOptions(const Path& inputFilePath)
  130. {
  131. if(!FileSystem::isFile(inputFilePath))
  132. {
  133. LOGWRN("Trying to import asset that doesn't exists. Asset path: " + inputFilePath.toString());
  134. return nullptr;
  135. }
  136. SpecificImporter* importer = getImporterForFile(inputFilePath);
  137. if(importer == nullptr)
  138. return nullptr;
  139. return importer->createImportOptions();
  140. }
  141. void Importer::_registerAssetImporter(SpecificImporter* importer)
  142. {
  143. if(!importer)
  144. {
  145. LOGWRN("Trying to register a null asset importer!");
  146. return;
  147. }
  148. mAssetImporters.push_back(importer);
  149. }
  150. SpecificImporter* Importer::getImporterForFile(const Path& inputFilePath) const
  151. {
  152. WString ext = inputFilePath.getWExtension();
  153. if (ext.empty())
  154. return nullptr;
  155. ext = ext.substr(1, ext.size() - 1); // Remove the .
  156. if(!supportsFileType(ext))
  157. {
  158. LOGWRN("There is no importer for the provided file type. (" + inputFilePath.toString() + ")");
  159. return nullptr;
  160. }
  161. for(auto iter = mAssetImporters.begin(); iter != mAssetImporters.end(); ++iter)
  162. {
  163. if(*iter != nullptr && (*iter)->isExtensionSupported(ext))
  164. {
  165. return *iter;
  166. }
  167. }
  168. return nullptr;
  169. }
  170. BS_CORE_EXPORT Importer& gImporter()
  171. {
  172. return Importer::instance();
  173. }
  174. }