mirror of
				https://github.com/Laupetin/OpenAssetTools.git
				synced 2025-10-25 07:45:52 +00:00 
			
		
		
		
	Replace FileAPI with c++ streams and std::filesystem
This commit is contained in:
		| @@ -241,8 +241,8 @@ class AssetDumperFontIconInternal | ||||
|     } | ||||
|  | ||||
| public: | ||||
|     explicit AssetDumperFontIconInternal(FileAPI::IFile* file) | ||||
|         : m_csv(file) | ||||
|     explicit AssetDumperFontIconInternal(std::ostream& stream) | ||||
|         : m_csv(stream) | ||||
|     { | ||||
|     } | ||||
|  | ||||
| @@ -265,8 +265,8 @@ std::string AssetDumperFontIcon::GetFileNameForAsset(Zone* zone, XAssetInfo<Font | ||||
|     return asset->m_name; | ||||
| } | ||||
|  | ||||
| void AssetDumperFontIcon::DumpAsset(Zone* zone, XAssetInfo<FontIcon>* asset, FileAPI::File* out) | ||||
| void AssetDumperFontIcon::DumpAsset(Zone* zone, XAssetInfo<FontIcon>* asset, std::ostream& stream) | ||||
| { | ||||
|     AssetDumperFontIconInternal dumper(out); | ||||
|     AssetDumperFontIconInternal dumper(stream); | ||||
|     dumper.DumpFontIcon(asset->Asset()); | ||||
| } | ||||
|   | ||||
| @@ -10,6 +10,6 @@ namespace T6 | ||||
|     protected: | ||||
|         bool ShouldDump(XAssetInfo<FontIcon>* asset) override; | ||||
|         std::string GetFileNameForAsset(Zone* zone, XAssetInfo<FontIcon>* asset) override; | ||||
|         void DumpAsset(Zone* zone, XAssetInfo<FontIcon>* asset, FileAPI::File* out) override; | ||||
|         void DumpAsset(Zone* zone, XAssetInfo<FontIcon>* asset, std::ostream& stream) override; | ||||
|     }; | ||||
| } | ||||
|   | ||||
| @@ -42,8 +42,8 @@ std::string AssetDumperGfxImage::GetFileNameForAsset(Zone* zone, XAssetInfo<GfxI | ||||
|     return "images/" + asset->m_name + m_writer->GetFileExtension(); | ||||
| } | ||||
|  | ||||
| void AssetDumperGfxImage::DumpAsset(Zone* zone, XAssetInfo<GfxImage>* asset, FileAPI::File* out) | ||||
| void AssetDumperGfxImage::DumpAsset(Zone* zone, XAssetInfo<GfxImage>* asset, std::ostream& stream) | ||||
| { | ||||
|     const auto* image = asset->Asset(); | ||||
|     m_writer->DumpImage(out, image->texture.texture); | ||||
|     m_writer->DumpImage(stream, image->texture.texture); | ||||
| } | ||||
|   | ||||
| @@ -13,7 +13,7 @@ namespace T6 | ||||
|     protected: | ||||
|         bool ShouldDump(XAssetInfo<GfxImage>* asset) override; | ||||
|         std::string GetFileNameForAsset(Zone* zone, XAssetInfo<GfxImage>* asset) override; | ||||
|         void DumpAsset(Zone* zone, XAssetInfo<GfxImage>* asset, FileAPI::File* out) override; | ||||
|         void DumpAsset(Zone* zone, XAssetInfo<GfxImage>* asset, std::ostream& stream) override; | ||||
|  | ||||
|     public: | ||||
|         AssetDumperGfxImage(); | ||||
|   | ||||
| @@ -1,25 +1,35 @@ | ||||
| #include "AssetDumperLocalizeEntry.h" | ||||
|  | ||||
| #include <fstream> | ||||
| #include <filesystem> | ||||
|  | ||||
| #include "Dumping/Localize/LocalizeCommon.h" | ||||
| #include "Dumping/Localize/StringFileDumper.h" | ||||
|  | ||||
| using namespace T6; | ||||
| namespace fs = std::filesystem; | ||||
|  | ||||
| void AssetDumperLocalizeEntry::DumpPool(Zone* zone, AssetPool<LocalizeEntry>* pool, const std::string& basePath) | ||||
| { | ||||
|     if (pool->m_asset_lookup.empty()) | ||||
|         return; | ||||
|  | ||||
|     const std::string language = LocalizeCommon::GetNameOfLanguage(zone->m_language); | ||||
|     const std::string stringsPath = utils::Path::Combine(basePath, language + "/localizedstrings"); | ||||
|     const auto language = LocalizeCommon::GetNameOfLanguage(zone->m_language); | ||||
|     fs::path stringsPath(basePath); | ||||
|     stringsPath.append(language); | ||||
|     stringsPath.append("/localizedstrings"); | ||||
|  | ||||
|     FileAPI::DirectoryCreate(stringsPath); | ||||
|     create_directories(stringsPath); | ||||
|  | ||||
|     FileAPI::File stringFile = FileAPI::Open(utils::Path::Combine(stringsPath, zone->m_name + ".str"), FileAPI::Mode::MODE_WRITE); | ||||
|     auto stringFilePath(stringsPath); | ||||
|     stringFilePath.append(zone->m_name); | ||||
|     stringFilePath.append(".str"); | ||||
|  | ||||
|     if(stringFile.IsOpen()) | ||||
|     std::ofstream stringFile(stringFilePath, std::fstream::out | std::ofstream::binary); | ||||
|  | ||||
|     if(stringFile.is_open()) | ||||
|     { | ||||
|         StringFileDumper stringFileDumper(zone, &stringFile); | ||||
|         StringFileDumper stringFileDumper(zone, stringFile); | ||||
|  | ||||
|         stringFileDumper.SetLanguageName(language); | ||||
|  | ||||
| @@ -28,14 +38,14 @@ void AssetDumperLocalizeEntry::DumpPool(Zone* zone, AssetPool<LocalizeEntry>* po | ||||
|  | ||||
|         stringFileDumper.SetNotes(""); | ||||
|  | ||||
|         for(auto localizeEntry : *pool) | ||||
|         for(auto* localizeEntry : *pool) | ||||
|         { | ||||
|             stringFileDumper.WriteLocalizeEntry(localizeEntry->m_name, localizeEntry->Asset()->value); | ||||
|         } | ||||
|  | ||||
|         stringFileDumper.Finalize(); | ||||
|  | ||||
|         stringFile.Close(); | ||||
|         stringFile.close(); | ||||
|     } | ||||
|     else | ||||
|     { | ||||
|   | ||||
| @@ -138,7 +138,7 @@ std::string AssetDumperPhysConstraints::GetFileNameForAsset(Zone* zone, XAssetIn | ||||
|     return "physconstraints/" + asset->m_name; | ||||
| } | ||||
|  | ||||
| void AssetDumperPhysConstraints::DumpAsset(Zone* zone, XAssetInfo<PhysConstraints>* asset, FileAPI::File* out) | ||||
| void AssetDumperPhysConstraints::DumpAsset(Zone* zone, XAssetInfo<PhysConstraints>* asset, std::ostream& stream) | ||||
| { | ||||
|     assert(asset->Asset()->count <= 4); | ||||
|  | ||||
| @@ -153,5 +153,5 @@ void AssetDumperPhysConstraints::DumpAsset(Zone* zone, XAssetInfo<PhysConstraint | ||||
|  | ||||
|     const auto infoString = converter.Convert(); | ||||
|     const auto stringValue = infoString.ToString("PHYSCONSTRAINTS"); | ||||
|     out->Write(stringValue.c_str(), 1, stringValue.length()); | ||||
|     stream.write(stringValue.c_str(), stringValue.size()); | ||||
| } | ||||
|   | ||||
| @@ -12,6 +12,6 @@ namespace T6 | ||||
|     protected: | ||||
|         bool ShouldDump(XAssetInfo<PhysConstraints>* asset) override; | ||||
|         std::string GetFileNameForAsset(Zone* zone, XAssetInfo<PhysConstraints>* asset) override; | ||||
|         void DumpAsset(Zone* zone, XAssetInfo<PhysConstraints>* asset, FileAPI::File* out) override; | ||||
|         void DumpAsset(Zone* zone, XAssetInfo<PhysConstraints>* asset, std::ostream& stream) override; | ||||
|     }; | ||||
| } | ||||
|   | ||||
| @@ -86,7 +86,7 @@ std::string AssetDumperPhysPreset::GetFileNameForAsset(Zone* zone, XAssetInfo<Ph | ||||
|     return "physic/" + asset->m_name; | ||||
| } | ||||
|  | ||||
| void AssetDumperPhysPreset::DumpAsset(Zone* zone, XAssetInfo<PhysPreset>* asset, FileAPI::File* out) | ||||
| void AssetDumperPhysPreset::DumpAsset(Zone* zone, XAssetInfo<PhysPreset>* asset, std::ostream& stream) | ||||
| { | ||||
|     auto* physPresetInfo = new PhysPresetInfo; | ||||
|     CopyToPhysPresetInfo(asset->Asset(), physPresetInfo); | ||||
| @@ -102,7 +102,7 @@ void AssetDumperPhysPreset::DumpAsset(Zone* zone, XAssetInfo<PhysPreset>* asset, | ||||
|  | ||||
|     const auto infoString = converter.Convert(); | ||||
|     const auto stringValue = infoString.ToString("PHYSIC"); | ||||
|     out->Write(stringValue.c_str(), 1, stringValue.length()); | ||||
|     stream.write(stringValue.c_str(), stringValue.size()); | ||||
|  | ||||
|     delete physPresetInfo; | ||||
| } | ||||
|   | ||||
| @@ -14,6 +14,6 @@ namespace T6 | ||||
|     protected: | ||||
|         bool ShouldDump(XAssetInfo<PhysPreset>* asset) override; | ||||
|         std::string GetFileNameForAsset(Zone* zone, XAssetInfo<PhysPreset>* asset) override; | ||||
|         void DumpAsset(Zone* zone, XAssetInfo<PhysPreset>* asset, FileAPI::File* out) override; | ||||
|         void DumpAsset(Zone* zone, XAssetInfo<PhysPreset>* asset, std::ostream& stream) override; | ||||
|     }; | ||||
| } | ||||
|   | ||||
| @@ -12,8 +12,8 @@ std::string AssetDumperQdb::GetFileNameForAsset(Zone* zone, XAssetInfo<Qdb>* ass | ||||
|     return asset->m_name; | ||||
| } | ||||
|  | ||||
| void AssetDumperQdb::DumpAsset(Zone* zone, XAssetInfo<Qdb>* asset, FileAPI::File* out) | ||||
| void AssetDumperQdb::DumpAsset(Zone* zone, XAssetInfo<Qdb>* asset, std::ostream& stream) | ||||
| { | ||||
|     const auto* qdb = asset->Asset(); | ||||
|     out->Write(qdb->buffer, 1, qdb->len); | ||||
|     stream.write(qdb->buffer, qdb->len); | ||||
| } | ||||
| @@ -10,6 +10,6 @@ namespace T6 | ||||
|     protected: | ||||
|         bool ShouldDump(XAssetInfo<Qdb>* asset) override; | ||||
|         std::string GetFileNameForAsset(Zone* zone, XAssetInfo<Qdb>* asset) override; | ||||
|         void DumpAsset(Zone* zone, XAssetInfo<Qdb>* asset, FileAPI::File* out) override; | ||||
|         void DumpAsset(Zone* zone, XAssetInfo<Qdb>* asset, std::ostream& stream) override; | ||||
|     }; | ||||
| } | ||||
|   | ||||
| @@ -12,8 +12,8 @@ std::string AssetDumperRawFile::GetFileNameForAsset(Zone* zone, XAssetInfo<RawFi | ||||
|     return asset->m_name; | ||||
| } | ||||
|  | ||||
| void AssetDumperRawFile::DumpAsset(Zone* zone, XAssetInfo<RawFile>* asset, FileAPI::File* out) | ||||
| void AssetDumperRawFile::DumpAsset(Zone* zone, XAssetInfo<RawFile>* asset, std::ostream& stream) | ||||
| { | ||||
|     const auto* rawFile = asset->Asset(); | ||||
|     out->Write(rawFile->buffer, 1, rawFile->len); | ||||
|     stream.write(rawFile->buffer, rawFile->len); | ||||
| } | ||||
| @@ -10,6 +10,6 @@ namespace T6 | ||||
|     protected: | ||||
|         bool ShouldDump(XAssetInfo<RawFile>* asset) override; | ||||
|         std::string GetFileNameForAsset(Zone* zone, XAssetInfo<RawFile>* asset) override; | ||||
|         void DumpAsset(Zone* zone, XAssetInfo<RawFile>* asset, FileAPI::File* out) override; | ||||
|         void DumpAsset(Zone* zone, XAssetInfo<RawFile>* asset, std::ostream& stream) override; | ||||
|     }; | ||||
| } | ||||
|   | ||||
| @@ -12,8 +12,8 @@ std::string AssetDumperScriptParseTree::GetFileNameForAsset(Zone* zone, XAssetIn | ||||
|     return asset->m_name; | ||||
| } | ||||
|  | ||||
| void AssetDumperScriptParseTree::DumpAsset(Zone* zone, XAssetInfo<ScriptParseTree>* asset, FileAPI::File* out) | ||||
| void AssetDumperScriptParseTree::DumpAsset(Zone* zone, XAssetInfo<ScriptParseTree>* asset, std::ostream& stream) | ||||
| { | ||||
|     const auto* scriptParseTree = asset->Asset(); | ||||
|     out->Write(scriptParseTree->buffer, 1, scriptParseTree->len); | ||||
|     stream.write(scriptParseTree->buffer, scriptParseTree->len); | ||||
| } | ||||
| @@ -10,6 +10,6 @@ namespace T6 | ||||
|     protected: | ||||
|         bool ShouldDump(XAssetInfo<ScriptParseTree>* asset) override; | ||||
|         std::string GetFileNameForAsset(Zone* zone, XAssetInfo<ScriptParseTree>* asset) override; | ||||
|         void DumpAsset(Zone* zone, XAssetInfo<ScriptParseTree>* asset, FileAPI::File* out) override; | ||||
|         void DumpAsset(Zone* zone, XAssetInfo<ScriptParseTree>* asset, std::ostream& stream) override; | ||||
|     }; | ||||
| } | ||||
|   | ||||
| @@ -12,8 +12,8 @@ std::string AssetDumperSlug::GetFileNameForAsset(Zone* zone, XAssetInfo<Slug>* a | ||||
|     return asset->m_name; | ||||
| } | ||||
|  | ||||
| void AssetDumperSlug::DumpAsset(Zone* zone, XAssetInfo<Slug>* asset, FileAPI::File* out) | ||||
| void AssetDumperSlug::DumpAsset(Zone* zone, XAssetInfo<Slug>* asset, std::ostream& stream) | ||||
| { | ||||
|     const auto* slug = asset->Asset(); | ||||
|     out->Write(slug->buffer, 1, slug->len); | ||||
|     stream.write(slug->buffer, slug->len); | ||||
| } | ||||
| @@ -10,6 +10,6 @@ namespace T6 | ||||
|     protected: | ||||
|         bool ShouldDump(XAssetInfo<Slug>* asset) override; | ||||
|         std::string GetFileNameForAsset(Zone* zone, XAssetInfo<Slug>* asset) override; | ||||
|         void DumpAsset(Zone* zone, XAssetInfo<Slug>* asset, FileAPI::File* out) override; | ||||
|         void DumpAsset(Zone* zone, XAssetInfo<Slug>* asset, std::ostream& stream) override; | ||||
|     }; | ||||
| } | ||||
|   | ||||
| @@ -14,14 +14,14 @@ std::string AssetDumperStringTable::GetFileNameForAsset(Zone* zone, XAssetInfo<S | ||||
|     return asset->m_name; | ||||
| } | ||||
|  | ||||
| void AssetDumperStringTable::DumpAsset(Zone* zone, XAssetInfo<StringTable>* asset, FileAPI::File* out) | ||||
| void AssetDumperStringTable::DumpAsset(Zone* zone, XAssetInfo<StringTable>* asset, std::ostream& stream) | ||||
| { | ||||
|     const auto* stringTable = asset->Asset(); | ||||
|     CsvWriter csv(out); | ||||
|     CsvWriter csv(stream); | ||||
|  | ||||
|     for(int row = 0; row < stringTable->rowCount; row++) | ||||
|     for(auto row = 0; row < stringTable->rowCount; row++) | ||||
|     { | ||||
|         for(int column = 0; column < stringTable->columnCount; column++) | ||||
|         for(auto column = 0; column < stringTable->columnCount; column++) | ||||
|         { | ||||
|             const auto* cell = &stringTable->values[column + row * stringTable->columnCount]; | ||||
|             csv.WriteColumn(cell->string); | ||||
|   | ||||
| @@ -10,6 +10,6 @@ namespace T6 | ||||
|     protected: | ||||
|         bool ShouldDump(XAssetInfo<StringTable>* asset) override; | ||||
|         std::string GetFileNameForAsset(Zone* zone, XAssetInfo<StringTable>* asset) override; | ||||
|         void DumpAsset(Zone* zone, XAssetInfo<StringTable>* asset, FileAPI::File* out) override; | ||||
|         void DumpAsset(Zone* zone, XAssetInfo<StringTable>* asset, std::ostream& stream) override; | ||||
|     }; | ||||
| } | ||||
|   | ||||
| @@ -85,7 +85,7 @@ std::string AssetDumperTracer::GetFileNameForAsset(Zone* zone, XAssetInfo<Tracer | ||||
|     return "tracer/" + asset->m_name; | ||||
| } | ||||
|  | ||||
| void AssetDumperTracer::DumpAsset(Zone* zone, XAssetInfo<TracerDef>* asset, FileAPI::File* out) | ||||
| void AssetDumperTracer::DumpAsset(Zone* zone, XAssetInfo<TracerDef>* asset, std::ostream& stream) | ||||
| { | ||||
|     InfoStringFromTracerConverter converter(asset->Asset(), tracer_fields, _countof(tracer_fields), [asset](const scr_string_t scrStr) -> std::string | ||||
|         { | ||||
| @@ -98,7 +98,7 @@ void AssetDumperTracer::DumpAsset(Zone* zone, XAssetInfo<TracerDef>* asset, File | ||||
|  | ||||
|     const auto infoString = converter.Convert(); | ||||
|     const auto stringValue = infoString.ToString("TRACER"); | ||||
|     out->Write(stringValue.c_str(), 1, stringValue.length()); | ||||
|     stream.write(stringValue.c_str(), stringValue.size()); | ||||
| } | ||||
|  | ||||
| //void AssetDumperTracer::CheckFields() | ||||
|   | ||||
| @@ -12,6 +12,6 @@ namespace T6 | ||||
|     protected: | ||||
|         bool ShouldDump(XAssetInfo<TracerDef>* asset) override; | ||||
|         std::string GetFileNameForAsset(Zone* zone, XAssetInfo<TracerDef>* asset) override; | ||||
|         void DumpAsset(Zone* zone, XAssetInfo<TracerDef>* asset, FileAPI::File* out) override; | ||||
|         void DumpAsset(Zone* zone, XAssetInfo<TracerDef>* asset, std::ostream& stream) override; | ||||
|     }; | ||||
| } | ||||
|   | ||||
| @@ -680,7 +680,7 @@ std::string AssetDumperVehicle::GetFileNameForAsset(Zone* zone, XAssetInfo<Vehic | ||||
|     return "vehicles/" + asset->m_name; | ||||
| } | ||||
|  | ||||
| void AssetDumperVehicle::DumpAsset(Zone* zone, XAssetInfo<VehicleDef>* asset, FileAPI::File* out) | ||||
| void AssetDumperVehicle::DumpAsset(Zone* zone, XAssetInfo<VehicleDef>* asset, std::ostream& stream) | ||||
| { | ||||
|     InfoStringFromVehicleConverter converter(asset->Asset(), vehicle_fields, _countof(vehicle_fields), [asset](const scr_string_t scrStr) -> std::string | ||||
|     { | ||||
| @@ -693,5 +693,5 @@ void AssetDumperVehicle::DumpAsset(Zone* zone, XAssetInfo<VehicleDef>* asset, Fi | ||||
|  | ||||
|     const auto infoString = converter.Convert(); | ||||
|     const auto stringValue = infoString.ToString("VEHICLEFILE"); | ||||
|     out->Write(stringValue.c_str(), 1, stringValue.length()); | ||||
|     stream.write(stringValue.c_str(), stringValue.size()); | ||||
| } | ||||
|   | ||||
| @@ -12,6 +12,6 @@ namespace T6 | ||||
|     protected: | ||||
|         bool ShouldDump(XAssetInfo<VehicleDef>* asset) override; | ||||
|         std::string GetFileNameForAsset(Zone* zone, XAssetInfo<VehicleDef>* asset) override; | ||||
|         void DumpAsset(Zone* zone, XAssetInfo<VehicleDef>* asset, FileAPI::File* out) override; | ||||
|         void DumpAsset(Zone* zone, XAssetInfo<VehicleDef>* asset, std::ostream& stream) override; | ||||
|     }; | ||||
| } | ||||
|   | ||||
| @@ -1620,7 +1620,7 @@ std::string AssetDumperWeapon::GetFileNameForAsset(Zone* zone, XAssetInfo<Weapon | ||||
|     return "weapons/" + asset->m_name; | ||||
| } | ||||
|  | ||||
| void AssetDumperWeapon::DumpAsset(Zone* zone, XAssetInfo<WeaponVariantDef>* asset, FileAPI::File* out) | ||||
| void AssetDumperWeapon::DumpAsset(Zone* zone, XAssetInfo<WeaponVariantDef>* asset, std::ostream& stream) | ||||
| { | ||||
|     auto* fullDef = new WeaponFullDef; | ||||
|     memset(fullDef, 0, sizeof WeaponFullDef); | ||||
| @@ -1637,7 +1637,7 @@ void AssetDumperWeapon::DumpAsset(Zone* zone, XAssetInfo<WeaponVariantDef>* asse | ||||
|  | ||||
|     const auto infoString = converter.Convert(); | ||||
|     const auto stringValue = infoString.ToString("WEAPONFILE"); | ||||
|     out->Write(stringValue.c_str(), 1, stringValue.length()); | ||||
|     stream.write(stringValue.c_str(), stringValue.size()); | ||||
|  | ||||
|     delete fullDef; | ||||
| } | ||||
|   | ||||
| @@ -14,6 +14,6 @@ namespace T6 | ||||
|     protected: | ||||
|         bool ShouldDump(XAssetInfo<WeaponVariantDef>* asset) override; | ||||
|         std::string GetFileNameForAsset(Zone* zone, XAssetInfo<WeaponVariantDef>* asset) override; | ||||
|         void DumpAsset(Zone* zone, XAssetInfo<WeaponVariantDef>* asset, FileAPI::File* out) override; | ||||
|         void DumpAsset(Zone* zone, XAssetInfo<WeaponVariantDef>* asset, std::ostream& stream) override; | ||||
|     }; | ||||
| } | ||||
|   | ||||
| @@ -183,7 +183,7 @@ std::string AssetDumperZBarrier::GetFileNameForAsset(Zone* zone, XAssetInfo<ZBar | ||||
|     return "zbarrier/" + asset->m_name; | ||||
| } | ||||
|  | ||||
| void AssetDumperZBarrier::DumpAsset(Zone* zone, XAssetInfo<ZBarrierDef>* asset, FileAPI::File* out) | ||||
| void AssetDumperZBarrier::DumpAsset(Zone* zone, XAssetInfo<ZBarrierDef>* asset, std::ostream& stream) | ||||
| { | ||||
|     InfoStringFromZBarrierConverter converter(asset->Asset(), zbarrier_fields, _countof(zbarrier_fields), [asset](const scr_string_t scrStr) -> std::string | ||||
|         { | ||||
| @@ -196,7 +196,7 @@ void AssetDumperZBarrier::DumpAsset(Zone* zone, XAssetInfo<ZBarrierDef>* asset, | ||||
|  | ||||
|     const auto infoString = converter.Convert(); | ||||
|     const auto stringValue = infoString.ToString("ZBARRIER"); | ||||
|     out->Write(stringValue.c_str(), 1, stringValue.length()); | ||||
|     stream.write(stringValue.c_str(), stringValue.size()); | ||||
| } | ||||
|  | ||||
| //void AssetDumperZBarrier::CheckFields() | ||||
|   | ||||
| @@ -12,6 +12,6 @@ namespace T6 | ||||
|     protected: | ||||
|         bool ShouldDump(XAssetInfo<ZBarrierDef>* asset) override; | ||||
|         std::string GetFileNameForAsset(Zone* zone, XAssetInfo<ZBarrierDef>* asset) override; | ||||
|         void DumpAsset(Zone* zone, XAssetInfo<ZBarrierDef>* asset, FileAPI::File* out) override; | ||||
|         void DumpAsset(Zone* zone, XAssetInfo<ZBarrierDef>* asset, std::ostream& stream) override; | ||||
|     }; | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user