mirror of
				https://github.com/AxioDL/metaforce.git
				synced 2025-10-25 12:50:24 +00:00 
			
		
		
		
	Humungous refactor
This commit is contained in:
		
							parent
							
								
									552ec1db4a
								
							
						
					
					
						commit
						783fb4c4fe
					
				| @ -1,6 +1,6 @@ | |||||||
| cmake_minimum_required(VERSION 3.0) | cmake_minimum_required(VERSION 3.0) | ||||||
| cmake_policy(SET CMP0054 NEW) | cmake_policy(SET CMP0054 NEW) | ||||||
| project(PathShagged) | project(urde) | ||||||
| if(MSVC) | if(MSVC) | ||||||
|   # Shaddup MSVC |   # Shaddup MSVC | ||||||
|   add_definitions(-DUNICODE=1 -D_UNICODE=1 -D__SSE__=1 -D_CRT_SECURE_NO_WARNINGS=1 -DD_SCL_SECURE_NO_WARNINGS=1 /wd4267 /wd4244 /wd4305 /MP) |   add_definitions(-DUNICODE=1 -D_UNICODE=1 -D__SSE__=1 -D_CRT_SECURE_NO_WARNINGS=1 -DD_SCL_SECURE_NO_WARNINGS=1 /wd4267 /wd4244 /wd4305 /MP) | ||||||
| @ -53,7 +53,7 @@ if(USE_LD_GOLD AND ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang" OR "${CMAKE_CXX_ | |||||||
|     endif() |     endif() | ||||||
| endif() | endif() | ||||||
| 
 | 
 | ||||||
| set(BOO_INCLUDE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/hecl/extern/libBoo/include) | set(BOO_INCLUDE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/hecl/extern/boo/include) | ||||||
| set(HECL_INCLUDE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/hecl/include | set(HECL_INCLUDE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/hecl/include | ||||||
|                      ${CMAKE_CURRENT_SOURCE_DIR}/hecl/blender) |                      ${CMAKE_CURRENT_SOURCE_DIR}/hecl/blender) | ||||||
| 
 | 
 | ||||||
| @ -67,25 +67,25 @@ set(HECL_DATASPEC_DECLS | |||||||
| "/* RetroCommon specs */ | "/* RetroCommon specs */ | ||||||
| namespace DataSpec | namespace DataSpec | ||||||
| { | { | ||||||
|     extern HECL::Database::DataSpecEntry SpecEntMP1; |     extern hecl::Database::DataSpecEntry SpecEntMP1; | ||||||
|     extern HECL::Database::DataSpecEntry SpecEntMP2; |     extern hecl::Database::DataSpecEntry SpecEntMP2; | ||||||
|     extern HECL::Database::DataSpecEntry SpecEntMP3; |     extern hecl::Database::DataSpecEntry SpecEntMP3; | ||||||
| }") | }") | ||||||
| set(HECL_DATASPEC_PUSHES | set(HECL_DATASPEC_PUSHES | ||||||
| "    /* RetroCommon */ | "    /* RetroCommon */ | ||||||
|     HECL::Database::DATA_SPEC_REGISTRY.push_back(&DataSpec::SpecEntMP1); |     hecl::Database::DATA_SPEC_REGISTRY.push_back(&DataSpec::SpecEntMP1); | ||||||
|     HECL::Database::DATA_SPEC_REGISTRY.push_back(&DataSpec::SpecEntMP2); |     hecl::Database::DATA_SPEC_REGISTRY.push_back(&DataSpec::SpecEntMP2); | ||||||
|     HECL::Database::DATA_SPEC_REGISTRY.push_back(&DataSpec::SpecEntMP3);") |     hecl::Database::DATA_SPEC_REGISTRY.push_back(&DataSpec::SpecEntMP3);") | ||||||
| add_subdirectory(hecl) | add_subdirectory(hecl) | ||||||
| add_definitions(${BOO_SYS_DEFINES}) | add_definitions(${BOO_SYS_DEFINES}) | ||||||
| add_subdirectory(libSpecter) | add_subdirectory(specter) | ||||||
| set(SPECTER_INCLUDE_DIR libSpecter/include libSpecter/freetype2/include) | set(SPECTER_INCLUDE_DIR specter/include specter/freetype2/include) | ||||||
| add_subdirectory(NODLib) | add_subdirectory(nod) | ||||||
| set(NODLIB_INCLUDE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/NODLib/include) | set(NOD_INCLUDE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/nod/include) | ||||||
| add_definitions(-DZE_ATHENA_TYPES=1) | add_definitions(-DZE_ATHENA_TYPES=1) | ||||||
| set(MATHLIB_INCLUDE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/libSpecter/MathLib/include) | set(ZEUS_INCLUDE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/specter/zeus/include) | ||||||
| include_directories(${ATHENA_INCLUDE_DIR} ${LOG_VISOR_INCLUDE_DIR} ${HECL_INCLUDE_DIR} | include_directories(${ATHENA_INCLUDE_DIR} ${LOGVISOR_INCLUDE_DIR} ${HECL_INCLUDE_DIR} | ||||||
|                     ${NODLIB_INCLUDE_DIR} ${MATHLIB_INCLUDE_DIR} ${BOO_INCLUDE_DIR} |                     ${NOD_INCLUDE_DIR} ${ZEUS_INCLUDE_DIR} ${BOO_INCLUDE_DIR} | ||||||
|                     ${SPECTER_INCLUDE_DIR} ${ZLIB_INCLUDE_DIR} ${CMAKE_CURRENT_SOURCE_DIR}) |                     ${SPECTER_INCLUDE_DIR} ${ZLIB_INCLUDE_DIR} ${CMAKE_CURRENT_SOURCE_DIR}) | ||||||
| add_subdirectory(DataSpec) | add_subdirectory(DataSpec) | ||||||
| add_subdirectory(Editor) | add_subdirectory(Editor) | ||||||
|  | |||||||
| @ -10,13 +10,13 @@ namespace DataSpec | |||||||
| namespace Blender | namespace Blender | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| bool BuildMasterShader(const HECL::ProjectPath& path) | bool BuildMasterShader(const hecl::ProjectPath& path) | ||||||
| { | { | ||||||
|     HECL::BlenderConnection& conn = HECL::BlenderConnection::SharedConnection(); |     hecl::BlenderConnection& conn = hecl::BlenderConnection::SharedConnection(); | ||||||
|     if (!conn.createBlend(path, HECL::BlenderConnection::BlendType::None)) |     if (!conn.createBlend(path, hecl::BlenderConnection::BlendType::None)) | ||||||
|         return false; |         return false; | ||||||
|     { |     { | ||||||
|         HECL::BlenderConnection::PyOutStream os = conn.beginPythonOut(true); |         hecl::BlenderConnection::PyOutStream os = conn.beginPythonOut(true); | ||||||
|         os << RETRO_MASTER_SHADER; |         os << RETRO_MASTER_SHADER; | ||||||
|         os << "make_master_shader_library()\n"; |         os << "make_master_shader_library()\n"; | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -1,14 +1,14 @@ | |||||||
| #ifndef _RETRO_BLENDER_SUPPORT_HPP_ | #ifndef _RETRO_BLENDER_SUPPORT_HPP_ | ||||||
| #define _RETRO_BLENDER_SUPPORT_HPP_ | #define _RETRO_BLENDER_SUPPORT_HPP_ | ||||||
| 
 | 
 | ||||||
| #include <HECL/HECL.hpp> | #include <hecl/hecl.hpp> | ||||||
| 
 | 
 | ||||||
| namespace DataSpec | namespace DataSpec | ||||||
| { | { | ||||||
| namespace Blender | namespace Blender | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| bool BuildMasterShader(const HECL::ProjectPath& path); | bool BuildMasterShader(const hecl::ProjectPath& path); | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
| } | } | ||||||
|  | |||||||
| @ -11,7 +11,7 @@ namespace DataSpec | |||||||
| namespace DNAANCS | namespace DNAANCS | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| using Actor = HECL::BlenderConnection::DataStream::Actor; | using Actor = hecl::BlenderConnection::DataStream::Actor; | ||||||
| 
 | 
 | ||||||
| template <typename IDTYPE> | template <typename IDTYPE> | ||||||
| struct CharacterResInfo | struct CharacterResInfo | ||||||
| @ -20,7 +20,7 @@ struct CharacterResInfo | |||||||
|     IDTYPE cmdl; |     IDTYPE cmdl; | ||||||
|     IDTYPE cskr; |     IDTYPE cskr; | ||||||
|     IDTYPE cinf; |     IDTYPE cinf; | ||||||
|     std::vector<std::pair<HECL::FourCC, std::pair<IDTYPE, IDTYPE>>> overlays; |     std::vector<std::pair<hecl::FourCC, std::pair<IDTYPE, IDTYPE>>> overlays; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| template <typename IDTYPE> | template <typename IDTYPE> | ||||||
| @ -33,13 +33,13 @@ struct AnimationResInfo | |||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| template <class PAKRouter, class ANCSDNA, class MaterialSet, class SurfaceHeader, atUint32 CMDLVersion> | template <class PAKRouter, class ANCSDNA, class MaterialSet, class SurfaceHeader, atUint32 CMDLVersion> | ||||||
| bool ReadANCSToBlender(HECL::BlenderConnection& conn, | bool ReadANCSToBlender(hecl::BlenderConnection& conn, | ||||||
|                        const ANCSDNA& ancs, |                        const ANCSDNA& ancs, | ||||||
|                        const HECL::ProjectPath& outPath, |                        const hecl::ProjectPath& outPath, | ||||||
|                        PAKRouter& pakRouter, |                        PAKRouter& pakRouter, | ||||||
|                        const typename PAKRouter::EntryType& entry, |                        const typename PAKRouter::EntryType& entry, | ||||||
|                        const SpecBase& dataspec, |                        const SpecBase& dataspec, | ||||||
|                        std::function<void(const HECL::SystemChar*)> fileChanged, |                        std::function<void(const hecl::SystemChar*)> fileChanged, | ||||||
|                        bool force=false) |                        bool force=false) | ||||||
| {     | {     | ||||||
|     /* Extract character CMDL/CSKR first */ |     /* Extract character CMDL/CSKR first */ | ||||||
| @ -47,17 +47,18 @@ bool ReadANCSToBlender(HECL::BlenderConnection& conn, | |||||||
|     ancs.getCharacterResInfo(chResInfo); |     ancs.getCharacterResInfo(chResInfo); | ||||||
|     for (const auto& info : chResInfo) |     for (const auto& info : chResInfo) | ||||||
|     { |     { | ||||||
|         const NOD::Node* node; |         const nod::Node* node; | ||||||
|         const typename PAKRouter::EntryType* cmdlE = pakRouter.lookupEntry(info.cmdl, &node, true, true); |         const typename PAKRouter::EntryType* cmdlE = pakRouter.lookupEntry(info.cmdl, &node, true, true); | ||||||
|         if (cmdlE) |         if (cmdlE) | ||||||
|         { |         { | ||||||
|             HECL::ProjectPath cmdlPath = pakRouter.getWorking(cmdlE); |             hecl::ProjectPath cmdlPath = pakRouter.getWorking(cmdlE); | ||||||
|             if (force || cmdlPath.getPathType() == HECL::ProjectPath::Type::None) |             if (force || cmdlPath.getPathType() == hecl::ProjectPath::Type::None) | ||||||
|             { |             { | ||||||
|                 if (!conn.createBlend(cmdlPath, HECL::BlenderConnection::BlendType::Mesh)) |                 if (!conn.createBlend(cmdlPath, hecl::BlenderConnection::BlendType::Mesh)) | ||||||
|                     return false; |                     return false; | ||||||
| 
 | 
 | ||||||
|                 HECL::SystemStringView bestNameView(pakRouter.getBestEntryName(*cmdlE)); |                 std::string bestName = pakRouter.getBestEntryName(*cmdlE); | ||||||
|  |                 hecl::SystemStringView bestNameView(bestName); | ||||||
|                 fileChanged(bestNameView.sys_str().c_str()); |                 fileChanged(bestNameView.sys_str().c_str()); | ||||||
| 
 | 
 | ||||||
|                 typename ANCSDNA::CSKRType cskr; |                 typename ANCSDNA::CSKRType cskr; | ||||||
| @ -76,13 +77,14 @@ bool ReadANCSToBlender(HECL::BlenderConnection& conn, | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     HECL::SystemStringView bestNameView(pakRouter.getBestEntryName(entry)); |     std::string bestName = pakRouter.getBestEntryName(entry); | ||||||
|  |     hecl::SystemStringView bestNameView(bestName); | ||||||
|     fileChanged(bestNameView.sys_str().c_str()); |     fileChanged(bestNameView.sys_str().c_str()); | ||||||
| 
 | 
 | ||||||
|     /* Establish ANCS blend */ |     /* Establish ANCS blend */ | ||||||
|     if (!conn.createBlend(outPath, HECL::BlenderConnection::BlendType::Actor)) |     if (!conn.createBlend(outPath, hecl::BlenderConnection::BlendType::Actor)) | ||||||
|         return false; |         return false; | ||||||
|     HECL::BlenderConnection::PyOutStream os = conn.beginPythonOut(true); |     hecl::BlenderConnection::PyOutStream os = conn.beginPythonOut(true); | ||||||
| 
 | 
 | ||||||
|     os.format("import bpy\n" |     os.format("import bpy\n" | ||||||
|               "from mathutils import Vector\n" |               "from mathutils import Vector\n" | ||||||
| @ -125,7 +127,7 @@ bool ReadANCSToBlender(HECL::BlenderConnection& conn, | |||||||
|         const typename PAKRouter::EntryType* cmdlE = pakRouter.lookupEntry(info.cmdl, nullptr, true, true); |         const typename PAKRouter::EntryType* cmdlE = pakRouter.lookupEntry(info.cmdl, nullptr, true, true); | ||||||
|         if (cmdlE) |         if (cmdlE) | ||||||
|         { |         { | ||||||
|             HECL::ProjectPath cmdlPath = pakRouter.getWorking(cmdlE); |             hecl::ProjectPath cmdlPath = pakRouter.getWorking(cmdlE); | ||||||
|             os.linkBlend(cmdlPath.getAbsolutePathUTF8().c_str(), |             os.linkBlend(cmdlPath.getAbsolutePathUTF8().c_str(), | ||||||
|                          pakRouter.getBestEntryName(*cmdlE).c_str(), true); |                          pakRouter.getBestEntryName(*cmdlE).c_str(), true); | ||||||
| 
 | 
 | ||||||
| @ -147,7 +149,7 @@ bool ReadANCSToBlender(HECL::BlenderConnection& conn, | |||||||
|             const typename PAKRouter::EntryType* cmdlE = pakRouter.lookupEntry(overlay.second.first, nullptr, true, true); |             const typename PAKRouter::EntryType* cmdlE = pakRouter.lookupEntry(overlay.second.first, nullptr, true, true); | ||||||
|             if (cmdlE) |             if (cmdlE) | ||||||
|             { |             { | ||||||
|                 HECL::ProjectPath cmdlPath = pakRouter.getWorking(cmdlE); |                 hecl::ProjectPath cmdlPath = pakRouter.getWorking(cmdlE); | ||||||
|                 os.linkBlend(cmdlPath.getAbsolutePathUTF8().c_str(), |                 os.linkBlend(cmdlPath.getAbsolutePathUTF8().c_str(), | ||||||
|                              pakRouter.getBestEntryName(*cmdlE).c_str(), true); |                              pakRouter.getBestEntryName(*cmdlE).c_str(), true); | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -1,5 +1,4 @@ | |||||||
| #define _USE_MATH_DEFINES | #include "zeus/Math.hpp" | ||||||
| #include <math.h> |  | ||||||
| #include "ANIM.hpp" | #include "ANIM.hpp" | ||||||
| 
 | 
 | ||||||
| namespace DataSpec | namespace DataSpec | ||||||
| @ -39,50 +38,50 @@ size_t ComputeBitstreamSize(size_t keyFrameCount, const std::vector<Channel>& ch | |||||||
| 
 | 
 | ||||||
| static inline QuantizedRot QuantizeRotation(const Value& quat, atUint32 div) | static inline QuantizedRot QuantizeRotation(const Value& quat, atUint32 div) | ||||||
| { | { | ||||||
|     float q = M_PI / 2.0 / div; |     float q = M_PI / 2.0f / float(div); | ||||||
|     return |     return | ||||||
|     { |     { | ||||||
|         { |         { | ||||||
|             atInt16(asinf(quat.v4.vec[1]) / q), |             atInt16(std::asin(quat.v4.vec[1]) / q), | ||||||
|             atInt16(asinf(quat.v4.vec[2]) / q), |             atInt16(std::asin(quat.v4.vec[2]) / q), | ||||||
|             atInt16(asinf(quat.v4.vec[3]) / q), |             atInt16(std::asin(quat.v4.vec[3]) / q), | ||||||
|         }, |         }, | ||||||
|         (quat.v4.vec[0] < 0) ? true : false |         (quat.v4.vec[0] < 0.f) ? true : false | ||||||
|     }; |     }; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static inline Value DequantizeRotation(const QuantizedRot& v, atUint32 div) | static inline Value DequantizeRotation(const QuantizedRot& v, atUint32 div) | ||||||
| { | { | ||||||
|     float q = M_PI / 2.0 / div; |     float q = M_PI / 2.0f / float(div); | ||||||
|     Value retval = |     Value retval = | ||||||
|     { |     { | ||||||
|         0.0, |         0.0f, | ||||||
|         sinf(v.v[0] * q), |         std::sin(v.v[0] * q), | ||||||
|         sinf(v.v[1] * q), |         std::sin(v.v[1] * q), | ||||||
|         sinf(v.v[2] * q), |         std::sin(v.v[2] * q), | ||||||
|     }; |     }; | ||||||
|     retval.v4.vec[0] = sqrtf(std::max((1.0 - |     retval.v4.vec[0] = std::sqrt(std::max((1.0f - | ||||||
|                                (retval.v4.vec[1] * retval.v4.vec[1] + |                                (retval.v4.vec[1] * retval.v4.vec[1] + | ||||||
|                                 retval.v4.vec[2] * retval.v4.vec[2] + |                                 retval.v4.vec[2] * retval.v4.vec[2] + | ||||||
|                                 retval.v4.vec[3] * retval.v4.vec[3])), 0.0)); |                                 retval.v4.vec[3] * retval.v4.vec[3])), 0.0f)); | ||||||
|     retval.v4.vec[0] = v.w ? -retval.v4.vec[0] : retval.v4.vec[0]; |     retval.v4.vec[0] = v.w ? -retval.v4.vec[0] : retval.v4.vec[0]; | ||||||
|     return retval; |     return retval; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static inline Value DequantizeRotation_3(const QuantizedRot& v, atUint32 div) | static inline Value DequantizeRotation_3(const QuantizedRot& v, atUint32 div) | ||||||
| { | { | ||||||
|     float q = 1.0 / div; |     float q = 1.0f / float(div); | ||||||
|     Value retval = |     Value retval = | ||||||
|     { |     { | ||||||
|         0.0, |         0.0f, | ||||||
|         v.v[0] * q, |         v.v[0] * q, | ||||||
|         v.v[1] * q, |         v.v[1] * q, | ||||||
|         v.v[2] * q, |         v.v[2] * q, | ||||||
|     }; |     }; | ||||||
|     retval.v4.vec[0] = sqrtf(std::max((1.0 - |     retval.v4.vec[0] = std::sqrt(std::max((1.0f - | ||||||
|                                (retval.v4.vec[1] * retval.v4.vec[1] + |                                (retval.v4.vec[1] * retval.v4.vec[1] + | ||||||
|                                 retval.v4.vec[2] * retval.v4.vec[2] + |                                 retval.v4.vec[2] * retval.v4.vec[2] + | ||||||
|                                 retval.v4.vec[3] * retval.v4.vec[3])), 0.0)); |                                 retval.v4.vec[3] * retval.v4.vec[3])), 0.0f)); | ||||||
|     retval.v4.vec[0] = v.w ? -retval.v4.vec[0] : retval.v4.vec[0]; |     retval.v4.vec[0] = v.w ? -retval.v4.vec[0] : retval.v4.vec[0]; | ||||||
|     return retval; |     return retval; | ||||||
| } | } | ||||||
| @ -94,7 +93,7 @@ bool BitstreamReader::dequantizeBit(const atUint8* data) | |||||||
| 
 | 
 | ||||||
|     /* Fill 32 bit buffer with region containing bits */ |     /* Fill 32 bit buffer with region containing bits */ | ||||||
|     /* Make them least significant */ |     /* Make them least significant */ | ||||||
|     atUint32 tempBuf = HECL::SBig(*reinterpret_cast<const atUint32*>(data + byteCur)) >> bitRem; |     atUint32 tempBuf = hecl::SBig(*reinterpret_cast<const atUint32*>(data + byteCur)) >> bitRem; | ||||||
| 
 | 
 | ||||||
|     /* That's it */ |     /* That's it */ | ||||||
|     m_bitCur += 1; |     m_bitCur += 1; | ||||||
| @ -108,13 +107,13 @@ atInt16 BitstreamReader::dequantize(const atUint8* data, atUint8 q) | |||||||
| 
 | 
 | ||||||
|     /* Fill 32 bit buffer with region containing bits */ |     /* Fill 32 bit buffer with region containing bits */ | ||||||
|     /* Make them least significant */ |     /* Make them least significant */ | ||||||
|     atUint32 tempBuf = HECL::SBig(*reinterpret_cast<const atUint32*>(data + byteCur)) >> bitRem; |     atUint32 tempBuf = hecl::SBig(*reinterpret_cast<const atUint32*>(data + byteCur)) >> bitRem; | ||||||
| 
 | 
 | ||||||
|     /* If this shift underflows the value, buffer the next 32 bits */ |     /* If this shift underflows the value, buffer the next 32 bits */ | ||||||
|     /* And tack onto shifted buffer */ |     /* And tack onto shifted buffer */ | ||||||
|     if ((bitRem + q) > 32) |     if ((bitRem + q) > 32) | ||||||
|     { |     { | ||||||
|         atUint32 tempBuf2 = HECL::SBig(*reinterpret_cast<const atUint32*>(data + byteCur + 4)); |         atUint32 tempBuf2 = hecl::SBig(*reinterpret_cast<const atUint32*>(data + byteCur + 4)); | ||||||
|         tempBuf |= (tempBuf2 << (32 - bitRem)); |         tempBuf |= (tempBuf2 << (32 - bitRem)); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -256,7 +255,7 @@ void BitstreamWriter::quantizeBit(atUint8* data, bool val) | |||||||
|     /* Fill 32 bit buffer with region containing bits */ |     /* Fill 32 bit buffer with region containing bits */ | ||||||
|     /* Make them least significant */ |     /* Make them least significant */ | ||||||
|     *(atUint32*)(data + byteCur) = |     *(atUint32*)(data + byteCur) = | ||||||
|     HECL::SBig(HECL::SBig(*(atUint32*)(data + byteCur)) | (val << bitRem)); |     hecl::SBig(hecl::SBig(*(atUint32*)(data + byteCur)) | (val << bitRem)); | ||||||
| 
 | 
 | ||||||
|     m_bitCur += 1; |     m_bitCur += 1; | ||||||
| } | } | ||||||
| @ -271,14 +270,14 @@ void BitstreamWriter::quantize(atUint8* data, atUint8 q, atInt16 val) | |||||||
|     /* Fill 32 bit buffer with region containing bits */ |     /* Fill 32 bit buffer with region containing bits */ | ||||||
|     /* Make them least significant */ |     /* Make them least significant */ | ||||||
|     *(atUint32*)(data + byteCur) = |     *(atUint32*)(data + byteCur) = | ||||||
|     HECL::SBig(HECL::SBig(*(atUint32*)(data + byteCur)) | (masked << bitRem)); |     hecl::SBig(hecl::SBig(*(atUint32*)(data + byteCur)) | (masked << bitRem)); | ||||||
| 
 | 
 | ||||||
|     /* If this shift underflows the value, buffer the next 32 bits */ |     /* If this shift underflows the value, buffer the next 32 bits */ | ||||||
|     /* And tack onto shifted buffer */ |     /* And tack onto shifted buffer */ | ||||||
|     if ((bitRem + q) > 32) |     if ((bitRem + q) > 32) | ||||||
|     { |     { | ||||||
|         *(atUint32*)(data + byteCur + 4) = |         *(atUint32*)(data + byteCur + 4) = | ||||||
|         HECL::SBig(HECL::SBig(*(atUint32*)(data + byteCur + 4)) | (masked >> (32 - bitRem))); |         hecl::SBig(hecl::SBig(*(atUint32*)(data + byteCur + 4)) | (masked >> (32 - bitRem))); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     m_bitCur += q; |     m_bitCur += q; | ||||||
| @ -295,7 +294,7 @@ BitstreamWriter::write(const std::vector<std::vector<Value>>& chanKeys, | |||||||
|     rotDivOut = 32767; /* Normalized range of values */ |     rotDivOut = 32767; /* Normalized range of values */ | ||||||
| 
 | 
 | ||||||
|     /* Pre-pass to calculate translation multiplier */ |     /* Pre-pass to calculate translation multiplier */ | ||||||
|     float maxTransDiff = 0.0; |     float maxTransDiff = 0.0f; | ||||||
|     auto kit = chanKeys.begin(); |     auto kit = chanKeys.begin(); | ||||||
|     for (Channel& chan : channels) |     for (Channel& chan : channels) | ||||||
|     { |     { | ||||||
|  | |||||||
| @ -1,18 +1,14 @@ | |||||||
| #ifndef _DNACOMMON_BABEDEAD_HPP_ | #ifndef _DNACOMMON_BABEDEAD_HPP_ | ||||||
| #define _DNACOMMON_BABEDEAD_HPP_ | #define _DNACOMMON_BABEDEAD_HPP_ | ||||||
| 
 | 
 | ||||||
| #include <BlenderConnection.hpp> | #include "BlenderConnection.hpp" | ||||||
| 
 | #include "zeus/Math.hpp" | ||||||
| #ifndef _USE_MATH_DEFINES |  | ||||||
| #define _USE_MATH_DEFINES 1 |  | ||||||
| #endif |  | ||||||
| #include <math.h> |  | ||||||
| 
 | 
 | ||||||
| namespace DataSpec | namespace DataSpec | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| template<class BabeDeadLight> | template<class BabeDeadLight> | ||||||
| void ReadBabeDeadLightToBlender(HECL::BlenderConnection::PyOutStream& os, | void ReadBabeDeadLightToBlender(hecl::BlenderConnection::PyOutStream& os, | ||||||
|                                 const BabeDeadLight& light, unsigned s, unsigned l) |                                 const BabeDeadLight& light, unsigned s, unsigned l) | ||||||
| { | { | ||||||
|     switch (light.lightType) |     switch (light.lightType) | ||||||
| @ -45,7 +41,7 @@ void ReadBabeDeadLightToBlender(HECL::BlenderConnection::PyOutStream& os, | |||||||
|                   "lamp_obj.rotation_mode = 'QUATERNION'\n" |                   "lamp_obj.rotation_mode = 'QUATERNION'\n" | ||||||
|                   "lamp_obj.rotation_quaternion = Vector((0,0,-1)).rotation_difference(Vector((%f,%f,%f)))\n" |                   "lamp_obj.rotation_quaternion = Vector((0,0,-1)).rotation_difference(Vector((%f,%f,%f)))\n" | ||||||
|                   "\n", s, l, |                   "\n", s, l, | ||||||
|                   light.spotCutoff * M_PI / 180.f, |                   zeus::degToRad(light.spotCutoff), | ||||||
|                   light.direction.vec[0], light.direction.vec[1], light.direction.vec[2]); |                   light.direction.vec[0], light.direction.vec[1], light.direction.vec[2]); | ||||||
|         break; |         break; | ||||||
|     default: return; |     default: return; | ||||||
|  | |||||||
| @ -5,8 +5,8 @@ namespace DataSpec | |||||||
| namespace DNACMDL | namespace DNACMDL | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| void InitGeomBlenderContext(HECL::BlenderConnection::PyOutStream& os, | void InitGeomBlenderContext(hecl::BlenderConnection::PyOutStream& os, | ||||||
|                             const HECL::ProjectPath& masterShaderPath) |                             const hecl::ProjectPath& masterShaderPath) | ||||||
| { | { | ||||||
|     os << "# Using 'Blender Game'\n" |     os << "# Using 'Blender Game'\n" | ||||||
|           "bpy.context.scene.render.engine = 'BLENDER_GAME'\n" |           "bpy.context.scene.render.engine = 'BLENDER_GAME'\n" | ||||||
| @ -87,7 +87,7 @@ void InitGeomBlenderContext(HECL::BlenderConnection::PyOutStream& os, | |||||||
|               "\n", masterShaderPath.getAbsolutePathUTF8().c_str()); |               "\n", masterShaderPath.getAbsolutePathUTF8().c_str()); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void FinishBlenderMesh(HECL::BlenderConnection::PyOutStream& os, | void FinishBlenderMesh(hecl::BlenderConnection::PyOutStream& os, | ||||||
|                        unsigned matSetCount, int meshIdx) |                        unsigned matSetCount, int meshIdx) | ||||||
| { | { | ||||||
|     if (meshIdx < 0) |     if (meshIdx < 0) | ||||||
|  | |||||||
| @ -1,9 +1,9 @@ | |||||||
| #ifndef _DNACOMMON_CMDL_HPP_ | #ifndef _DNACOMMON_CMDL_HPP_ | ||||||
| #define _DNACOMMON_CMDL_HPP_ | #define _DNACOMMON_CMDL_HPP_ | ||||||
| 
 | 
 | ||||||
| #include <Athena/FileWriter.hpp> | #include <athena/FileWriter.hpp> | ||||||
| #include <HECL/Frontend.hpp> | #include <hecl/Frontend.hpp> | ||||||
| #include <HECL/Backend/GX.hpp> | #include <hecl/Backend/GX.hpp> | ||||||
| #include "PAK.hpp" | #include "PAK.hpp" | ||||||
| #include "BlenderConnection.hpp" | #include "BlenderConnection.hpp" | ||||||
| #include "GX.hpp" | #include "GX.hpp" | ||||||
| @ -14,7 +14,7 @@ namespace DataSpec | |||||||
| namespace DNACMDL | namespace DNACMDL | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| using Mesh = HECL::BlenderConnection::DataStream::Mesh; | using Mesh = hecl::BlenderConnection::DataStream::Mesh; | ||||||
| 
 | 
 | ||||||
| struct Header : BigDNA | struct Header : BigDNA | ||||||
| { | { | ||||||
| @ -49,7 +49,7 @@ struct SurfaceHeader_1 : BigDNA | |||||||
|     Value<atUint32> unk2 = 0; |     Value<atUint32> unk2 = 0; | ||||||
|     Value<atUint32> aabbSz = 0; |     Value<atUint32> aabbSz = 0; | ||||||
|     Value<atVec3f> reflectionNormal; |     Value<atVec3f> reflectionNormal; | ||||||
|     Seek<DNA_COUNT(aabbSz), Athena::Current> seek2; |     Seek<DNA_COUNT(aabbSz), athena::Current> seek2; | ||||||
|     Align<32> align; |     Align<32> align; | ||||||
| 
 | 
 | ||||||
|     static constexpr bool UseMatrixSkinning() {return false;} |     static constexpr bool UseMatrixSkinning() {return false;} | ||||||
| @ -69,7 +69,7 @@ struct SurfaceHeader_2 : BigDNA | |||||||
|     Value<atVec3f> reflectionNormal; |     Value<atVec3f> reflectionNormal; | ||||||
|     Value<atInt16> skinMtxBankIdx; |     Value<atInt16> skinMtxBankIdx; | ||||||
|     Value<atUint16> surfaceGroup; |     Value<atUint16> surfaceGroup; | ||||||
|     Seek<DNA_COUNT(aabbSz), Athena::Current> seek2; |     Seek<DNA_COUNT(aabbSz), athena::Current> seek2; | ||||||
|     Align<32> align; |     Align<32> align; | ||||||
| 
 | 
 | ||||||
|     static constexpr bool UseMatrixSkinning() {return false;} |     static constexpr bool UseMatrixSkinning() {return false;} | ||||||
| @ -89,7 +89,7 @@ struct SurfaceHeader_3 : BigDNA | |||||||
|     Value<atVec3f> reflectionNormal; |     Value<atVec3f> reflectionNormal; | ||||||
|     Value<atInt16> skinMtxBankIdx; |     Value<atInt16> skinMtxBankIdx; | ||||||
|     Value<atUint16> surfaceGroup; |     Value<atUint16> surfaceGroup; | ||||||
|     Seek<DNA_COUNT(aabbSz), Athena::Current> seek2; |     Seek<DNA_COUNT(aabbSz), athena::Current> seek2; | ||||||
|     Value<atUint8> unk3; |     Value<atUint8> unk3; | ||||||
|     Align<32> align; |     Align<32> align; | ||||||
| 
 | 
 | ||||||
| @ -166,7 +166,7 @@ void GetVertexAttributes(const MaterialSet& matSet, | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| template <class PAKRouter, class MaterialSet> | template <class PAKRouter, class MaterialSet> | ||||||
| void ReadMaterialSetToBlender_1_2(HECL::BlenderConnection::PyOutStream& os, | void ReadMaterialSetToBlender_1_2(hecl::BlenderConnection::PyOutStream& os, | ||||||
|                                   const MaterialSet& matSet, |                                   const MaterialSet& matSet, | ||||||
|                                   const PAKRouter& pakRouter, |                                   const PAKRouter& pakRouter, | ||||||
|                                   const typename PAKRouter::EntryType& entry, |                                   const typename PAKRouter::EntryType& entry, | ||||||
| @ -177,16 +177,16 @@ void ReadMaterialSetToBlender_1_2(HECL::BlenderConnection::PyOutStream& os, | |||||||
|     for (const UniqueID32& tex : matSet.head.textureIDs) |     for (const UniqueID32& tex : matSet.head.textureIDs) | ||||||
|     { |     { | ||||||
|         std::string texName = pakRouter.getBestEntryName(tex); |         std::string texName = pakRouter.getBestEntryName(tex); | ||||||
|         const NOD::Node* node; |         const nod::Node* node; | ||||||
|         const typename PAKRouter::EntryType* texEntry = pakRouter.lookupEntry(tex, &node); |         const typename PAKRouter::EntryType* texEntry = pakRouter.lookupEntry(tex, &node); | ||||||
|         HECL::ProjectPath txtrPath = pakRouter.getWorking(texEntry); |         hecl::ProjectPath txtrPath = pakRouter.getWorking(texEntry); | ||||||
|         if (txtrPath.getPathType() == HECL::ProjectPath::Type::None) |         if (txtrPath.getPathType() == hecl::ProjectPath::Type::None) | ||||||
|         { |         { | ||||||
|             PAKEntryReadStream rs = texEntry->beginReadStream(*node); |             PAKEntryReadStream rs = texEntry->beginReadStream(*node); | ||||||
|             TXTR::Extract(rs, txtrPath); |             TXTR::Extract(rs, txtrPath); | ||||||
|         } |         } | ||||||
|         HECL::SystemString resPath = pakRouter.getResourceRelativePath(entry, tex); |         hecl::SystemString resPath = pakRouter.getResourceRelativePath(entry, tex); | ||||||
|         HECL::SystemUTF8View resPathView(resPath); |         hecl::SystemUTF8View resPathView(resPath); | ||||||
|         os.format("if '%s' in bpy.data.textures:\n" |         os.format("if '%s' in bpy.data.textures:\n" | ||||||
|                   "    image = bpy.data.images['%s']\n" |                   "    image = bpy.data.images['%s']\n" | ||||||
|                   "    texture = bpy.data.textures[image.name]\n" |                   "    texture = bpy.data.textures[image.name]\n" | ||||||
| @ -209,7 +209,7 @@ void ReadMaterialSetToBlender_1_2(HECL::BlenderConnection::PyOutStream& os, | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| template <class PAKRouter, class MaterialSet> | template <class PAKRouter, class MaterialSet> | ||||||
| void ReadMaterialSetToBlender_3(HECL::BlenderConnection::PyOutStream& os, | void ReadMaterialSetToBlender_3(hecl::BlenderConnection::PyOutStream& os, | ||||||
|                                 const MaterialSet& matSet, |                                 const MaterialSet& matSet, | ||||||
|                                 const PAKRouter& pakRouter, |                                 const PAKRouter& pakRouter, | ||||||
|                                 const typename PAKRouter::EntryType& entry, |                                 const typename PAKRouter::EntryType& entry, | ||||||
| @ -251,7 +251,7 @@ public: | |||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         template<class RigPair> |         template<class RigPair> | ||||||
|         void sendAdditionalVertsToBlender(HECL::BlenderConnection::PyOutStream& os, |         void sendAdditionalVertsToBlender(hecl::BlenderConnection::PyOutStream& os, | ||||||
|                                           const RigPair& rp) const |                                           const RigPair& rp) const | ||||||
|         { |         { | ||||||
|             atUint32 nextVert = 1; |             atUint32 nextVert = 1; | ||||||
| @ -312,7 +312,7 @@ private: | |||||||
|         case GX::INDEX16: |         case GX::INDEX16: | ||||||
|             if ((m_cur - m_dl.get() + 1) >= intptr_t(m_dlSize)) |             if ((m_cur - m_dl.get() + 1) >= intptr_t(m_dlSize)) | ||||||
|                 return 0; |                 return 0; | ||||||
|             retval = HECL::SBig(*(atUint16*)m_cur); |             retval = hecl::SBig(*(atUint16*)m_cur); | ||||||
|             m_cur += 2; |             m_cur += 2; | ||||||
|             break; |             break; | ||||||
|         default: break; |         default: break; | ||||||
| @ -346,7 +346,7 @@ public: | |||||||
| 
 | 
 | ||||||
|     atUint16 readVertCount() |     atUint16 readVertCount() | ||||||
|     { |     { | ||||||
|         atUint16 retval = HECL::SBig(*(atUint16*)m_cur); |         atUint16 retval = hecl::SBig(*(atUint16*)m_cur); | ||||||
|         m_cur += 2; |         m_cur += 2; | ||||||
|         return retval; |         return retval; | ||||||
|     } |     } | ||||||
| @ -510,14 +510,14 @@ public: | |||||||
|     } |     } | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| void InitGeomBlenderContext(HECL::BlenderConnection::PyOutStream& os, | void InitGeomBlenderContext(hecl::BlenderConnection::PyOutStream& os, | ||||||
|                             const HECL::ProjectPath& masterShaderPath); |                             const hecl::ProjectPath& masterShaderPath); | ||||||
| void FinishBlenderMesh(HECL::BlenderConnection::PyOutStream& os, | void FinishBlenderMesh(hecl::BlenderConnection::PyOutStream& os, | ||||||
|                        unsigned matSetCount, int meshIdx); |                        unsigned matSetCount, int meshIdx); | ||||||
| 
 | 
 | ||||||
| template <class PAKRouter, class MaterialSet, class RigPair, class SurfaceHeader> | template <class PAKRouter, class MaterialSet, class RigPair, class SurfaceHeader> | ||||||
| atUint32 ReadGeomSectionsToBlender(HECL::BlenderConnection::PyOutStream& os, | atUint32 ReadGeomSectionsToBlender(hecl::BlenderConnection::PyOutStream& os, | ||||||
|                                    Athena::io::IStreamReader& reader, |                                    athena::io::IStreamReader& reader, | ||||||
|                                    PAKRouter& pakRouter, |                                    PAKRouter& pakRouter, | ||||||
|                                    const typename PAKRouter::EntryType& entry, |                                    const typename PAKRouter::EntryType& entry, | ||||||
|                                    const RigPair& rp, |                                    const RigPair& rp, | ||||||
| @ -640,10 +640,10 @@ atUint32 ReadGeomSectionsToBlender(HECL::BlenderConnection::PyOutStream& os, | |||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         if (s < secCount - 1) |         if (s < secCount - 1) | ||||||
|             reader.seek(secStart + secSizes[s], Athena::Begin); |             reader.seek(secStart + secSizes[s], athena::Begin); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     reader.seek(afterHeaderPos, Athena::Begin); |     reader.seek(afterHeaderPos, athena::Begin); | ||||||
| 
 | 
 | ||||||
|     visitedDLOffsets = false; |     visitedDLOffsets = false; | ||||||
|     unsigned createdUVLayers = 0; |     unsigned createdUVLayers = 0; | ||||||
| @ -986,7 +986,7 @@ atUint32 ReadGeomSectionsToBlender(HECL::BlenderConnection::PyOutStream& os, | |||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         if (s < secCount - 1) |         if (s < secCount - 1) | ||||||
|             reader.seek(secStart + secSizes[s], Athena::Begin); |             reader.seek(secStart + secSizes[s], athena::Begin); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /* Finish Mesh */ |     /* Finish Mesh */ | ||||||
| @ -999,8 +999,8 @@ atUint32 ReadGeomSectionsToBlender(HECL::BlenderConnection::PyOutStream& os, | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| template <class PAKRouter, class MaterialSet, class RigPair, class SurfaceHeader, atUint32 Version> | template <class PAKRouter, class MaterialSet, class RigPair, class SurfaceHeader, atUint32 Version> | ||||||
| bool ReadCMDLToBlender(HECL::BlenderConnection& conn, | bool ReadCMDLToBlender(hecl::BlenderConnection& conn, | ||||||
|                        Athena::io::IStreamReader& reader, |                        athena::io::IStreamReader& reader, | ||||||
|                        PAKRouter& pakRouter, |                        PAKRouter& pakRouter, | ||||||
|                        const typename PAKRouter::EntryType& entry, |                        const typename PAKRouter::EntryType& entry, | ||||||
|                        const SpecBase& dataspec, |                        const SpecBase& dataspec, | ||||||
| @ -1011,18 +1011,18 @@ bool ReadCMDLToBlender(HECL::BlenderConnection& conn, | |||||||
| 
 | 
 | ||||||
|     if (head.magic != 0xDEADBABE) |     if (head.magic != 0xDEADBABE) | ||||||
|     { |     { | ||||||
|         LogDNACommon.report(LogVisor::Error, "invalid CMDL magic"); |         LogDNACommon.report(logvisor::Error, "invalid CMDL magic"); | ||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (head.version != Version) |     if (head.version != Version) | ||||||
|     { |     { | ||||||
|         LogDNACommon.report(LogVisor::Error, "invalid CMDL version"); |         LogDNACommon.report(logvisor::Error, "invalid CMDL version"); | ||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /* Open Py Stream and read sections */ |     /* Open Py Stream and read sections */ | ||||||
|     HECL::BlenderConnection::PyOutStream os = conn.beginPythonOut(true); |     hecl::BlenderConnection::PyOutStream os = conn.beginPythonOut(true); | ||||||
|     os.format("import bpy\n" |     os.format("import bpy\n" | ||||||
|               "import bmesh\n" |               "import bmesh\n" | ||||||
|               "\n" |               "\n" | ||||||
| @ -1046,14 +1046,14 @@ bool ReadCMDLToBlender(HECL::BlenderConnection& conn, | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| template <class PAKRouter, class MaterialSet> | template <class PAKRouter, class MaterialSet> | ||||||
| void NameCMDL(Athena::io::IStreamReader& reader, | void NameCMDL(athena::io::IStreamReader& reader, | ||||||
|               PAKRouter& pakRouter, |               PAKRouter& pakRouter, | ||||||
|               typename PAKRouter::EntryType& entry, |               typename PAKRouter::EntryType& entry, | ||||||
|               const SpecBase& dataspec) |               const SpecBase& dataspec) | ||||||
| { | { | ||||||
|     Header head; |     Header head; | ||||||
|     head.read(reader); |     head.read(reader); | ||||||
|     std::string bestName = HECL::Format("CMDL_%s", entry.id.toString().c_str()); |     std::string bestName = hecl::Format("CMDL_%s", entry.id.toString().c_str()); | ||||||
| 
 | 
 | ||||||
|     /* Pre-read pass to determine maximum used vert indices */ |     /* Pre-read pass to determine maximum used vert indices */ | ||||||
|     atUint32 matSecCount = 0; |     atUint32 matSecCount = 0; | ||||||
| @ -1071,11 +1071,11 @@ void NameCMDL(Athena::io::IStreamReader& reader, | |||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         if (s < head.secCount - 1) |         if (s < head.secCount - 1) | ||||||
|             reader.seek(secStart + head.secSizes[s], Athena::Begin); |             reader.seek(secStart + head.secSizes[s], athena::Begin); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static void WriteDLVal(Athena::io::FileWriter& writer, GX::AttrType type, atUint32 val) | static void WriteDLVal(athena::io::FileWriter& writer, GX::AttrType type, atUint32 val) | ||||||
| { | { | ||||||
|     switch (type) |     switch (type) | ||||||
|     { |     { | ||||||
| @ -1091,7 +1091,7 @@ static void WriteDLVal(Athena::io::FileWriter& writer, GX::AttrType type, atUint | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| template <class MaterialSet, class SurfaceHeader, atUint32 Version> | template <class MaterialSet, class SurfaceHeader, atUint32 Version> | ||||||
| bool WriteCMDL(const HECL::ProjectPath& outPath, const HECL::ProjectPath& inPath, const Mesh& mesh) | bool WriteCMDL(const hecl::ProjectPath& outPath, const hecl::ProjectPath& inPath, const Mesh& mesh) | ||||||
| { | { | ||||||
|     Header head; |     Header head; | ||||||
|     head.magic = 0xDEADBABE; |     head.magic = 0xDEADBABE; | ||||||
| @ -1110,23 +1110,23 @@ bool WriteCMDL(const HECL::ProjectPath& outPath, const HECL::ProjectPath& inPath | |||||||
|     std::vector<MaterialSet> matSets; |     std::vector<MaterialSet> matSets; | ||||||
|     matSets.reserve(mesh.materialSets.size()); |     matSets.reserve(mesh.materialSets.size()); | ||||||
|     { |     { | ||||||
|         HECL::Frontend::Frontend FE; |         hecl::Frontend::Frontend FE; | ||||||
|         for (const std::vector<Mesh::Material>& mset : mesh.materialSets) |         for (const std::vector<Mesh::Material>& mset : mesh.materialSets) | ||||||
|         { |         { | ||||||
|             matSets.emplace_back(); |             matSets.emplace_back(); | ||||||
|             MaterialSet& targetMSet = matSets.back(); |             MaterialSet& targetMSet = matSets.back(); | ||||||
|             std::vector<HECL::ProjectPath> texPaths; |             std::vector<hecl::ProjectPath> texPaths; | ||||||
|             std::vector<HECL::Backend::GX> setBackends; |             std::vector<hecl::Backend::GX> setBackends; | ||||||
|             setBackends.reserve(mset.size()); |             setBackends.reserve(mset.size()); | ||||||
| 
 | 
 | ||||||
|             size_t endOff = 0; |             size_t endOff = 0; | ||||||
|             atUint32 nextGroupIdx = 0; |             atUint32 nextGroupIdx = 0; | ||||||
|             for (const Mesh::Material& mat : mset) |             for (const Mesh::Material& mat : mset) | ||||||
|             { |             { | ||||||
|                 std::string diagName = HECL::Format("%s:%s", inPath.getLastComponentUTF8(), mat.name.c_str()); |                 std::string diagName = hecl::Format("%s:%s", inPath.getLastComponentUTF8(), mat.name.c_str()); | ||||||
|                 HECL::Frontend::IR matIR = FE.compileSource(mat.source, diagName); |                 hecl::Frontend::IR matIR = FE.compileSource(mat.source, diagName); | ||||||
|                 setBackends.emplace_back(); |                 setBackends.emplace_back(); | ||||||
|                 HECL::Backend::GX& matGX = setBackends.back(); |                 hecl::Backend::GX& matGX = setBackends.back(); | ||||||
|                 matGX.reset(matIR, FE.getDiagnostics()); |                 matGX.reset(matIR, FE.getDiagnostics()); | ||||||
| 
 | 
 | ||||||
|                 atUint32 groupIdx = -1; |                 atUint32 groupIdx = -1; | ||||||
| @ -1134,7 +1134,7 @@ bool WriteCMDL(const HECL::ProjectPath& outPath, const HECL::ProjectPath& inPath | |||||||
|                 { |                 { | ||||||
|                     for (size_t i=0 ; i<setBackends.size()-1 ; ++i) |                     for (size_t i=0 ; i<setBackends.size()-1 ; ++i) | ||||||
|                     { |                     { | ||||||
|                         const HECL::Backend::GX& other = setBackends[i]; |                         const hecl::Backend::GX& other = setBackends[i]; | ||||||
|                         if (matGX == other) |                         if (matGX == other) | ||||||
|                         { |                         { | ||||||
|                             groupIdx = i; |                             groupIdx = i; | ||||||
| @ -1153,16 +1153,16 @@ bool WriteCMDL(const HECL::ProjectPath& outPath, const HECL::ProjectPath& inPath | |||||||
|                 targetMSet.head.addMaterialEndOff(endOff); |                 targetMSet.head.addMaterialEndOff(endOff); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             for (const HECL::ProjectPath& path : texPaths) |             for (const hecl::ProjectPath& path : texPaths) | ||||||
|             { |             { | ||||||
|                 const HECL::SystemString& relPath = path.getRelativePath(); |                 const hecl::SystemString& relPath = path.getRelativePath(); | ||||||
| 
 | 
 | ||||||
|                 /* TODO: incorporate hecl hashes */ |                 /* TODO: incorporate hecl hashes */ | ||||||
|                 size_t search = relPath.find(_S("TXTR_")); |                 size_t search = relPath.find(_S("TXTR_")); | ||||||
|                 if (search != HECL::SystemString::npos) |                 if (search != hecl::SystemString::npos) | ||||||
|                     targetMSet.head.addTexture(relPath.c_str() + search + 5); |                     targetMSet.head.addTexture(relPath.c_str() + search + 5); | ||||||
|                 else |                 else | ||||||
|                     LogDNACommon.report(LogVisor::FatalError, "unable to get hash from path"); |                     LogDNACommon.report(logvisor::Fatal, "unable to get hash from path"); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             size_t secSz = targetMSet.binarySize(0); |             size_t secSz = targetMSet.binarySize(0); | ||||||
| @ -1220,7 +1220,7 @@ bool WriteCMDL(const HECL::ProjectPath& outPath, const HECL::ProjectPath& inPath | |||||||
|     { |     { | ||||||
|         size_t vertSz = matSets.at(0).materials.at(surf.materialIdx).getVAFlags().vertDLSize(); |         size_t vertSz = matSets.at(0).materials.at(surf.materialIdx).getVAFlags().vertDLSize(); | ||||||
|         if (surf.verts.size() > 65536) |         if (surf.verts.size() > 65536) | ||||||
|             LogDNACommon.report(LogVisor::FatalError, "GX DisplayList overflow"); |             LogDNACommon.report(logvisor::Fatal, "GX DisplayList overflow"); | ||||||
|         size_t secSz = 67 + surf.verts.size() * vertSz; |         size_t secSz = 67 + surf.verts.size() * vertSz; | ||||||
|         secSz32 = ROUND_UP_32(secSz); |         secSz32 = ROUND_UP_32(secSz); | ||||||
|         if (secSz32 == 0) |         if (secSz32 == 0) | ||||||
| @ -1232,7 +1232,7 @@ bool WriteCMDL(const HECL::ProjectPath& outPath, const HECL::ProjectPath& inPath | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /* Write sections */ |     /* Write sections */ | ||||||
|     Athena::io::FileWriter writer(outPath.getAbsolutePath()); |     athena::io::FileWriter writer(outPath.getAbsolutePath()); | ||||||
|     head.write(writer); |     head.write(writer); | ||||||
|     std::vector<size_t>::const_iterator padIt = paddingSizes.cbegin(); |     std::vector<size_t>::const_iterator padIt = paddingSizes.cbegin(); | ||||||
| 
 | 
 | ||||||
| @ -1280,12 +1280,12 @@ bool WriteCMDL(const HECL::ProjectPath& outPath, const HECL::ProjectPath& inPath | |||||||
| 
 | 
 | ||||||
|     /* Surfaces */ |     /* Surfaces */ | ||||||
|     GX::Primitive prim; |     GX::Primitive prim; | ||||||
|     if (mesh.topology == HECL::HMDLTopology::Triangles) |     if (mesh.topology == hecl::HMDLTopology::Triangles) | ||||||
|         prim = GX::TRIANGLES; |         prim = GX::TRIANGLES; | ||||||
|     else if (mesh.topology == HECL::HMDLTopology::TriStrips) |     else if (mesh.topology == hecl::HMDLTopology::TriStrips) | ||||||
|         prim = GX::TRIANGLESTRIP; |         prim = GX::TRIANGLESTRIP; | ||||||
|     else |     else | ||||||
|         LogDNACommon.report(LogVisor::FatalError, "unrecognized mesh output mode"); |         LogDNACommon.report(logvisor::Fatal, "unrecognized mesh output mode"); | ||||||
|     for (const Mesh::Surface& surf : mesh.surfaces) |     for (const Mesh::Surface& surf : mesh.surfaces) | ||||||
|     { |     { | ||||||
|         const typename MaterialSet::Material::VAFlags& vaFlags = |         const typename MaterialSet::Material::VAFlags& vaFlags = | ||||||
| @ -1335,7 +1335,7 @@ bool WriteCMDL(const HECL::ProjectPath& outPath, const HECL::ProjectPath& inPath | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| template <class MaterialSet, class SurfaceHeader, atUint32 Version> | template <class MaterialSet, class SurfaceHeader, atUint32 Version> | ||||||
| bool WriteHMDLCMDL(const HECL::ProjectPath& outPath, const HECL::ProjectPath& inPath, const Mesh& mesh) | bool WriteHMDLCMDL(const hecl::ProjectPath& outPath, const hecl::ProjectPath& inPath, const Mesh& mesh) | ||||||
| { | { | ||||||
|     Header head; |     Header head; | ||||||
|     head.magic = 0xDEADBABE; |     head.magic = 0xDEADBABE; | ||||||
| @ -1354,19 +1354,19 @@ bool WriteHMDLCMDL(const HECL::ProjectPath& outPath, const HECL::ProjectPath& in | |||||||
|     std::vector<MaterialSet> matSets; |     std::vector<MaterialSet> matSets; | ||||||
|     matSets.reserve(mesh.materialSets.size()); |     matSets.reserve(mesh.materialSets.size()); | ||||||
|     { |     { | ||||||
|         HECL::Frontend::Frontend FE; |         hecl::Frontend::Frontend FE; | ||||||
|         for (const std::vector<Mesh::Material>& mset : mesh.materialSets) |         for (const std::vector<Mesh::Material>& mset : mesh.materialSets) | ||||||
|         { |         { | ||||||
|             matSets.emplace_back(); |             matSets.emplace_back(); | ||||||
|             MaterialSet& targetMSet = matSets.back(); |             MaterialSet& targetMSet = matSets.back(); | ||||||
|             std::vector<HECL::ProjectPath> texPaths; |             std::vector<hecl::ProjectPath> texPaths; | ||||||
|             texPaths.reserve(mset.size()*4); |             texPaths.reserve(mset.size()*4); | ||||||
|             for (const Mesh::Material& mat : mset) |             for (const Mesh::Material& mat : mset) | ||||||
|             { |             { | ||||||
|                 for (const HECL::ProjectPath& path : mat.texs) |                 for (const hecl::ProjectPath& path : mat.texs) | ||||||
|                 { |                 { | ||||||
|                     bool found = false; |                     bool found = false; | ||||||
|                     for (const HECL::ProjectPath& ePath : texPaths) |                     for (const hecl::ProjectPath& ePath : texPaths) | ||||||
|                     { |                     { | ||||||
|                         if (path == ePath) |                         if (path == ePath) | ||||||
|                         { |                         { | ||||||
| @ -1382,22 +1382,22 @@ bool WriteHMDLCMDL(const HECL::ProjectPath& outPath, const HECL::ProjectPath& in | |||||||
|             size_t endOff = 0; |             size_t endOff = 0; | ||||||
|             for (const Mesh::Material& mat : mset) |             for (const Mesh::Material& mat : mset) | ||||||
|             { |             { | ||||||
|                 std::string diagName = HECL::Format("%s:%s", inPath.getLastComponentUTF8(), mat.name.c_str()); |                 std::string diagName = hecl::Format("%s:%s", inPath.getLastComponentUTF8(), mat.name.c_str()); | ||||||
|                 targetMSet.materials.emplace_back(FE, diagName, mat, mat.iprops, texPaths); |                 targetMSet.materials.emplace_back(FE, diagName, mat, mat.iprops, texPaths); | ||||||
|                 endOff = targetMSet.materials.back().binarySize(endOff); |                 endOff = targetMSet.materials.back().binarySize(endOff); | ||||||
|                 targetMSet.head.addMaterialEndOff(endOff); |                 targetMSet.head.addMaterialEndOff(endOff); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             for (const HECL::ProjectPath& path : texPaths) |             for (const hecl::ProjectPath& path : texPaths) | ||||||
|             { |             { | ||||||
|                 const HECL::SystemString& relPath = path.getRelativePath(); |                 const hecl::SystemString& relPath = path.getRelativePath(); | ||||||
| 
 | 
 | ||||||
|                 /* TODO: incorporate hecl hashes */ |                 /* TODO: incorporate hecl hashes */ | ||||||
|                 size_t search = relPath.find(_S("TXTR_")); |                 size_t search = relPath.find(_S("TXTR_")); | ||||||
|                 if (search != HECL::SystemString::npos) |                 if (search != hecl::SystemString::npos) | ||||||
|                     targetMSet.head.addTexture(relPath.c_str() + search + 5); |                     targetMSet.head.addTexture(relPath.c_str() + search + 5); | ||||||
|                 else |                 else | ||||||
|                     LogDNACommon.report(LogVisor::FatalError, "unable to get hash from path"); |                     LogDNACommon.report(logvisor::Fatal, "unable to get hash from path"); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             size_t secSz = targetMSet.binarySize(0); |             size_t secSz = targetMSet.binarySize(0); | ||||||
| @ -1407,7 +1407,7 @@ bool WriteHMDLCMDL(const HECL::ProjectPath& outPath, const HECL::ProjectPath& in | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     HECL::HMDLBuffers bufs = mesh.getHMDLBuffers(); |     hecl::HMDLBuffers bufs = mesh.getHMDLBuffers(); | ||||||
| 
 | 
 | ||||||
|     /* Metadata */ |     /* Metadata */ | ||||||
|     size_t secSz = bufs.m_meta.binarySize(0); |     size_t secSz = bufs.m_meta.binarySize(0); | ||||||
| @ -1445,7 +1445,7 @@ bool WriteHMDLCMDL(const HECL::ProjectPath& outPath, const HECL::ProjectPath& in | |||||||
| 
 | 
 | ||||||
|     /* Surfaces */ |     /* Surfaces */ | ||||||
|     size_t endOff = 0; |     size_t endOff = 0; | ||||||
|     for (const HECL::HMDLBuffers::Surface& surf : bufs.m_surfaces) |     for (const hecl::HMDLBuffers::Surface& surf : bufs.m_surfaces) | ||||||
|     { |     { | ||||||
|         head.secSizes.push_back(64); |         head.secSizes.push_back(64); | ||||||
|         paddingSizes.push_back(0); |         paddingSizes.push_back(0); | ||||||
| @ -1454,7 +1454,7 @@ bool WriteHMDLCMDL(const HECL::ProjectPath& outPath, const HECL::ProjectPath& in | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /* Write sections */ |     /* Write sections */ | ||||||
|     Athena::io::FileWriter writer(outPath.getAbsolutePath()); |     athena::io::FileWriter writer(outPath.getAbsolutePath()); | ||||||
|     head.write(writer); |     head.write(writer); | ||||||
|     std::vector<size_t>::const_iterator padIt = paddingSizes.cbegin(); |     std::vector<size_t>::const_iterator padIt = paddingSizes.cbegin(); | ||||||
| 
 | 
 | ||||||
| @ -1489,7 +1489,7 @@ bool WriteHMDLCMDL(const HECL::ProjectPath& outPath, const HECL::ProjectPath& in | |||||||
|     ++padIt; |     ++padIt; | ||||||
| 
 | 
 | ||||||
|     /* Surfaces */ |     /* Surfaces */ | ||||||
|     for (const HECL::HMDLBuffers::Surface& surf : bufs.m_surfaces) |     for (const hecl::HMDLBuffers::Surface& surf : bufs.m_surfaces) | ||||||
|     { |     { | ||||||
|         const Mesh::Surface& osurf = surf.m_origSurf; |         const Mesh::Surface& osurf = surf.m_origSurf; | ||||||
| 
 | 
 | ||||||
| @ -1506,7 +1506,7 @@ bool WriteHMDLCMDL(const HECL::ProjectPath& outPath, const HECL::ProjectPath& in | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /* Ensure final surface's alignment writes zeros */ |     /* Ensure final surface's alignment writes zeros */ | ||||||
|     writer.seek(-1, Athena::Current); |     writer.seek(-1, athena::Current); | ||||||
|     writer.writeUByte(0); |     writer.writeUByte(0); | ||||||
|     writer.close(); |     writer.close(); | ||||||
|     return true; |     return true; | ||||||
|  | |||||||
| @ -3,7 +3,7 @@ | |||||||
| namespace DataSpec | namespace DataSpec | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| LogVisor::LogModule LogDNACommon("Retro::DNACommon"); | logvisor::Module LogDNACommon("urde::DNACommon"); | ||||||
| SpecBase* g_curSpec = nullptr; | SpecBase* g_curSpec = nullptr; | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -2,48 +2,48 @@ | |||||||
| #define __DNA_COMMON_HPP__ | #define __DNA_COMMON_HPP__ | ||||||
| 
 | 
 | ||||||
| #include <stdio.h> | #include <stdio.h> | ||||||
| #include <Athena/DNAYaml.hpp> | #include <athena/DNAYaml.hpp> | ||||||
| #include <NOD/DiscBase.hpp> | #include <nod/DiscBase.hpp> | ||||||
| #include "HECL/HECL.hpp" | #include "hecl/hecl.hpp" | ||||||
| #include "HECL/Database.hpp" | #include "hecl/Database.hpp" | ||||||
| #include "../SpecBase.hpp" | #include "../SpecBase.hpp" | ||||||
| 
 | 
 | ||||||
| namespace DataSpec | namespace DataSpec | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| extern LogVisor::LogModule LogDNACommon; | extern logvisor::Module LogDNACommon; | ||||||
| extern SpecBase* g_curSpec; | extern SpecBase* g_curSpec; | ||||||
| 
 | 
 | ||||||
| /* This comes up a great deal */ | /* This comes up a great deal */ | ||||||
| typedef Athena::io::DNA<Athena::BigEndian> BigDNA; | typedef athena::io::DNA<athena::BigEndian> BigDNA; | ||||||
| typedef Athena::io::DNAYaml<Athena::BigEndian> BigYAML; | typedef athena::io::DNAYaml<athena::BigEndian> BigYAML; | ||||||
| 
 | 
 | ||||||
| /** FourCC with DNA read/write */ | /** FourCC with DNA read/write */ | ||||||
| class DNAFourCC final : public BigYAML, public HECL::FourCC | class DNAFourCC final : public BigYAML, public hecl::FourCC | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     DNAFourCC() : HECL::FourCC() {} |     DNAFourCC() : hecl::FourCC() {} | ||||||
|     DNAFourCC(const HECL::FourCC& other) |     DNAFourCC(const hecl::FourCC& other) | ||||||
|     : HECL::FourCC() {num = other.toUint32();} |     : hecl::FourCC() {num = other.toUint32();} | ||||||
|     DNAFourCC(const char* name) |     DNAFourCC(const char* name) | ||||||
|     : HECL::FourCC(name) {} |     : hecl::FourCC(name) {} | ||||||
|     DNAFourCC(uint32_t n) |     DNAFourCC(uint32_t n) | ||||||
|     : HECL::FourCC(n) {} |     : hecl::FourCC(n) {} | ||||||
| 
 | 
 | ||||||
|     Delete expl; |     Delete expl; | ||||||
|     void read(Athena::io::IStreamReader& reader) |     void read(athena::io::IStreamReader& reader) | ||||||
|     {reader.readUBytesToBuf(fcc, 4);} |     {reader.readUBytesToBuf(fcc, 4);} | ||||||
|     void write(Athena::io::IStreamWriter& writer) const |     void write(athena::io::IStreamWriter& writer) const | ||||||
|     {writer.writeUBytes((atUint8*)fcc, 4);} |     {writer.writeUBytes((atUint8*)fcc, 4);} | ||||||
|     void read(Athena::io::YAMLDocReader& reader) |     void read(athena::io::YAMLDocReader& reader) | ||||||
|     {std::string rs = reader.readString(nullptr); strncpy(fcc, rs.c_str(), 4);} |     {std::string rs = reader.readString(nullptr); strncpy(fcc, rs.c_str(), 4);} | ||||||
|     void write(Athena::io::YAMLDocWriter& writer) const |     void write(athena::io::YAMLDocWriter& writer) const | ||||||
|     {writer.writeString(nullptr, std::string(fcc, 4));} |     {writer.writeString(nullptr, std::string(fcc, 4));} | ||||||
|     size_t binarySize(size_t __isz) const |     size_t binarySize(size_t __isz) const | ||||||
|     {return __isz + 4;} |     {return __isz + 4;} | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| using FourCC = HECL::FourCC; | using FourCC = hecl::FourCC; | ||||||
| 
 | 
 | ||||||
| /** PAK 32-bit Unique ID */ | /** PAK 32-bit Unique ID */ | ||||||
| class UniqueID32 : public BigYAML | class UniqueID32 : public BigYAML | ||||||
| @ -52,18 +52,18 @@ class UniqueID32 : public BigYAML | |||||||
| public: | public: | ||||||
|     Delete expl; |     Delete expl; | ||||||
|     operator bool() const {return m_id != 0xffffffff && m_id != 0;} |     operator bool() const {return m_id != 0xffffffff && m_id != 0;} | ||||||
|     void read(Athena::io::IStreamReader& reader) |     void read(athena::io::IStreamReader& reader) | ||||||
|     {m_id = reader.readUint32Big();} |     {m_id = reader.readUint32Big();} | ||||||
|     void write(Athena::io::IStreamWriter& writer) const |     void write(athena::io::IStreamWriter& writer) const | ||||||
|     {writer.writeUint32Big(m_id);} |     {writer.writeUint32Big(m_id);} | ||||||
|     void read(Athena::io::YAMLDocReader& reader) |     void read(athena::io::YAMLDocReader& reader) | ||||||
|     {m_id = reader.readUint32(nullptr);} |     {m_id = reader.readUint32(nullptr);} | ||||||
|     void write(Athena::io::YAMLDocWriter& writer) const |     void write(athena::io::YAMLDocWriter& writer) const | ||||||
|     {writer.writeUint32(nullptr, m_id);} |     {writer.writeUint32(nullptr, m_id);} | ||||||
|     size_t binarySize(size_t __isz) const |     size_t binarySize(size_t __isz) const | ||||||
|     {return __isz + 4;} |     {return __isz + 4;} | ||||||
| 
 | 
 | ||||||
|     UniqueID32& operator=(const HECL::ProjectPath& path) |     UniqueID32& operator=(const hecl::ProjectPath& path) | ||||||
|     {m_id = path.hash().val32(); return *this;} |     {m_id = path.hash().val32(); return *this;} | ||||||
| 
 | 
 | ||||||
|     bool operator!=(const UniqueID32& other) const {return m_id != other.m_id;} |     bool operator!=(const UniqueID32& other) const {return m_id != other.m_id;} | ||||||
| @ -78,8 +78,8 @@ public: | |||||||
|     void clear() {m_id = 0xffffffff;} |     void clear() {m_id = 0xffffffff;} | ||||||
| 
 | 
 | ||||||
|     UniqueID32() = default; |     UniqueID32() = default; | ||||||
|     UniqueID32(Athena::io::IStreamReader& reader) {read(reader);} |     UniqueID32(athena::io::IStreamReader& reader) {read(reader);} | ||||||
|     UniqueID32(const HECL::ProjectPath& path) {*this = path;} |     UniqueID32(const hecl::ProjectPath& path) {*this = path;} | ||||||
|     UniqueID32(const char* hexStr) |     UniqueID32(const char* hexStr) | ||||||
|     { |     { | ||||||
|         char copy[9]; |         char copy[9]; | ||||||
| @ -105,18 +105,18 @@ class UniqueID64 : public BigYAML | |||||||
| public: | public: | ||||||
|     Delete expl; |     Delete expl; | ||||||
|     operator bool() const {return m_id != 0xffffffffffffffff && m_id != 0;} |     operator bool() const {return m_id != 0xffffffffffffffff && m_id != 0;} | ||||||
|     void read(Athena::io::IStreamReader& reader) |     void read(athena::io::IStreamReader& reader) | ||||||
|     {m_id = reader.readUint64Big();} |     {m_id = reader.readUint64Big();} | ||||||
|     void write(Athena::io::IStreamWriter& writer) const |     void write(athena::io::IStreamWriter& writer) const | ||||||
|     {writer.writeUint64Big(m_id);} |     {writer.writeUint64Big(m_id);} | ||||||
|     void read(Athena::io::YAMLDocReader& reader) |     void read(athena::io::YAMLDocReader& reader) | ||||||
|     {m_id = reader.readUint64(nullptr);} |     {m_id = reader.readUint64(nullptr);} | ||||||
|     void write(Athena::io::YAMLDocWriter& writer) const |     void write(athena::io::YAMLDocWriter& writer) const | ||||||
|     {writer.writeUint64(nullptr, m_id);} |     {writer.writeUint64(nullptr, m_id);} | ||||||
|     size_t binarySize(size_t __isz) const |     size_t binarySize(size_t __isz) const | ||||||
|     {return __isz + 8;} |     {return __isz + 8;} | ||||||
| 
 | 
 | ||||||
|     UniqueID64& operator=(const HECL::ProjectPath& path) |     UniqueID64& operator=(const hecl::ProjectPath& path) | ||||||
|     {m_id = path.hash().val64(); return *this;} |     {m_id = path.hash().val64(); return *this;} | ||||||
| 
 | 
 | ||||||
|     bool operator!=(const UniqueID64& other) const {return m_id != other.m_id;} |     bool operator!=(const UniqueID64& other) const {return m_id != other.m_id;} | ||||||
| @ -131,8 +131,8 @@ public: | |||||||
|     void clear() {m_id = 0xffffffffffffffff;} |     void clear() {m_id = 0xffffffffffffffff;} | ||||||
| 
 | 
 | ||||||
|     UniqueID64() = default; |     UniqueID64() = default; | ||||||
|     UniqueID64(Athena::io::IStreamReader& reader) {read(reader);} |     UniqueID64(athena::io::IStreamReader& reader) {read(reader);} | ||||||
|     UniqueID64(const HECL::ProjectPath& path) {*this = path;} |     UniqueID64(const hecl::ProjectPath& path) {*this = path;} | ||||||
|     UniqueID64(const char* hexStr) |     UniqueID64(const char* hexStr) | ||||||
|     { |     { | ||||||
|         char copy[17]; |         char copy[17]; | ||||||
| @ -174,17 +174,17 @@ public: | |||||||
|     UniqueID128() {m_id[0]=0xffffffffffffffff; m_id[1]=0xffffffffffffffff;} |     UniqueID128() {m_id[0]=0xffffffffffffffff; m_id[1]=0xffffffffffffffff;} | ||||||
|     operator bool() const |     operator bool() const | ||||||
|     {return m_id[0] != 0xffffffffffffffff && m_id[0] != 0 && m_id[1] != 0xffffffffffffffff && m_id[1] != 0;} |     {return m_id[0] != 0xffffffffffffffff && m_id[0] != 0 && m_id[1] != 0xffffffffffffffff && m_id[1] != 0;} | ||||||
|     void read(Athena::io::IStreamReader& reader) |     void read(athena::io::IStreamReader& reader) | ||||||
|     { |     { | ||||||
|         m_id[0] = reader.readUint64Big(); |         m_id[0] = reader.readUint64Big(); | ||||||
|         m_id[1] = reader.readUint64Big(); |         m_id[1] = reader.readUint64Big(); | ||||||
|     } |     } | ||||||
|     void write(Athena::io::IStreamWriter& writer) const |     void write(athena::io::IStreamWriter& writer) const | ||||||
|     { |     { | ||||||
|         writer.writeUint64Big(m_id[0]); |         writer.writeUint64Big(m_id[0]); | ||||||
|         writer.writeUint64Big(m_id[1]); |         writer.writeUint64Big(m_id[1]); | ||||||
|     } |     } | ||||||
|     void read(Athena::io::YAMLDocReader& reader) |     void read(athena::io::YAMLDocReader& reader) | ||||||
|     { |     { | ||||||
|         std::string str = reader.readString(nullptr); |         std::string str = reader.readString(nullptr); | ||||||
|         while (str.size() < 32) |         while (str.size() < 32) | ||||||
| @ -194,7 +194,7 @@ public: | |||||||
|         m_id[0] = strtoull(hStr.c_str(), nullptr, 16); |         m_id[0] = strtoull(hStr.c_str(), nullptr, 16); | ||||||
|         m_id[1] = strtoull(lStr.c_str(), nullptr, 16); |         m_id[1] = strtoull(lStr.c_str(), nullptr, 16); | ||||||
|     } |     } | ||||||
|     void write(Athena::io::YAMLDocWriter& writer) const |     void write(athena::io::YAMLDocWriter& writer) const | ||||||
|     { |     { | ||||||
|         writer.writeString(nullptr, toString().c_str()); |         writer.writeString(nullptr, toString().c_str()); | ||||||
|     } |     } | ||||||
| @ -238,31 +238,31 @@ public: | |||||||
| template <class IDTYPE> | template <class IDTYPE> | ||||||
| class PAKPath : public BigYAML | class PAKPath : public BigYAML | ||||||
| { | { | ||||||
|     HECL::ProjectPath m_path; |     hecl::ProjectPath m_path; | ||||||
|     IDTYPE m_id; |     IDTYPE m_id; | ||||||
| public: | public: | ||||||
|     HECL::ProjectPath getPath() const |     hecl::ProjectPath getPath() const | ||||||
|     { |     { | ||||||
|         if (m_path) |         if (m_path) | ||||||
|             return m_path; |             return m_path; | ||||||
|         if (!g_curSpec) |         if (!g_curSpec) | ||||||
|             LogDNACommon.report(LogVisor::FatalError, "current DataSpec not set for PAKPath"); |             LogDNACommon.report(logvisor::Fatal, "current DataSpec not set for PAKPath"); | ||||||
|         if (m_id) |         if (m_id) | ||||||
|             return g_curSpec->getWorking(m_id); |             return g_curSpec->getWorking(m_id); | ||||||
|         return HECL::ProjectPath(); |         return hecl::ProjectPath(); | ||||||
|     } |     } | ||||||
|     operator HECL::ProjectPath() const {return getPath();} |     operator hecl::ProjectPath() const {return getPath();} | ||||||
|     operator const IDTYPE&() const {return m_id;} |     operator const IDTYPE&() const {return m_id;} | ||||||
| 
 | 
 | ||||||
|     Delete _d; |     Delete _d; | ||||||
|     void read(Athena::io::IStreamReader& reader) |     void read(athena::io::IStreamReader& reader) | ||||||
|     {m_id.read(reader);} |     {m_id.read(reader);} | ||||||
|     void write(Athena::io::IStreamWriter& writer) const |     void write(athena::io::IStreamWriter& writer) const | ||||||
|     {m_id.write(writer);} |     {m_id.write(writer);} | ||||||
|     void read(Athena::io::YAMLDocReader& reader) |     void read(athena::io::YAMLDocReader& reader) | ||||||
|     { |     { | ||||||
|         if (!g_curSpec) |         if (!g_curSpec) | ||||||
|             LogDNACommon.report(LogVisor::FatalError, "current DataSpec not set for PAKPath"); |             LogDNACommon.report(logvisor::Fatal, "current DataSpec not set for PAKPath"); | ||||||
|         std::string path = reader.readString(nullptr); |         std::string path = reader.readString(nullptr); | ||||||
|         if (path.empty()) |         if (path.empty()) | ||||||
|         { |         { | ||||||
| @ -273,7 +273,7 @@ public: | |||||||
|         m_path.assign(g_curSpec->getProject(), path); |         m_path.assign(g_curSpec->getProject(), path); | ||||||
|         m_id = m_path; |         m_id = m_path; | ||||||
|     } |     } | ||||||
|     void write(Athena::io::YAMLDocWriter& writer) const |     void write(athena::io::YAMLDocWriter& writer) const | ||||||
|     { |     { | ||||||
|         if (m_path) |         if (m_path) | ||||||
|         { |         { | ||||||
| @ -295,7 +295,7 @@ class WordBitmap | |||||||
|     std::vector<atUint32> m_words; |     std::vector<atUint32> m_words; | ||||||
|     size_t m_bitCount = 0; |     size_t m_bitCount = 0; | ||||||
| public: | public: | ||||||
|     void read(Athena::io::IStreamReader& reader, size_t bitCount) |     void read(athena::io::IStreamReader& reader, size_t bitCount) | ||||||
|     { |     { | ||||||
|         m_bitCount = bitCount; |         m_bitCount = bitCount; | ||||||
|         size_t wordCount = (bitCount + 31) / 32; |         size_t wordCount = (bitCount + 31) / 32; | ||||||
| @ -304,7 +304,7 @@ public: | |||||||
|         for (size_t w=0 ; w<wordCount ; ++w) |         for (size_t w=0 ; w<wordCount ; ++w) | ||||||
|             m_words.push_back(reader.readUint32Big()); |             m_words.push_back(reader.readUint32Big()); | ||||||
|     } |     } | ||||||
|     void write(Athena::io::IStreamWriter& writer) const |     void write(athena::io::IStreamWriter& writer) const | ||||||
|     { |     { | ||||||
|         for (atUint32 word : m_words) |         for (atUint32 word : m_words) | ||||||
|             writer.writeUint32(word); |             writer.writeUint32(word); | ||||||
| @ -356,7 +356,7 @@ public: | |||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| /** Resource cooker function */ | /** Resource cooker function */ | ||||||
| typedef std::function<bool(const HECL::ProjectPath&, const HECL::ProjectPath&)> ResCooker; | typedef std::function<bool(const hecl::ProjectPath&, const hecl::ProjectPath&)> ResCooker; | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -8,7 +8,7 @@ namespace DataSpec | |||||||
| { | { | ||||||
| 
 | 
 | ||||||
| template<class DEAFBABE> | template<class DEAFBABE> | ||||||
| void DeafBabeSendToBlender(HECL::BlenderConnection::PyOutStream& os, const DEAFBABE& db) | void DeafBabeSendToBlender(hecl::BlenderConnection::PyOutStream& os, const DEAFBABE& db) | ||||||
| { | { | ||||||
|     os << "material_index = []\n" |     os << "material_index = []\n" | ||||||
|           "col_bm = bmesh.new()\n"; |           "col_bm = bmesh.new()\n"; | ||||||
|  | |||||||
| @ -1,7 +1,7 @@ | |||||||
| #ifndef _DNACOMMON_GX_HPP_ | #ifndef _DNACOMMON_GX_HPP_ | ||||||
| #define _DNACOMMON_GX_HPP_ | #define _DNACOMMON_GX_HPP_ | ||||||
| 
 | 
 | ||||||
| #include "HECL/Backend/GX.hpp" | #include "hecl/Backend/GX.hpp" | ||||||
| using GX = HECL::Backend::GX; | using GX = hecl::Backend::GX; | ||||||
| 
 | 
 | ||||||
| #endif // _DNACOMMON_GX_HPP_
 | #endif // _DNACOMMON_GX_HPP_
 | ||||||
|  | |||||||
| @ -74,13 +74,13 @@ struct MAPA : BigDNA | |||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|     void read(Athena::io::IStreamReader& __dna_reader) |     void read(athena::io::IStreamReader& __dna_reader) | ||||||
|     { |     { | ||||||
|         /* magic */ |         /* magic */ | ||||||
|         magic = __dna_reader.readUint32Big(); |         magic = __dna_reader.readUint32Big(); | ||||||
|         if (magic != 0xDEADD00D) |         if (magic != 0xDEADD00D) | ||||||
|         { |         { | ||||||
|             LogDNACommon.report(LogVisor::Error, "invalid MAPA magic"); |             LogDNACommon.report(logvisor::Error, "invalid MAPA magic"); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         /* version */ |         /* version */ | ||||||
| @ -93,7 +93,7 @@ struct MAPA : BigDNA | |||||||
|             header.reset(new HeaderMP3); |             header.reset(new HeaderMP3); | ||||||
|         else |         else | ||||||
|         { |         { | ||||||
|             LogDNACommon.report(LogVisor::Error, "invalid MAPA version"); |             LogDNACommon.report(logvisor::Error, "invalid MAPA version"); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @ -118,7 +118,7 @@ struct MAPA : BigDNA | |||||||
|         __dna_reader.enumerate(surfaces, header->surfaceCount()); |         __dna_reader.enumerate(surfaces, header->surfaceCount()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void write(Athena::io::IStreamWriter& __dna_writer) const |     void write(athena::io::IStreamWriter& __dna_writer) const | ||||||
|     { |     { | ||||||
|         /* magic */ |         /* magic */ | ||||||
|         __dna_writer.writeUint32Big(magic); |         __dna_writer.writeUint32Big(magic); | ||||||
| @ -189,9 +189,9 @@ struct MAPA : BigDNA | |||||||
|         Value<Type> type; |         Value<Type> type; | ||||||
|         Value<atUint32> unknown1; |         Value<atUint32> unknown1; | ||||||
|         Value<atUint32> sclyId; |         Value<atUint32> sclyId; | ||||||
|         Seek<DNA_COUNT(4), Athena::Current> seek1; |         Seek<DNA_COUNT(4), athena::Current> seek1; | ||||||
|         Value<atVec4f>  transformMtx[3]; |         Value<atVec4f>  transformMtx[3]; | ||||||
|         Seek<DNA_COUNT(0x10), Athena::Current> seek2; |         Seek<DNA_COUNT(0x10), athena::Current> seek2; | ||||||
|         virtual ~MappableObjectMP1_2()  {} |         virtual ~MappableObjectMP1_2()  {} | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
| @ -202,9 +202,9 @@ struct MAPA : BigDNA | |||||||
|         Value<atUint32> unknown1; |         Value<atUint32> unknown1; | ||||||
|         Value<atUint32> sclyId; |         Value<atUint32> sclyId; | ||||||
|         Buffer<DNA_COUNT(0x10)> unknownHash; |         Buffer<DNA_COUNT(0x10)> unknownHash; | ||||||
|         Seek<DNA_COUNT(4), Athena::Current> seek1; |         Seek<DNA_COUNT(4), athena::Current> seek1; | ||||||
|         Value<atVec4f>  transformMtx[3]; |         Value<atVec4f>  transformMtx[3]; | ||||||
|         Seek<DNA_COUNT(0x10), Athena::Current> seek2; |         Seek<DNA_COUNT(0x10), athena::Current> seek2; | ||||||
|         virtual ~MappableObjectMP3()  {} |         virtual ~MappableObjectMP3()  {} | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
| @ -252,21 +252,21 @@ struct MAPA : BigDNA | |||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| template <typename PAKRouter> | template <typename PAKRouter> | ||||||
| bool ReadMAPAToBlender(HECL::BlenderConnection& conn, | bool ReadMAPAToBlender(hecl::BlenderConnection& conn, | ||||||
|                        const MAPA& mapa, |                        const MAPA& mapa, | ||||||
|                        const HECL::ProjectPath& outPath, |                        const hecl::ProjectPath& outPath, | ||||||
|                        PAKRouter& pakRouter, |                        PAKRouter& pakRouter, | ||||||
|                        const typename PAKRouter::EntryType& entry, |                        const typename PAKRouter::EntryType& entry, | ||||||
|                        bool force) |                        bool force) | ||||||
| { | { | ||||||
|     /* Rename MAPA for consistency */ |     /* Rename MAPA for consistency */ | ||||||
|     HECL::ProjectPath mapaPath(outPath.getParentPath(), _S("!map.blend")); |     hecl::ProjectPath mapaPath(outPath.getParentPath(), _S("!map.blend")); | ||||||
|     if (!force && mapaPath.getPathType() == HECL::ProjectPath::Type::File) |     if (!force && mapaPath.getPathType() == hecl::ProjectPath::Type::File) | ||||||
|         return true; |         return true; | ||||||
| 
 | 
 | ||||||
|     if (!conn.createBlend(mapaPath, HECL::BlenderConnection::BlendType::MapArea)) |     if (!conn.createBlend(mapaPath, hecl::BlenderConnection::BlendType::MapArea)) | ||||||
|         return false; |         return false; | ||||||
|     HECL::BlenderConnection::PyOutStream os = conn.beginPythonOut(true); |     hecl::BlenderConnection::PyOutStream os = conn.beginPythonOut(true); | ||||||
| 
 | 
 | ||||||
|     os << "import bpy, bmesh\n" |     os << "import bpy, bmesh\n" | ||||||
|           "from mathutils import Matrix\n" |           "from mathutils import Matrix\n" | ||||||
| @ -450,8 +450,8 @@ bool ReadMAPAToBlender(HECL::BlenderConnection& conn, | |||||||
|           "bm.free()\n"; |           "bm.free()\n"; | ||||||
| 
 | 
 | ||||||
|     /* World background */ |     /* World background */ | ||||||
|     HECL::ProjectPath worldBlend(outPath.getParentPath().getParentPath(), "!world.blend"); |     hecl::ProjectPath worldBlend(outPath.getParentPath().getParentPath(), "!world.blend"); | ||||||
|     if (worldBlend.getPathType() == HECL::ProjectPath::Type::File) |     if (worldBlend.getPathType() == hecl::ProjectPath::Type::File) | ||||||
|         os.linkBackground("//../!world.blend", "World"); |         os.linkBackground("//../!world.blend", "World"); | ||||||
| 
 | 
 | ||||||
|     os.centerView(); |     os.centerView(); | ||||||
|  | |||||||
| @ -3,7 +3,7 @@ | |||||||
| 
 | 
 | ||||||
| #include "DNACommon.hpp" | #include "DNACommon.hpp" | ||||||
| #include "BlenderConnection.hpp" | #include "BlenderConnection.hpp" | ||||||
| #include "CVector3f.hpp" | #include "zeus/CVector3f.hpp" | ||||||
| 
 | 
 | ||||||
| namespace DataSpec | namespace DataSpec | ||||||
| { | { | ||||||
| @ -11,31 +11,23 @@ namespace DNAMLVL | |||||||
| { | { | ||||||
| 
 | 
 | ||||||
| template <class PAKRouter, typename MLVL> | template <class PAKRouter, typename MLVL> | ||||||
| bool ReadMLVLToBlender(HECL::BlenderConnection& conn, | bool ReadMLVLToBlender(hecl::BlenderConnection& conn, | ||||||
|                        const MLVL& mlvl, |                        const MLVL& mlvl, | ||||||
|                        const HECL::ProjectPath& outPath, |                        const hecl::ProjectPath& outPath, | ||||||
|                        PAKRouter& pakRouter, |                        PAKRouter& pakRouter, | ||||||
|                        const typename PAKRouter::EntryType& entry, |                        const typename PAKRouter::EntryType& entry, | ||||||
|                        bool force, |                        bool force, | ||||||
|                        std::function<void(const HECL::SystemChar*)> fileChanged) |                        std::function<void(const hecl::SystemChar*)> fileChanged) | ||||||
| { | { | ||||||
|     /* Rename MLVL for consistency */ |     /* Rename MLVL for consistency */ | ||||||
|     HECL::ProjectPath mlvlPath(outPath.getParentPath(), _S("!world.blend")); |     hecl::ProjectPath mlvlPath(outPath.getParentPath(), _S("!world.blend")); | ||||||
|     if (!force && mlvlPath.getPathType() == HECL::ProjectPath::Type::File) |     if (!force && mlvlPath.getPathType() == hecl::ProjectPath::Type::File) | ||||||
|         return true; |         return true; | ||||||
| 
 | 
 | ||||||
|     /* Link Skybox CMDL */ |  | ||||||
|     const typename PAKRouter::EntryType* skyboxEntry = pakRouter.lookupEntry(mlvl.worldSkyboxId); |  | ||||||
|     if (skyboxEntry) |  | ||||||
|     { |  | ||||||
|         HECL::ProjectPath skyboxPath = pakRouter.getWorking(skyboxEntry); |  | ||||||
|         HECL::ProjectPath(outPath.getParentPath(), _S("!skybox.blend")).makeLinkTo(skyboxPath); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     /* Create World Blend */ |     /* Create World Blend */ | ||||||
|     if (!conn.createBlend(mlvlPath, HECL::BlenderConnection::BlendType::World)) |     if (!conn.createBlend(mlvlPath, hecl::BlenderConnection::BlendType::World)) | ||||||
|         return false; |         return false; | ||||||
|     HECL::BlenderConnection::PyOutStream os = conn.beginPythonOut(true); |     hecl::BlenderConnection::PyOutStream os = conn.beginPythonOut(true); | ||||||
|     os.format("import bpy\n" |     os.format("import bpy\n" | ||||||
|               "import bmesh\n" |               "import bmesh\n" | ||||||
|               "from mathutils import Matrix\n" |               "from mathutils import Matrix\n" | ||||||
| @ -52,7 +44,7 @@ bool ReadMLVLToBlender(HECL::BlenderConnection& conn, | |||||||
|     for (const auto& area : mlvl.areas) |     for (const auto& area : mlvl.areas) | ||||||
|     { |     { | ||||||
|         const typename PAKRouter::EntryType* mreaEntry = pakRouter.lookupEntry(area.areaMREAId); |         const typename PAKRouter::EntryType* mreaEntry = pakRouter.lookupEntry(area.areaMREAId); | ||||||
|         HECL::SystemUTF8View areaDirName(*mreaEntry->unique.m_areaName); |         hecl::SystemUTF8View areaDirName(*mreaEntry->unique.m_areaName); | ||||||
| 
 | 
 | ||||||
|         os.AABBToBMesh(area.aabb[0], area.aabb[1]); |         os.AABBToBMesh(area.aabb[0], area.aabb[1]); | ||||||
|         os.format("box_mesh = bpy.data.meshes.new('''%s''')\n" |         os.format("box_mesh = bpy.data.meshes.new('''%s''')\n" | ||||||
| @ -76,14 +68,14 @@ bool ReadMLVLToBlender(HECL::BlenderConnection& conn, | |||||||
|         for (const auto& dock : area.docks) |         for (const auto& dock : area.docks) | ||||||
|         { |         { | ||||||
|             os << "bm = bmesh.new()\n"; |             os << "bm = bmesh.new()\n"; | ||||||
|             Zeus::CVector3f pvAvg; |             zeus::CVector3f pvAvg; | ||||||
|             for (const atVec3f& pv : dock.planeVerts) |             for (const atVec3f& pv : dock.planeVerts) | ||||||
|                 pvAvg += pv; |                 pvAvg += pv; | ||||||
|             pvAvg /= dock.planeVerts.size(); |             pvAvg /= dock.planeVerts.size(); | ||||||
|             int idx = 0; |             int idx = 0; | ||||||
|             for (const atVec3f& pv : dock.planeVerts) |             for (const atVec3f& pv : dock.planeVerts) | ||||||
|             { |             { | ||||||
|                 Zeus::CVector3f pvRel = Zeus::CVector3f(pv) - pvAvg; |                 zeus::CVector3f pvRel = zeus::CVector3f(pv) - pvAvg; | ||||||
|                 os.format("bm.verts.new((%f,%f,%f))\n" |                 os.format("bm.verts.new((%f,%f,%f))\n" | ||||||
|                           "bm.verts.ensure_lookup_table()\n", |                           "bm.verts.ensure_lookup_table()\n", | ||||||
|                           pvRel[0], pvRel[1], pvRel[2]); |                           pvRel[0], pvRel[1], pvRel[2]); | ||||||
|  | |||||||
| @ -16,7 +16,7 @@ struct NamedResourceCatalog : BigYAML | |||||||
|         String<-1> name; |         String<-1> name; | ||||||
|         IDType uid; |         IDType uid; | ||||||
| 
 | 
 | ||||||
|         void read(Athena::io::IStreamReader& __dna_reader) |         void read(athena::io::IStreamReader& __dna_reader) | ||||||
|         { |         { | ||||||
|             /* type */ |             /* type */ | ||||||
|             type.read(__dna_reader); |             type.read(__dna_reader); | ||||||
| @ -26,7 +26,7 @@ struct NamedResourceCatalog : BigYAML | |||||||
|             uid.read(__dna_reader); |             uid.read(__dna_reader); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         void write(Athena::io::IStreamWriter& __dna_writer) const |         void write(athena::io::IStreamWriter& __dna_writer) const | ||||||
|         { |         { | ||||||
|             /* type */ |             /* type */ | ||||||
|             type.write(__dna_writer); |             type.write(__dna_writer); | ||||||
| @ -36,7 +36,7 @@ struct NamedResourceCatalog : BigYAML | |||||||
|             uid.write(__dna_writer); |             uid.write(__dna_writer); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         void read(Athena::io::YAMLDocReader& __dna_docin) |         void read(athena::io::YAMLDocReader& __dna_docin) | ||||||
|         { |         { | ||||||
|             /* type */ |             /* type */ | ||||||
|             __dna_docin.enumerate("type", type); |             __dna_docin.enumerate("type", type); | ||||||
| @ -46,7 +46,7 @@ struct NamedResourceCatalog : BigYAML | |||||||
|             __dna_docin.enumerate("uid", uid); |             __dna_docin.enumerate("uid", uid); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         void write(Athena::io::YAMLDocWriter& __dna_docout) const |         void write(athena::io::YAMLDocWriter& __dna_docout) const | ||||||
|         { |         { | ||||||
|             /* type */ |             /* type */ | ||||||
|             __dna_docout.enumerate("type", type); |             __dna_docout.enumerate("type", type); | ||||||
| @ -56,7 +56,7 @@ struct NamedResourceCatalog : BigYAML | |||||||
|             __dna_docout.enumerate("uid", uid); |             __dna_docout.enumerate("uid", uid); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         static const char* DNAType() { return "DataSpec::DNACommon::NameResourceCatalog::NamedResource"; } |         static const char* DNAType() { return "DataSpec::DNACommon::NameResourceCatalogvisor::NamedResource"; } | ||||||
| 
 | 
 | ||||||
|         size_t binarySize(size_t __isz) const |         size_t binarySize(size_t __isz) const | ||||||
|         { |         { | ||||||
| @ -68,7 +68,7 @@ struct NamedResourceCatalog : BigYAML | |||||||
|     }; |     }; | ||||||
|     Vector<NamedResource, DNA_COUNT(namedResCount)> namedResources; |     Vector<NamedResource, DNA_COUNT(namedResCount)> namedResources; | ||||||
| 
 | 
 | ||||||
|     void read(Athena::io::IStreamReader& __dna_reader) |     void read(athena::io::IStreamReader& __dna_reader) | ||||||
|     { |     { | ||||||
|         /* namedResCount */ |         /* namedResCount */ | ||||||
|         namedResCount = __dna_reader.readUint32Big(); |         namedResCount = __dna_reader.readUint32Big(); | ||||||
| @ -76,7 +76,7 @@ struct NamedResourceCatalog : BigYAML | |||||||
|         __dna_reader.enumerate(namedResources, namedResCount); |         __dna_reader.enumerate(namedResources, namedResCount); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void write(Athena::io::IStreamWriter& __dna_writer) const |     void write(athena::io::IStreamWriter& __dna_writer) const | ||||||
|     { |     { | ||||||
|         /* namedResCount */ |         /* namedResCount */ | ||||||
|         __dna_writer.writeUint32Big(namedResCount); |         __dna_writer.writeUint32Big(namedResCount); | ||||||
| @ -84,18 +84,14 @@ struct NamedResourceCatalog : BigYAML | |||||||
|         __dna_writer.enumerate(namedResources); |         __dna_writer.enumerate(namedResources); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void read(Athena::io::YAMLDocReader& __dna_docin) |     void read(athena::io::YAMLDocReader& __dna_docin) | ||||||
|     { |     { | ||||||
|         /* namedResCount */ |  | ||||||
|         namedResCount = __dna_docin.readUint32("namedResCount"); |  | ||||||
|         /* namedResources */ |         /* namedResources */ | ||||||
|         __dna_docin.enumerate("namedResources", namedResources, namedResCount); |         namedResCount = __dna_docin.enumerate("namedResources", namedResources); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void write(Athena::io::YAMLDocWriter& __dna_docout) const |     void write(athena::io::YAMLDocWriter& __dna_docout) const | ||||||
|     { |     { | ||||||
|         /* namedResCount */ |  | ||||||
|         __dna_docout.writeUint32("namedResCount", namedResCount); |  | ||||||
|         /* namedResources */ |         /* namedResources */ | ||||||
|         __dna_docout.enumerate("namedResources", namedResources); |         __dna_docout.enumerate("namedResources", namedResources); | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -8,7 +8,7 @@ namespace DataSpec | |||||||
| { | { | ||||||
| 
 | 
 | ||||||
| /* PAK entry stream reader */ | /* PAK entry stream reader */ | ||||||
| class PAKEntryReadStream : public Athena::io::IStreamReader | class PAKEntryReadStream : public athena::io::IStreamReader | ||||||
| { | { | ||||||
|     std::unique_ptr<atUint8[]> m_buf; |     std::unique_ptr<atUint8[]> m_buf; | ||||||
|     atUint64 m_sz; |     atUint64 m_sz; | ||||||
| @ -24,18 +24,18 @@ public: | |||||||
|     : m_buf(std::move(buf)), m_sz(sz), m_pos(pos) |     : m_buf(std::move(buf)), m_sz(sz), m_pos(pos) | ||||||
|     { |     { | ||||||
|         if (m_pos >= m_sz) |         if (m_pos >= m_sz) | ||||||
|             LogDNACommon.report(LogVisor::FatalError, "PAK stream cursor overrun"); |             LogDNACommon.report(logvisor::Fatal, "PAK stream cursor overrun"); | ||||||
|     } |     } | ||||||
|     void seek(atInt64 pos, Athena::SeekOrigin origin) |     void seek(atInt64 pos, athena::SeekOrigin origin) | ||||||
|     { |     { | ||||||
|         if (origin == Athena::Begin) |         if (origin == athena::Begin) | ||||||
|             m_pos = pos; |             m_pos = pos; | ||||||
|         else if (origin == Athena::Current) |         else if (origin == athena::Current) | ||||||
|             m_pos += pos; |             m_pos += pos; | ||||||
|         else if (origin == Athena::End) |         else if (origin == athena::End) | ||||||
|             m_pos = m_sz + pos; |             m_pos = m_sz + pos; | ||||||
|         if (m_pos > m_sz) |         if (m_pos > m_sz) | ||||||
|             LogDNACommon.report(LogVisor::FatalError, "PAK stream cursor overrun"); |             LogDNACommon.report(logvisor::Fatal, "PAK stream cursor overrun"); | ||||||
|     } |     } | ||||||
|     atUint64 position() const {return m_pos;} |     atUint64 position() const {return m_pos;} | ||||||
|     atUint64 length() const {return m_sz;} |     atUint64 length() const {return m_sz;} | ||||||
| @ -61,9 +61,9 @@ struct UniqueResult | |||||||
|         Area, |         Area, | ||||||
|         Layer |         Layer | ||||||
|     } m_type = Type::NotFound; |     } m_type = Type::NotFound; | ||||||
|     const HECL::SystemString* m_levelName = nullptr; |     const hecl::SystemString* m_levelName = nullptr; | ||||||
|     const HECL::SystemString* m_areaName = nullptr; |     const hecl::SystemString* m_areaName = nullptr; | ||||||
|     const HECL::SystemString* m_layerName = nullptr; |     const hecl::SystemString* m_layerName = nullptr; | ||||||
|     UniqueResult() = default; |     UniqueResult() = default; | ||||||
|     UniqueResult(Type tp) : m_type(tp) {} |     UniqueResult(Type tp) : m_type(tp) {} | ||||||
| 
 | 
 | ||||||
| @ -72,7 +72,7 @@ struct UniqueResult | |||||||
|     { |     { | ||||||
|         UniqueResult::Type resultType = UniqueResult::Type::NotFound; |         UniqueResult::Type resultType = UniqueResult::Type::NotFound; | ||||||
|         bool foundOneLayer = false; |         bool foundOneLayer = false; | ||||||
|         const HECL::SystemString* levelName = nullptr; |         const hecl::SystemString* levelName = nullptr; | ||||||
|         typename PAKBRIDGE::PAKType::IDType levelId; |         typename PAKBRIDGE::PAKType::IDType levelId; | ||||||
|         typename PAKBRIDGE::PAKType::IDType areaId; |         typename PAKBRIDGE::PAKType::IDType areaId; | ||||||
|         unsigned layerIdx; |         unsigned layerIdx; | ||||||
| @ -163,12 +163,12 @@ struct UniqueResult | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     HECL::ProjectPath uniquePath(const HECL::ProjectPath& pakPath) const |     hecl::ProjectPath uniquePath(const hecl::ProjectPath& pakPath) const | ||||||
|     { |     { | ||||||
|         if (m_type == Type::Pak) |         if (m_type == Type::Pak) | ||||||
|             return pakPath; |             return pakPath; | ||||||
| 
 | 
 | ||||||
|         HECL::ProjectPath levelDir; |         hecl::ProjectPath levelDir; | ||||||
|         if (m_levelName) |         if (m_levelName) | ||||||
|             levelDir.assign(pakPath, *m_levelName); |             levelDir.assign(pakPath, *m_levelName); | ||||||
|         else |         else | ||||||
| @ -177,15 +177,15 @@ struct UniqueResult | |||||||
| 
 | 
 | ||||||
|         if (m_type == Type::Area) |         if (m_type == Type::Area) | ||||||
|         { |         { | ||||||
|             HECL::ProjectPath areaDir(levelDir, *m_areaName); |             hecl::ProjectPath areaDir(levelDir, *m_areaName); | ||||||
|             areaDir.makeDir(); |             areaDir.makeDir(); | ||||||
|             return areaDir; |             return areaDir; | ||||||
|         } |         } | ||||||
|         else if (m_type == Type::Layer) |         else if (m_type == Type::Layer) | ||||||
|         { |         { | ||||||
|             HECL::ProjectPath areaDir(levelDir, *m_areaName); |             hecl::ProjectPath areaDir(levelDir, *m_areaName); | ||||||
|             areaDir.makeDir(); |             areaDir.makeDir(); | ||||||
|             HECL::ProjectPath layerDir(areaDir, *m_layerName); |             hecl::ProjectPath layerDir(areaDir, *m_layerName); | ||||||
|             layerDir.makeDir(); |             layerDir.makeDir(); | ||||||
|             return layerDir; |             return layerDir; | ||||||
|         } |         } | ||||||
| @ -201,11 +201,11 @@ class PAKRouter; | |||||||
| template <class PAKBRIDGE> | template <class PAKBRIDGE> | ||||||
| struct ResExtractor | struct ResExtractor | ||||||
| { | { | ||||||
|     std::function<bool(PAKEntryReadStream&, const HECL::ProjectPath&)> func_a; |     std::function<bool(PAKEntryReadStream&, const hecl::ProjectPath&)> func_a; | ||||||
|     std::function<bool(const SpecBase&, PAKEntryReadStream&, const HECL::ProjectPath&, PAKRouter<PAKBRIDGE>&, |     std::function<bool(const SpecBase&, PAKEntryReadStream&, const hecl::ProjectPath&, PAKRouter<PAKBRIDGE>&, | ||||||
|                        const typename PAKBRIDGE::PAKType::Entry&, bool, |                        const typename PAKBRIDGE::PAKType::Entry&, bool, | ||||||
|                        std::function<void(const HECL::SystemChar*)>)> func_b; |                        std::function<void(const hecl::SystemChar*)>)> func_b; | ||||||
|     const HECL::SystemChar* fileExts[4]; |     const hecl::SystemChar* fileExts[4]; | ||||||
|     unsigned weight; |     unsigned weight; | ||||||
|     std::function<void(const SpecBase&, PAKEntryReadStream&, PAKRouter<PAKBRIDGE>&, |     std::function<void(const SpecBase&, PAKEntryReadStream&, PAKRouter<PAKBRIDGE>&, | ||||||
|                        typename PAKBRIDGE::PAKType::Entry&)> func_name; |                        typename PAKBRIDGE::PAKType::Entry&)> func_name; | ||||||
| @ -215,13 +215,13 @@ struct ResExtractor | |||||||
| template <class IDType> | template <class IDType> | ||||||
| struct Level | struct Level | ||||||
| { | { | ||||||
|     HECL::SystemString name; |     hecl::SystemString name; | ||||||
|     struct Area |     struct Area | ||||||
|     { |     { | ||||||
|         HECL::SystemString name; |         hecl::SystemString name; | ||||||
|         struct Layer |         struct Layer | ||||||
|         { |         { | ||||||
|             HECL::SystemString name; |             hecl::SystemString name; | ||||||
|             bool active; |             bool active; | ||||||
|             std::unordered_set<IDType> resources; |             std::unordered_set<IDType> resources; | ||||||
|         }; |         }; | ||||||
| @ -244,19 +244,19 @@ private: | |||||||
|     NamedResourceCatalog<IDType> m_catalog; |     NamedResourceCatalog<IDType> m_catalog; | ||||||
|     const SpecBase& m_dataSpec; |     const SpecBase& m_dataSpec; | ||||||
|     const std::vector<BRIDGETYPE>* m_bridges = nullptr; |     const std::vector<BRIDGETYPE>* m_bridges = nullptr; | ||||||
|     std::vector<std::pair<HECL::ProjectPath,HECL::ProjectPath>> m_bridgePaths; |     std::vector<std::pair<hecl::ProjectPath,hecl::ProjectPath>> m_bridgePaths; | ||||||
|     size_t m_curBridgeIdx = 0; |     size_t m_curBridgeIdx = 0; | ||||||
|     const HECL::ProjectPath& m_gameWorking; |     const hecl::ProjectPath& m_gameWorking; | ||||||
|     const HECL::ProjectPath& m_gameCooked; |     const hecl::ProjectPath& m_gameCooked; | ||||||
|     HECL::ProjectPath m_sharedWorking; |     hecl::ProjectPath m_sharedWorking; | ||||||
|     HECL::ProjectPath m_sharedCooked; |     hecl::ProjectPath m_sharedCooked; | ||||||
|     const PAKType* m_pak = nullptr; |     const PAKType* m_pak = nullptr; | ||||||
|     const NOD::Node* m_node = nullptr; |     const nod::Node* m_node = nullptr; | ||||||
|     std::unordered_map<IDType, std::pair<size_t, EntryType*>> m_uniqueEntries; |     std::unordered_map<IDType, std::pair<size_t, EntryType*>> m_uniqueEntries; | ||||||
|     std::unordered_map<IDType, std::pair<size_t, EntryType*>> m_sharedEntries; |     std::unordered_map<IDType, std::pair<size_t, EntryType*>> m_sharedEntries; | ||||||
|     std::unordered_map<IDType, RigPair> m_cmdlRigs; |     std::unordered_map<IDType, RigPair> m_cmdlRigs; | ||||||
| public: | public: | ||||||
|     PAKRouter(const SpecBase& dataSpec, const HECL::ProjectPath& working, const HECL::ProjectPath& cooked) |     PAKRouter(const SpecBase& dataSpec, const hecl::ProjectPath& working, const hecl::ProjectPath& cooked) | ||||||
|     : m_dataSpec(dataSpec), |     : m_dataSpec(dataSpec), | ||||||
|       m_gameWorking(working), m_gameCooked(cooked), |       m_gameWorking(working), m_gameCooked(cooked), | ||||||
|       m_sharedWorking(working, "Shared"), m_sharedCooked(cooked, "Shared") {} |       m_sharedWorking(working, "Shared"), m_sharedCooked(cooked, "Shared") {} | ||||||
| @ -277,13 +277,13 @@ public: | |||||||
|         for (BRIDGETYPE& bridge : bridges) |         for (BRIDGETYPE& bridge : bridges) | ||||||
|         { |         { | ||||||
|             const std::string& name = bridge.getName(); |             const std::string& name = bridge.getName(); | ||||||
|             HECL::SystemStringView sysName(name); |             hecl::SystemStringView sysName(name); | ||||||
| 
 | 
 | ||||||
|             HECL::SystemString::const_iterator extit = sysName.sys_str().end() - 4; |             hecl::SystemString::const_iterator extit = sysName.sys_str().end() - 4; | ||||||
|             HECL::SystemString baseName(sysName.sys_str().begin(), extit); |             hecl::SystemString baseName(sysName.sys_str().begin(), extit); | ||||||
| 
 | 
 | ||||||
|             m_bridgePaths.emplace_back(std::make_pair(HECL::ProjectPath(m_gameWorking, baseName), |             m_bridgePaths.emplace_back(std::make_pair(hecl::ProjectPath(m_gameWorking, baseName), | ||||||
|                                                       HECL::ProjectPath(m_gameCooked, baseName))); |                                                       hecl::ProjectPath(m_gameCooked, baseName))); | ||||||
| 
 | 
 | ||||||
|             /* Index this PAK */ |             /* Index this PAK */ | ||||||
|             bridge.build(); |             bridge.build(); | ||||||
| @ -319,8 +319,8 @@ public: | |||||||
|             ++bridgeIdx; |             ++bridgeIdx; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         HECL::SystemString catalogPath = HECL::ProjectPath(m_gameCooked, "catalog.yaml").getAbsolutePath(); |         hecl::SystemString catalogPath = hecl::ProjectPath(m_gameCooked, "catalog.yaml").getAbsolutePath(); | ||||||
|         FILE* catalog = HECL::Fopen(catalogPath.c_str(), _S("wb")); |         FILE* catalog = hecl::Fopen(catalogPath.c_str(), _S("wb")); | ||||||
|         if (catalog) |         if (catalog) | ||||||
|         { |         { | ||||||
|             m_catalog.toYAMLFile(catalog); |             m_catalog.toYAMLFile(catalog); | ||||||
| @ -346,150 +346,132 @@ public: | |||||||
|             ++pit; |             ++pit; | ||||||
|             ++bridgeIdx; |             ++bridgeIdx; | ||||||
|         } |         } | ||||||
|         LogDNACommon.report(LogVisor::FatalError, "PAKBridge provided to PAKRouter::enterPAKBridge() was not part of build()"); |         LogDNACommon.report(logvisor::Fatal, "PAKBridge provided to PAKRouter::enterPAKBridge() was not part of build()"); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     HECL::ProjectPath getWorking(const EntryType* entry, |     hecl::ProjectPath getWorking(const EntryType* entry, | ||||||
|                                  const ResExtractor<BRIDGETYPE>& extractor) const |                                  const ResExtractor<BRIDGETYPE>& extractor) const | ||||||
|     { |     { | ||||||
|         if (!m_pak) |         if (!m_pak) | ||||||
|             LogDNACommon.report(LogVisor::FatalError, |             LogDNACommon.report(logvisor::Fatal, | ||||||
|             "PAKRouter::enterPAKBridge() must be called before PAKRouter::getWorkingPath()"); |             "PAKRouter::enterPAKBridge() must be called before PAKRouter::getWorkingPath()"); | ||||||
|         if (m_pak->m_noShare) |         if (m_pak->m_noShare) | ||||||
|         { |         { | ||||||
|             const EntryType* singleSearch = m_pak->lookupEntry(entry->id); |             const EntryType* singleSearch = m_pak->lookupEntry(entry->id); | ||||||
|             if (singleSearch) |             if (singleSearch) | ||||||
|             { |             { | ||||||
|                 const HECL::ProjectPath& pakPath = m_bridgePaths[m_curBridgeIdx].first; |                 const hecl::ProjectPath& pakPath = m_bridgePaths[m_curBridgeIdx].first; | ||||||
|                 pakPath.makeDir(); |                 pakPath.makeDir(); | ||||||
|     #if HECL_UCS2 |     #if HECL_UCS2 | ||||||
|                 HECL::SystemString entName = HECL::UTF8ToWide(m_pak->bestEntryName(*entry)); |                 hecl::SystemString entName = hecl::UTF8ToWide(m_pak->bestEntryName(*entry)); | ||||||
|     #else |     #else | ||||||
|                 HECL::SystemString entName = m_pak->bestEntryName(*entry); |                 hecl::SystemString entName = m_pak->bestEntryName(*entry); | ||||||
|     #endif |     #endif | ||||||
|                 if (extractor.fileExts[0] && !extractor.fileExts[1]) |                 if (extractor.fileExts[0] && !extractor.fileExts[1]) | ||||||
|                     entName += extractor.fileExts[0]; |                     entName += extractor.fileExts[0]; | ||||||
|                 return HECL::ProjectPath(pakPath, entName); |                 return hecl::ProjectPath(pakPath, entName); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         auto uniqueSearch = m_uniqueEntries.find(entry->id); |         auto uniqueSearch = m_uniqueEntries.find(entry->id); | ||||||
|         if (uniqueSearch != m_uniqueEntries.end()) |         if (uniqueSearch != m_uniqueEntries.end()) | ||||||
|         { |         { | ||||||
|             const HECL::ProjectPath& pakPath = m_bridgePaths[uniqueSearch->second.first].first; |             const hecl::ProjectPath& pakPath = m_bridgePaths[uniqueSearch->second.first].first; | ||||||
|             pakPath.makeDir(); |             pakPath.makeDir(); | ||||||
|             HECL::ProjectPath uniquePath = entry->unique.uniquePath(pakPath); |             hecl::ProjectPath uniquePath = entry->unique.uniquePath(pakPath); | ||||||
| #if HECL_UCS2 | #if HECL_UCS2 | ||||||
|             HECL::SystemString entName = HECL::UTF8ToWide(m_pak->bestEntryName(*entry)); |             hecl::SystemString entName = hecl::UTF8ToWide(m_pak->bestEntryName(*entry)); | ||||||
| #else | #else | ||||||
|             HECL::SystemString entName = m_pak->bestEntryName(*entry); |             hecl::SystemString entName = m_pak->bestEntryName(*entry); | ||||||
| #endif | #endif | ||||||
|             if (extractor.fileExts[0] && !extractor.fileExts[1]) |             if (extractor.fileExts[0] && !extractor.fileExts[1]) | ||||||
|                 entName += extractor.fileExts[0]; |                 entName += extractor.fileExts[0]; | ||||||
|             return HECL::ProjectPath(uniquePath, entName); |             return hecl::ProjectPath(uniquePath, entName); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         auto sharedSearch = m_sharedEntries.find(entry->id); |         auto sharedSearch = m_sharedEntries.find(entry->id); | ||||||
|         if (sharedSearch != m_sharedEntries.end()) |         if (sharedSearch != m_sharedEntries.end()) | ||||||
|         { |         { | ||||||
|             const HECL::ProjectPath& pakPath = m_bridgePaths[m_curBridgeIdx].first; |             const hecl::ProjectPath& pakPath = m_bridgePaths[m_curBridgeIdx].first; | ||||||
|             HECL::ProjectPath uniquePathPre = entry->unique.uniquePath(pakPath); |             hecl::ProjectPath uniquePathPre = entry->unique.uniquePath(pakPath); | ||||||
| #if HECL_UCS2 | #if HECL_UCS2 | ||||||
|             HECL::SystemString entBase = HECL::UTF8ToWide(m_pak->bestEntryName(*entry)); |             hecl::SystemString entBase = hecl::UTF8ToWide(m_pak->bestEntryName(*entry)); | ||||||
| #else | #else | ||||||
|             HECL::SystemString entBase = m_pak->bestEntryName(*entry); |             hecl::SystemString entBase = m_pak->bestEntryName(*entry); | ||||||
| #endif | #endif | ||||||
|             HECL::SystemString entName = entBase; |             hecl::SystemString entName = entBase; | ||||||
|             if (extractor.fileExts[0] && !extractor.fileExts[1]) |             if (extractor.fileExts[0] && !extractor.fileExts[1]) | ||||||
|                 entName += extractor.fileExts[0]; |                 entName += extractor.fileExts[0]; | ||||||
|             HECL::ProjectPath sharedPath(m_sharedWorking, entName); |             hecl::ProjectPath sharedPath(m_sharedWorking, entName); | ||||||
|             HECL::ProjectPath uniquePath(uniquePathPre, entName); |  | ||||||
|             if (extractor.func_a || extractor.func_b) |  | ||||||
|             { |  | ||||||
|                 if (extractor.fileExts[0] && !extractor.fileExts[1]) |  | ||||||
|                     uniquePath.makeLinkTo(sharedPath); |  | ||||||
|                 else |  | ||||||
|                 { |  | ||||||
|                     for (int e=0 ; e<4 ; ++e) |  | ||||||
|                     { |  | ||||||
|                         if (!extractor.fileExts[e]) |  | ||||||
|                             break; |  | ||||||
|                         HECL::SystemString entName = entBase + extractor.fileExts[e]; |  | ||||||
|                         HECL::ProjectPath sharedPath(m_sharedWorking, entName); |  | ||||||
|                         HECL::ProjectPath uniquePath(uniquePathPre, entName); |  | ||||||
|                         uniquePath.makeLinkTo(sharedPath); |  | ||||||
|                     } |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|             m_sharedWorking.makeDir(); |             m_sharedWorking.makeDir(); | ||||||
|             return sharedPath; |             return sharedPath; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         LogDNACommon.report(LogVisor::FatalError, "Unable to find entry %s", entry->id.toString().c_str()); |         LogDNACommon.report(logvisor::Fatal, "Unable to find entry %s", entry->id.toString().c_str()); | ||||||
|         return HECL::ProjectPath(); |         return hecl::ProjectPath(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     HECL::ProjectPath getWorking(const EntryType* entry) const |     hecl::ProjectPath getWorking(const EntryType* entry) const | ||||||
|     { |     { | ||||||
|         return getWorking(entry, BRIDGETYPE::LookupExtractor(*entry)); |         return getWorking(entry, BRIDGETYPE::LookupExtractor(*entry)); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     HECL::ProjectPath getWorking(const IDType& id) const |     hecl::ProjectPath getWorking(const IDType& id) const | ||||||
|     { |     { | ||||||
|         return getWorking(lookupEntry(id)); |         return getWorking(lookupEntry(id)); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     HECL::ProjectPath getCooked(const EntryType* entry) const |     hecl::ProjectPath getCooked(const EntryType* entry) const | ||||||
|     { |     { | ||||||
|         if (!m_pak) |         if (!m_pak) | ||||||
|             LogDNACommon.report(LogVisor::FatalError, |             LogDNACommon.report(logvisor::Fatal, | ||||||
|             "PAKRouter::enterPAKBridge() must be called before PAKRouter::getCookedPath()"); |             "PAKRouter::enterPAKBridge() must be called before PAKRouter::getCookedPath()"); | ||||||
|         if (m_pak->m_noShare) |         if (m_pak->m_noShare) | ||||||
|         { |         { | ||||||
|             const EntryType* singleSearch = m_pak->lookupEntry(entry->id); |             const EntryType* singleSearch = m_pak->lookupEntry(entry->id); | ||||||
|             if (singleSearch) |             if (singleSearch) | ||||||
|             { |             { | ||||||
|                 const HECL::ProjectPath& pakPath = m_bridgePaths[m_curBridgeIdx].second; |                 const hecl::ProjectPath& pakPath = m_bridgePaths[m_curBridgeIdx].second; | ||||||
|                 pakPath.makeDir(); |                 pakPath.makeDir(); | ||||||
|                 return HECL::ProjectPath(pakPath, m_pak->bestEntryName(*entry)); |                 return hecl::ProjectPath(pakPath, m_pak->bestEntryName(*entry)); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         auto uniqueSearch = m_uniqueEntries.find(entry->id); |         auto uniqueSearch = m_uniqueEntries.find(entry->id); | ||||||
|         if (uniqueSearch != m_uniqueEntries.end()) |         if (uniqueSearch != m_uniqueEntries.end()) | ||||||
|         { |         { | ||||||
|             const HECL::ProjectPath& pakPath = m_bridgePaths[uniqueSearch->second.first].second; |             const hecl::ProjectPath& pakPath = m_bridgePaths[uniqueSearch->second.first].second; | ||||||
|             pakPath.makeDir(); |             pakPath.makeDir(); | ||||||
|             HECL::ProjectPath uniquePath = entry->unique.uniquePath(pakPath); |             hecl::ProjectPath uniquePath = entry->unique.uniquePath(pakPath); | ||||||
|             return HECL::ProjectPath(uniquePath, m_pak->bestEntryName(*entry)); |             return hecl::ProjectPath(uniquePath, m_pak->bestEntryName(*entry)); | ||||||
|         } |         } | ||||||
|         auto sharedSearch = m_sharedEntries.find(entry->id); |         auto sharedSearch = m_sharedEntries.find(entry->id); | ||||||
|         if (sharedSearch != m_sharedEntries.end()) |         if (sharedSearch != m_sharedEntries.end()) | ||||||
|         { |         { | ||||||
|             m_sharedCooked.makeDir(); |             m_sharedCooked.makeDir(); | ||||||
|             return HECL::ProjectPath(m_sharedCooked, m_pak->bestEntryName(*entry)); |             return hecl::ProjectPath(m_sharedCooked, m_pak->bestEntryName(*entry)); | ||||||
|         } |         } | ||||||
|         LogDNACommon.report(LogVisor::FatalError, "Unable to find entry %s", entry->id.toString().c_str()); |         LogDNACommon.report(logvisor::Fatal, "Unable to find entry %s", entry->id.toString().c_str()); | ||||||
|         return HECL::ProjectPath(); |         return hecl::ProjectPath(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     HECL::ProjectPath getCooked(const IDType& id) const |     hecl::ProjectPath getCooked(const IDType& id) const | ||||||
|     { |     { | ||||||
|         return getCooked(lookupEntry(id)); |         return getCooked(lookupEntry(id)); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     HECL::SystemString getResourceRelativePath(const EntryType& a, const IDType& b) const |     hecl::SystemString getResourceRelativePath(const EntryType& a, const IDType& b) const | ||||||
|     { |     { | ||||||
|         if (!m_pak) |         if (!m_pak) | ||||||
|             LogDNACommon.report(LogVisor::FatalError, |             LogDNACommon.report(logvisor::Fatal, | ||||||
|             "PAKRouter::enterPAKBridge() must be called before PAKRouter::getResourceRelativePath()"); |             "PAKRouter::enterPAKBridge() must be called before PAKRouter::getResourceRelativePath()"); | ||||||
|         const typename BRIDGETYPE::PAKType::Entry* be = lookupEntry(b); |         const typename BRIDGETYPE::PAKType::Entry* be = lookupEntry(b); | ||||||
|         if (!be) |         if (!be) | ||||||
|             return HECL::SystemString(); |             return hecl::SystemString(); | ||||||
|         HECL::ProjectPath aPath = getWorking(&a, BRIDGETYPE::LookupExtractor(a)); |         hecl::ProjectPath aPath = getWorking(&a, BRIDGETYPE::LookupExtractor(a)); | ||||||
|         HECL::SystemString ret; |         hecl::SystemString ret; | ||||||
|         for (int i=0 ; i<aPath.levelCount() ; ++i) |         for (int i=0 ; i<aPath.levelCount() ; ++i) | ||||||
|             ret += _S("../"); |             ret += _S("../"); | ||||||
|         HECL::ProjectPath bPath = getWorking(be, BRIDGETYPE::LookupExtractor(*be)); |         hecl::ProjectPath bPath = getWorking(be, BRIDGETYPE::LookupExtractor(*be)); | ||||||
|         ret += bPath.getRelativePath(); |         ret += bPath.getRelativePath(); | ||||||
|         return ret; |         return ret; | ||||||
|     } |     } | ||||||
| @ -497,7 +479,7 @@ public: | |||||||
|     std::string getBestEntryName(const EntryType& entry) const |     std::string getBestEntryName(const EntryType& entry) const | ||||||
|     { |     { | ||||||
|         if (!m_pak) |         if (!m_pak) | ||||||
|             LogDNACommon.report(LogVisor::FatalError, |             LogDNACommon.report(logvisor::Fatal, | ||||||
|             "PAKRouter::enterPAKBridge() must be called before PAKRouter::getBestEntryName()"); |             "PAKRouter::enterPAKBridge() must be called before PAKRouter::getBestEntryName()"); | ||||||
|         return m_pak->bestEntryName(entry); |         return m_pak->bestEntryName(entry); | ||||||
|     } |     } | ||||||
| @ -505,7 +487,7 @@ public: | |||||||
|     std::string getBestEntryName(const IDType& entry) const |     std::string getBestEntryName(const IDType& entry) const | ||||||
|     { |     { | ||||||
|         if (!m_pak) |         if (!m_pak) | ||||||
|             LogDNACommon.report(LogVisor::FatalError, |             LogDNACommon.report(logvisor::Fatal, | ||||||
|             "PAKRouter::enterPAKBridge() must be called before PAKRouter::getBestEntryName()"); |             "PAKRouter::enterPAKBridge() must be called before PAKRouter::getBestEntryName()"); | ||||||
|         const typename BRIDGETYPE::PAKType::Entry* e = m_pak->lookupEntry(entry); |         const typename BRIDGETYPE::PAKType::Entry* e = m_pak->lookupEntry(entry); | ||||||
|         if (!e) |         if (!e) | ||||||
| @ -514,7 +496,7 @@ public: | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     bool extractResources(const BRIDGETYPE& pakBridge, bool force, |     bool extractResources(const BRIDGETYPE& pakBridge, bool force, | ||||||
|                           std::function<void(const HECL::SystemChar*, float)> progress) |                           std::function<void(const hecl::SystemChar*, float)> progress) | ||||||
|     { |     { | ||||||
|         enterPAKBridge(pakBridge); |         enterPAKBridge(pakBridge); | ||||||
|         size_t count = 0; |         size_t count = 0; | ||||||
| @ -529,24 +511,24 @@ public: | |||||||
|                     continue; |                     continue; | ||||||
|                  |                  | ||||||
|                 std::string bestName = getBestEntryName(*item); |                 std::string bestName = getBestEntryName(*item); | ||||||
|                 HECL::SystemStringView bestNameView(bestName); |                 hecl::SystemStringView bestNameView(bestName); | ||||||
|                 float thisFac = ++count / fsz; |                 float thisFac = ++count / fsz; | ||||||
|                 progress(bestNameView.sys_str().c_str(), thisFac); |                 progress(bestNameView.sys_str().c_str(), thisFac); | ||||||
| 
 | 
 | ||||||
|                 /* TODO: Position after extracted item */ |                 /* TODO: Position after extracted item */ | ||||||
|                 HECL::ProjectPath cooked = getCooked(item); |                 hecl::ProjectPath cooked = getCooked(item); | ||||||
|                 if (force || cooked.getPathType() == HECL::ProjectPath::Type::None) |                 if (force || cooked.getPathType() == hecl::ProjectPath::Type::None) | ||||||
|                 { |                 { | ||||||
|                     PAKEntryReadStream s = item->beginReadStream(*m_node); |                     PAKEntryReadStream s = item->beginReadStream(*m_node); | ||||||
|                     FILE* fout = HECL::Fopen(cooked.getAbsolutePath().c_str(), _S("wb")); |                     FILE* fout = hecl::Fopen(cooked.getAbsolutePath().c_str(), _S("wb")); | ||||||
|                     fwrite(s.data(), 1, s.length(), fout); |                     fwrite(s.data(), 1, s.length(), fout); | ||||||
|                     fclose(fout); |                     fclose(fout); | ||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
|                 HECL::ProjectPath working = getWorking(item, extractor); |                 hecl::ProjectPath working = getWorking(item, extractor); | ||||||
|                 if (extractor.func_a) /* Doesn't need PAKRouter access */ |                 if (extractor.func_a) /* Doesn't need PAKRouter access */ | ||||||
|                 { |                 { | ||||||
|                     if (force || working.getPathType() == HECL::ProjectPath::Type::None) |                     if (force || working.getPathType() == hecl::ProjectPath::Type::None) | ||||||
|                     { |                     { | ||||||
|                         PAKEntryReadStream s = item->beginReadStream(*m_node); |                         PAKEntryReadStream s = item->beginReadStream(*m_node); | ||||||
|                         extractor.func_a(s, working); |                         extractor.func_a(s, working); | ||||||
| @ -554,11 +536,11 @@ public: | |||||||
|                 } |                 } | ||||||
|                 else if (extractor.func_b) /* Needs PAKRouter access */ |                 else if (extractor.func_b) /* Needs PAKRouter access */ | ||||||
|                 { |                 { | ||||||
|                     if (force || working.getPathType() == HECL::ProjectPath::Type::None) |                     if (force || working.getPathType() == hecl::ProjectPath::Type::None) | ||||||
|                     { |                     { | ||||||
|                         PAKEntryReadStream s = item->beginReadStream(*m_node); |                         PAKEntryReadStream s = item->beginReadStream(*m_node); | ||||||
|                         extractor.func_b(m_dataSpec, s, working, *this, *item, force, |                         extractor.func_b(m_dataSpec, s, working, *this, *item, force, | ||||||
|                                          [&progress, thisFac](const HECL::SystemChar* update) |                                          [&progress, thisFac](const hecl::SystemChar* update) | ||||||
|                                          { |                                          { | ||||||
|                                              progress(update, thisFac); |                                              progress(update, thisFac); | ||||||
|                                          }); |                                          }); | ||||||
| @ -571,7 +553,7 @@ public: | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     const typename BRIDGETYPE::PAKType::Entry* lookupEntry(const IDType& entry, |     const typename BRIDGETYPE::PAKType::Entry* lookupEntry(const IDType& entry, | ||||||
|                                                            const NOD::Node** nodeOut=nullptr, |                                                            const nod::Node** nodeOut=nullptr, | ||||||
|                                                            bool silenceWarnings=false, |                                                            bool silenceWarnings=false, | ||||||
|                                                            bool currentPAK=false) const |                                                            bool currentPAK=false) const | ||||||
|     { |     { | ||||||
| @ -579,7 +561,7 @@ public: | |||||||
|             return nullptr; |             return nullptr; | ||||||
| 
 | 
 | ||||||
|         if (!m_bridges) |         if (!m_bridges) | ||||||
|             LogDNACommon.report(LogVisor::FatalError, |             LogDNACommon.report(logvisor::Fatal, | ||||||
|             "PAKRouter::build() must be called before PAKRouter::lookupEntry()"); |             "PAKRouter::build() must be called before PAKRouter::lookupEntry()"); | ||||||
| 
 | 
 | ||||||
|         if (m_pak) |         if (m_pak) | ||||||
| @ -596,7 +578,7 @@ public: | |||||||
|         if (currentPAK) |         if (currentPAK) | ||||||
|         { |         { | ||||||
|             if (!silenceWarnings) |             if (!silenceWarnings) | ||||||
|                 LogDNACommon.report(LogVisor::Warning, "unable to find PAK entry %s in current PAK", entry.toString().c_str()); |                 LogDNACommon.report(logvisor::Warning, "unable to find PAK entry %s in current PAK", entry.toString().c_str()); | ||||||
|             return nullptr; |             return nullptr; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @ -613,7 +595,7 @@ public: | |||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         if (!silenceWarnings) |         if (!silenceWarnings) | ||||||
|             LogDNACommon.report(LogVisor::Warning, "unable to find PAK entry %s", entry.toString().c_str()); |             LogDNACommon.report(logvisor::Warning, "unable to find PAK entry %s", entry.toString().c_str()); | ||||||
|         if (nodeOut) |         if (nodeOut) | ||||||
|             *nodeOut = nullptr; |             *nodeOut = nullptr; | ||||||
|         return nullptr; |         return nullptr; | ||||||
| @ -622,7 +604,7 @@ public: | |||||||
|     template <typename DNA> |     template <typename DNA> | ||||||
|     bool lookupAndReadDNA(const IDType& id, DNA& out, bool silenceWarnings=false) |     bool lookupAndReadDNA(const IDType& id, DNA& out, bool silenceWarnings=false) | ||||||
|     { |     { | ||||||
|         const NOD::Node* node; |         const nod::Node* node; | ||||||
|         const EntryType* entry = lookupEntry(id, &node, silenceWarnings); |         const EntryType* entry = lookupEntry(id, &node, silenceWarnings); | ||||||
|         if (!entry) |         if (!entry) | ||||||
|             return false; |             return false; | ||||||
| @ -639,10 +621,10 @@ public: | |||||||
|         return &search->second; |         return &search->second; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     HECL::ProjectPath getAreaLayerWorking(const IDType& areaId, int layerIdx) const |     hecl::ProjectPath getAreaLayerWorking(const IDType& areaId, int layerIdx) const | ||||||
|     { |     { | ||||||
|         if (!m_bridges) |         if (!m_bridges) | ||||||
|             LogDNACommon.report(LogVisor::FatalError, |             LogDNACommon.report(logvisor::Fatal, | ||||||
|             "PAKRouter::build() must be called before PAKRouter::getAreaLayerWorking()"); |             "PAKRouter::build() must be called before PAKRouter::getAreaLayerWorking()"); | ||||||
|         auto bridgePathIt = m_bridgePaths.cbegin(); |         auto bridgePathIt = m_bridgePaths.cbegin(); | ||||||
|         for (const BRIDGETYPE& bridge : *m_bridges) |         for (const BRIDGETYPE& bridge : *m_bridges) | ||||||
| @ -651,21 +633,21 @@ public: | |||||||
|                 for (const auto& area : level.second.areas) |                 for (const auto& area : level.second.areas) | ||||||
|                     if (area.first == areaId) |                     if (area.first == areaId) | ||||||
|                     { |                     { | ||||||
|                         HECL::ProjectPath levelPath(bridgePathIt->first, level.second.name); |                         hecl::ProjectPath levelPath(bridgePathIt->first, level.second.name); | ||||||
|                         HECL::ProjectPath areaPath(levelPath, area.second.name); |                         hecl::ProjectPath areaPath(levelPath, area.second.name); | ||||||
|                         if (layerIdx < 0) |                         if (layerIdx < 0) | ||||||
|                             return areaPath; |                             return areaPath; | ||||||
|                         return HECL::ProjectPath(areaPath, area.second.layers.at(layerIdx).name); |                         return hecl::ProjectPath(areaPath, area.second.layers.at(layerIdx).name); | ||||||
|                     } |                     } | ||||||
|             ++bridgePathIt; |             ++bridgePathIt; | ||||||
|         } |         } | ||||||
|         return HECL::ProjectPath(); |         return hecl::ProjectPath(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     HECL::ProjectPath getAreaLayerCooked(const IDType& areaId, int layerIdx) const |     hecl::ProjectPath getAreaLayerCooked(const IDType& areaId, int layerIdx) const | ||||||
|     { |     { | ||||||
|         if (!m_bridges) |         if (!m_bridges) | ||||||
|             LogDNACommon.report(LogVisor::FatalError, |             LogDNACommon.report(logvisor::Fatal, | ||||||
|             "PAKRouter::build() must be called before PAKRouter::getAreaLayerCooked()"); |             "PAKRouter::build() must be called before PAKRouter::getAreaLayerCooked()"); | ||||||
|         auto bridgePathIt = m_bridgePaths.cbegin(); |         auto bridgePathIt = m_bridgePaths.cbegin(); | ||||||
|         for (const BRIDGETYPE& bridge : *m_bridges) |         for (const BRIDGETYPE& bridge : *m_bridges) | ||||||
| @ -674,15 +656,15 @@ public: | |||||||
|                 for (const auto& area : level.second.areas) |                 for (const auto& area : level.second.areas) | ||||||
|                     if (area.first == areaId) |                     if (area.first == areaId) | ||||||
|                     { |                     { | ||||||
|                         HECL::ProjectPath levelPath(bridgePathIt->second, level.second.name); |                         hecl::ProjectPath levelPath(bridgePathIt->second, level.second.name); | ||||||
|                         HECL::ProjectPath areaPath(levelPath, area.second.name); |                         hecl::ProjectPath areaPath(levelPath, area.second.name); | ||||||
|                         if (layerIdx < 0) |                         if (layerIdx < 0) | ||||||
|                             return areaPath; |                             return areaPath; | ||||||
|                         return HECL::ProjectPath(areaPath, area.second.layers.at(layerIdx).name); |                         return hecl::ProjectPath(areaPath, area.second.layers.at(layerIdx).name); | ||||||
|                     } |                     } | ||||||
|             ++bridgePathIt; |             ++bridgePathIt; | ||||||
|         } |         } | ||||||
|         return HECL::ProjectPath(); |         return hecl::ProjectPath(); | ||||||
|     } |     } | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -3,7 +3,7 @@ | |||||||
| 
 | 
 | ||||||
| #include "ParticleCommon.hpp" | #include "ParticleCommon.hpp" | ||||||
| #include "PAK.hpp" | #include "PAK.hpp" | ||||||
| #include "Athena/FileWriter.hpp" | #include "athena/FileWriter.hpp" | ||||||
| 
 | 
 | ||||||
| namespace DataSpec | namespace DataSpec | ||||||
| { | { | ||||||
| @ -13,7 +13,7 @@ namespace DNAParticle | |||||||
| template <class IDType> | template <class IDType> | ||||||
| struct GPSM : BigYAML | struct GPSM : BigYAML | ||||||
| { | { | ||||||
|     static const char* DNAType() {return "Retro::GPSM";} |     static const char* DNAType() {return "urde::GPSM";} | ||||||
|     const char* DNATypeV() const {return DNAType();} |     const char* DNATypeV() const {return DNAType();} | ||||||
| 
 | 
 | ||||||
|     VectorElementFactory x0_PSIV; |     VectorElementFactory x0_PSIV; | ||||||
| @ -107,13 +107,13 @@ struct GPSM : BigYAML | |||||||
|         x45_25_PMOO = true; |         x45_25_PMOO = true; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void read(Athena::io::YAMLDocReader& r) |     void read(athena::io::YAMLDocReader& r) | ||||||
|     { |     { | ||||||
|         for (const auto& elem : r.getCurNode()->m_mapChildren) |         for (const auto& elem : r.getCurNode()->m_mapChildren) | ||||||
|         { |         { | ||||||
|             if (elem.first.size() < 4) |             if (elem.first.size() < 4) | ||||||
|             { |             { | ||||||
|                 LogModule.report(LogVisor::Warning, "short FourCC in element '%s'", elem.first.c_str()); |                 LogModule.report(logvisor::Warning, "short FourCC in element '%s'", elem.first.c_str()); | ||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
| @ -366,7 +366,7 @@ struct GPSM : BigYAML | |||||||
|             r.leaveSubRecord(); |             r.leaveSubRecord(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     void write(Athena::io::YAMLDocWriter& w) const |     void write(athena::io::YAMLDocWriter& w) const | ||||||
|     { |     { | ||||||
|         if (x0_PSIV) |         if (x0_PSIV) | ||||||
|         { |         { | ||||||
| @ -950,13 +950,13 @@ struct GPSM : BigYAML | |||||||
|             __isz = x128_ADV8.binarySize(__isz + 4); |             __isz = x128_ADV8.binarySize(__isz + 4); | ||||||
|         return __isz; |         return __isz; | ||||||
|     } |     } | ||||||
|     void read(Athena::io::IStreamReader& r) |     void read(athena::io::IStreamReader& r) | ||||||
|     { |     { | ||||||
|         uint32_t clsId; |         uint32_t clsId; | ||||||
|         r.readBytesToBuf(&clsId, 4); |         r.readBytesToBuf(&clsId, 4); | ||||||
|         if (clsId != SBIG('GPSM')) |         if (clsId != SBIG('GPSM')) | ||||||
|         { |         { | ||||||
|             LogModule.report(LogVisor::Warning, "non GPSM provided to GPSM parser"); |             LogModule.report(logvisor::Warning, "non GPSM provided to GPSM parser"); | ||||||
|             return; |             return; | ||||||
|         } |         } | ||||||
|         r.readBytesToBuf(&clsId, 4); |         r.readBytesToBuf(&clsId, 4); | ||||||
| @ -1226,13 +1226,13 @@ struct GPSM : BigYAML | |||||||
|                 xd8_SELC.read(r); |                 xd8_SELC.read(r); | ||||||
|                 break; |                 break; | ||||||
|             default: |             default: | ||||||
|                 LogModule.report(LogVisor::FatalError, "Unknown GPSM class %.4s @%" PRIi64, &clsId, r.position()); |                 LogModule.report(logvisor::Fatal, "Unknown GPSM class %.4s @%" PRIi64, &clsId, r.position()); | ||||||
|                 break; |                 break; | ||||||
|             } |             } | ||||||
|             r.readBytesToBuf(&clsId, 4); |             r.readBytesToBuf(&clsId, 4); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     void write(Athena::io::IStreamWriter& w) const |     void write(athena::io::IStreamWriter& w) const | ||||||
|     { |     { | ||||||
|         w.writeBytes((atInt8*)"GPSM", 4); |         w.writeBytes((atInt8*)"GPSM", 4); | ||||||
|         if (x0_PSIV) |         if (x0_PSIV) | ||||||
| @ -1626,9 +1626,9 @@ struct GPSM : BigYAML | |||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| template <class IDType> | template <class IDType> | ||||||
| bool ExtractGPSM(PAKEntryReadStream& rs, const HECL::ProjectPath& outPath) | bool ExtractGPSM(PAKEntryReadStream& rs, const hecl::ProjectPath& outPath) | ||||||
| { | { | ||||||
|     FILE* fp = HECL::Fopen(outPath.getAbsolutePath().c_str(), _S("w")); |     FILE* fp = hecl::Fopen(outPath.getAbsolutePath().c_str(), _S("w")); | ||||||
|     if (fp) |     if (fp) | ||||||
|     { |     { | ||||||
|         GPSM<IDType> gpsm; |         GPSM<IDType> gpsm; | ||||||
| @ -1641,9 +1641,9 @@ bool ExtractGPSM(PAKEntryReadStream& rs, const HECL::ProjectPath& outPath) | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| template <class IDType> | template <class IDType> | ||||||
| bool WriteGPSM(const GPSM<IDType>& gpsm, const HECL::ProjectPath& outPath) | bool WriteGPSM(const GPSM<IDType>& gpsm, const hecl::ProjectPath& outPath) | ||||||
| { | { | ||||||
|     Athena::io::FileWriter w(outPath.getAbsolutePath(), true, false); |     athena::io::FileWriter w(outPath.getAbsolutePath(), true, false); | ||||||
|     if (w.hasError()) |     if (w.hasError()) | ||||||
|         return false; |         return false; | ||||||
|     gpsm.write(w); |     gpsm.write(w); | ||||||
|  | |||||||
| @ -4,9 +4,9 @@ namespace DataSpec | |||||||
| { | { | ||||||
| namespace DNAParticle | namespace DNAParticle | ||||||
| { | { | ||||||
| LogVisor::LogModule LogModule("Retro::DNAParticle"); | logvisor::Module LogModule("urde::DNAParticle"); | ||||||
| 
 | 
 | ||||||
| void RealElementFactory::read(Athena::io::YAMLDocReader& r) | void RealElementFactory::read(athena::io::YAMLDocReader& r) | ||||||
| { | { | ||||||
|     const auto& mapChildren = r.getCurNode()->m_mapChildren; |     const auto& mapChildren = r.getCurNode()->m_mapChildren; | ||||||
|     if (mapChildren.empty()) |     if (mapChildren.empty()) | ||||||
| @ -17,7 +17,7 @@ void RealElementFactory::read(Athena::io::YAMLDocReader& r) | |||||||
| 
 | 
 | ||||||
|     const auto& elem = mapChildren[0]; |     const auto& elem = mapChildren[0]; | ||||||
|     if (elem.first.size() < 4) |     if (elem.first.size() < 4) | ||||||
|         LogModule.report(LogVisor::FatalError, "short FourCC in element '%s'", elem.first.c_str()); |         LogModule.report(logvisor::Fatal, "short FourCC in element '%s'", elem.first.c_str()); | ||||||
| 
 | 
 | ||||||
|     switch (*reinterpret_cast<const uint32_t*>(elem.first.data())) |     switch (*reinterpret_cast<const uint32_t*>(elem.first.data())) | ||||||
|     { |     { | ||||||
| @ -130,7 +130,7 @@ void RealElementFactory::read(Athena::io::YAMLDocReader& r) | |||||||
|     r.leaveSubRecord(); |     r.leaveSubRecord(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void RealElementFactory::write(Athena::io::YAMLDocWriter& w) const | void RealElementFactory::write(athena::io::YAMLDocWriter& w) const | ||||||
| { | { | ||||||
|     if (m_elem) |     if (m_elem) | ||||||
|     { |     { | ||||||
| @ -148,7 +148,7 @@ size_t RealElementFactory::binarySize(size_t __isz) const | |||||||
|         return __isz + 4; |         return __isz + 4; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void RealElementFactory::read(Athena::io::IStreamReader& r) | void RealElementFactory::read(athena::io::IStreamReader& r) | ||||||
| { | { | ||||||
|     uint32_t clsId; |     uint32_t clsId; | ||||||
|     r.readBytesToBuf(&clsId, 4); |     r.readBytesToBuf(&clsId, 4); | ||||||
| @ -259,13 +259,13 @@ void RealElementFactory::read(Athena::io::IStreamReader& r) | |||||||
|         return; |         return; | ||||||
|     default: |     default: | ||||||
|         m_elem.reset(); |         m_elem.reset(); | ||||||
|         LogModule.report(LogVisor::FatalError, "Unknown RealElement class %.4s @%" PRIi64, &clsId, r.position()); |         LogModule.report(logvisor::Fatal, "Unknown RealElement class %.4s @%" PRIi64, &clsId, r.position()); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     m_elem->read(r); |     m_elem->read(r); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void RealElementFactory::write(Athena::io::IStreamWriter& w) const | void RealElementFactory::write(athena::io::IStreamWriter& w) const | ||||||
| { | { | ||||||
|     if (m_elem) |     if (m_elem) | ||||||
|     { |     { | ||||||
| @ -277,7 +277,7 @@ void RealElementFactory::write(Athena::io::IStreamWriter& w) const | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| void IntElementFactory::read(Athena::io::YAMLDocReader& r) | void IntElementFactory::read(athena::io::YAMLDocReader& r) | ||||||
| { | { | ||||||
|     const auto& mapChildren = r.getCurNode()->m_mapChildren; |     const auto& mapChildren = r.getCurNode()->m_mapChildren; | ||||||
|     if (mapChildren.empty()) |     if (mapChildren.empty()) | ||||||
| @ -288,7 +288,7 @@ void IntElementFactory::read(Athena::io::YAMLDocReader& r) | |||||||
| 
 | 
 | ||||||
|     const auto& elem = mapChildren[0]; |     const auto& elem = mapChildren[0]; | ||||||
|     if (elem.first.size() < 4) |     if (elem.first.size() < 4) | ||||||
|         LogModule.report(LogVisor::FatalError, "short FourCC in element '%s'", elem.first.c_str()); |         LogModule.report(logvisor::Fatal, "short FourCC in element '%s'", elem.first.c_str()); | ||||||
| 
 | 
 | ||||||
|     switch (*reinterpret_cast<const uint32_t*>(elem.first.data())) |     switch (*reinterpret_cast<const uint32_t*>(elem.first.data())) | ||||||
|     { |     { | ||||||
| @ -353,7 +353,7 @@ void IntElementFactory::read(Athena::io::YAMLDocReader& r) | |||||||
|     r.leaveSubRecord(); |     r.leaveSubRecord(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void IntElementFactory::write(Athena::io::YAMLDocWriter& w) const | void IntElementFactory::write(athena::io::YAMLDocWriter& w) const | ||||||
| { | { | ||||||
|     if (m_elem) |     if (m_elem) | ||||||
|     { |     { | ||||||
| @ -371,7 +371,7 @@ size_t IntElementFactory::binarySize(size_t __isz) const | |||||||
|         return __isz + 4; |         return __isz + 4; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void IntElementFactory::read(Athena::io::IStreamReader& r) | void IntElementFactory::read(athena::io::IStreamReader& r) | ||||||
| { | { | ||||||
|     uint32_t clsId; |     uint32_t clsId; | ||||||
|     r.readBytesToBuf(&clsId, 4); |     r.readBytesToBuf(&clsId, 4); | ||||||
| @ -434,13 +434,13 @@ void IntElementFactory::read(Athena::io::IStreamReader& r) | |||||||
|         return; |         return; | ||||||
|     default: |     default: | ||||||
|         m_elem.reset(); |         m_elem.reset(); | ||||||
|         LogModule.report(LogVisor::FatalError, "Unknown IntElement class %.4s @%" PRIi64, &clsId, r.position()); |         LogModule.report(logvisor::Fatal, "Unknown IntElement class %.4s @%" PRIi64, &clsId, r.position()); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     m_elem->read(r); |     m_elem->read(r); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void IntElementFactory::write(Athena::io::IStreamWriter& w) const | void IntElementFactory::write(athena::io::IStreamWriter& w) const | ||||||
| { | { | ||||||
|     if (m_elem) |     if (m_elem) | ||||||
|     { |     { | ||||||
| @ -451,7 +451,7 @@ void IntElementFactory::write(Athena::io::IStreamWriter& w) const | |||||||
|         w.writeBytes((atInt8*)"NONE", 4); |         w.writeBytes((atInt8*)"NONE", 4); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void VectorElementFactory::read(Athena::io::YAMLDocReader& r) | void VectorElementFactory::read(athena::io::YAMLDocReader& r) | ||||||
| { | { | ||||||
|     const auto& mapChildren = r.getCurNode()->m_mapChildren; |     const auto& mapChildren = r.getCurNode()->m_mapChildren; | ||||||
|     if (mapChildren.empty()) |     if (mapChildren.empty()) | ||||||
| @ -462,7 +462,7 @@ void VectorElementFactory::read(Athena::io::YAMLDocReader& r) | |||||||
| 
 | 
 | ||||||
|     const auto& elem = mapChildren[0]; |     const auto& elem = mapChildren[0]; | ||||||
|     if (elem.first.size() < 4) |     if (elem.first.size() < 4) | ||||||
|         LogModule.report(LogVisor::FatalError, "short FourCC in element '%s'", elem.first.c_str()); |         LogModule.report(logvisor::Fatal, "short FourCC in element '%s'", elem.first.c_str()); | ||||||
| 
 | 
 | ||||||
|     switch (*reinterpret_cast<const uint32_t*>(elem.first.data())) |     switch (*reinterpret_cast<const uint32_t*>(elem.first.data())) | ||||||
|     { |     { | ||||||
| @ -527,7 +527,7 @@ void VectorElementFactory::read(Athena::io::YAMLDocReader& r) | |||||||
|     r.leaveSubRecord(); |     r.leaveSubRecord(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void VectorElementFactory::write(Athena::io::YAMLDocWriter& w) const | void VectorElementFactory::write(athena::io::YAMLDocWriter& w) const | ||||||
| { | { | ||||||
|     if (m_elem) |     if (m_elem) | ||||||
|     { |     { | ||||||
| @ -545,7 +545,7 @@ size_t VectorElementFactory::binarySize(size_t __isz) const | |||||||
|         return __isz + 4; |         return __isz + 4; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void VectorElementFactory::read(Athena::io::IStreamReader& r) | void VectorElementFactory::read(athena::io::IStreamReader& r) | ||||||
| { | { | ||||||
|     uint32_t clsId; |     uint32_t clsId; | ||||||
|     r.readBytesToBuf(&clsId, 4); |     r.readBytesToBuf(&clsId, 4); | ||||||
| @ -608,13 +608,13 @@ void VectorElementFactory::read(Athena::io::IStreamReader& r) | |||||||
|         return; |         return; | ||||||
|     default: |     default: | ||||||
|         m_elem.reset(); |         m_elem.reset(); | ||||||
|         LogModule.report(LogVisor::FatalError, "Unknown VectorElement class %.4s @%" PRIi64, &clsId, r.position()); |         LogModule.report(logvisor::Fatal, "Unknown VectorElement class %.4s @%" PRIi64, &clsId, r.position()); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     m_elem->read(r); |     m_elem->read(r); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void VectorElementFactory::write(Athena::io::IStreamWriter& w) const | void VectorElementFactory::write(athena::io::IStreamWriter& w) const | ||||||
| { | { | ||||||
|     if (m_elem) |     if (m_elem) | ||||||
|     { |     { | ||||||
| @ -626,7 +626,7 @@ void VectorElementFactory::write(Athena::io::IStreamWriter& w) const | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| void ColorElementFactory::read(Athena::io::YAMLDocReader& r) | void ColorElementFactory::read(athena::io::YAMLDocReader& r) | ||||||
| { | { | ||||||
|     const auto& mapChildren = r.getCurNode()->m_mapChildren; |     const auto& mapChildren = r.getCurNode()->m_mapChildren; | ||||||
|     if (mapChildren.empty()) |     if (mapChildren.empty()) | ||||||
| @ -637,7 +637,7 @@ void ColorElementFactory::read(Athena::io::YAMLDocReader& r) | |||||||
| 
 | 
 | ||||||
|     const auto& elem = mapChildren[0]; |     const auto& elem = mapChildren[0]; | ||||||
|     if (elem.first.size() < 4) |     if (elem.first.size() < 4) | ||||||
|         LogModule.report(LogVisor::FatalError, "short FourCC in element '%s'", elem.first.c_str()); |         LogModule.report(logvisor::Fatal, "short FourCC in element '%s'", elem.first.c_str()); | ||||||
| 
 | 
 | ||||||
|     switch (*reinterpret_cast<const uint32_t*>(elem.first.data())) |     switch (*reinterpret_cast<const uint32_t*>(elem.first.data())) | ||||||
|     { |     { | ||||||
| @ -669,7 +669,7 @@ void ColorElementFactory::read(Athena::io::YAMLDocReader& r) | |||||||
|     r.leaveSubRecord(); |     r.leaveSubRecord(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ColorElementFactory::write(Athena::io::YAMLDocWriter& w) const | void ColorElementFactory::write(athena::io::YAMLDocWriter& w) const | ||||||
| { | { | ||||||
|     if (m_elem) |     if (m_elem) | ||||||
|     { |     { | ||||||
| @ -687,7 +687,7 @@ size_t ColorElementFactory::binarySize(size_t __isz) const | |||||||
|         return __isz + 4; |         return __isz + 4; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ColorElementFactory::read(Athena::io::IStreamReader& r) | void ColorElementFactory::read(athena::io::IStreamReader& r) | ||||||
| { | { | ||||||
|     uint32_t clsId; |     uint32_t clsId; | ||||||
|     r.readBytesToBuf(&clsId, 4); |     r.readBytesToBuf(&clsId, 4); | ||||||
| @ -717,13 +717,13 @@ void ColorElementFactory::read(Athena::io::IStreamReader& r) | |||||||
|         return; |         return; | ||||||
|     default: |     default: | ||||||
|         m_elem.reset(); |         m_elem.reset(); | ||||||
|         LogModule.report(LogVisor::FatalError, "Unknown ColorElement class %.4s @%" PRIi64, &clsId, r.position()); |         LogModule.report(logvisor::Fatal, "Unknown ColorElement class %.4s @%" PRIi64, &clsId, r.position()); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     m_elem->read(r); |     m_elem->read(r); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ColorElementFactory::write(Athena::io::IStreamWriter& w) const | void ColorElementFactory::write(athena::io::IStreamWriter& w) const | ||||||
| { | { | ||||||
|     if (m_elem) |     if (m_elem) | ||||||
|     { |     { | ||||||
| @ -735,7 +735,7 @@ void ColorElementFactory::write(Athena::io::IStreamWriter& w) const | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| void ModVectorElementFactory::read(Athena::io::YAMLDocReader& r) | void ModVectorElementFactory::read(athena::io::YAMLDocReader& r) | ||||||
| { | { | ||||||
|     const auto& mapChildren = r.getCurNode()->m_mapChildren; |     const auto& mapChildren = r.getCurNode()->m_mapChildren; | ||||||
|     if (mapChildren.empty()) |     if (mapChildren.empty()) | ||||||
| @ -746,7 +746,7 @@ void ModVectorElementFactory::read(Athena::io::YAMLDocReader& r) | |||||||
| 
 | 
 | ||||||
|     const auto& elem = mapChildren[0]; |     const auto& elem = mapChildren[0]; | ||||||
|     if (elem.first.size() < 4) |     if (elem.first.size() < 4) | ||||||
|         LogModule.report(LogVisor::FatalError, "short FourCC in element '%s'", elem.first.c_str()); |         LogModule.report(logvisor::Fatal, "short FourCC in element '%s'", elem.first.c_str()); | ||||||
| 
 | 
 | ||||||
|     switch (*reinterpret_cast<const uint32_t*>(elem.first.data())) |     switch (*reinterpret_cast<const uint32_t*>(elem.first.data())) | ||||||
|     { |     { | ||||||
| @ -795,7 +795,7 @@ void ModVectorElementFactory::read(Athena::io::YAMLDocReader& r) | |||||||
|     r.leaveSubRecord(); |     r.leaveSubRecord(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ModVectorElementFactory::write(Athena::io::YAMLDocWriter& w) const | void ModVectorElementFactory::write(athena::io::YAMLDocWriter& w) const | ||||||
| { | { | ||||||
|     if (m_elem) |     if (m_elem) | ||||||
|     { |     { | ||||||
| @ -813,7 +813,7 @@ size_t ModVectorElementFactory::binarySize(size_t __isz) const | |||||||
|         return __isz + 4; |         return __isz + 4; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ModVectorElementFactory::read(Athena::io::IStreamReader& r) | void ModVectorElementFactory::read(athena::io::IStreamReader& r) | ||||||
| { | { | ||||||
|     uint32_t clsId; |     uint32_t clsId; | ||||||
|     r.readBytesToBuf(&clsId, 4); |     r.readBytesToBuf(&clsId, 4); | ||||||
| @ -860,13 +860,13 @@ void ModVectorElementFactory::read(Athena::io::IStreamReader& r) | |||||||
|         return; |         return; | ||||||
|     default: |     default: | ||||||
|         m_elem.reset(); |         m_elem.reset(); | ||||||
|         LogModule.report(LogVisor::FatalError, "Unknown ModVectorElement class %.4s @%" PRIi64, &clsId, r.position()); |         LogModule.report(logvisor::Fatal, "Unknown ModVectorElement class %.4s @%" PRIi64, &clsId, r.position()); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     m_elem->read(r); |     m_elem->read(r); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ModVectorElementFactory::write(Athena::io::IStreamWriter& w) const | void ModVectorElementFactory::write(athena::io::IStreamWriter& w) const | ||||||
| { | { | ||||||
|     if (m_elem) |     if (m_elem) | ||||||
|     { |     { | ||||||
| @ -878,7 +878,7 @@ void ModVectorElementFactory::write(Athena::io::IStreamWriter& w) const | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| void EmitterElementFactory::read(Athena::io::YAMLDocReader& r) | void EmitterElementFactory::read(athena::io::YAMLDocReader& r) | ||||||
| { | { | ||||||
|     const auto& mapChildren = r.getCurNode()->m_mapChildren; |     const auto& mapChildren = r.getCurNode()->m_mapChildren; | ||||||
|     if (mapChildren.empty()) |     if (mapChildren.empty()) | ||||||
| @ -889,7 +889,7 @@ void EmitterElementFactory::read(Athena::io::YAMLDocReader& r) | |||||||
| 
 | 
 | ||||||
|     const auto& elem = mapChildren[0]; |     const auto& elem = mapChildren[0]; | ||||||
|     if (elem.first.size() < 4) |     if (elem.first.size() < 4) | ||||||
|         LogModule.report(LogVisor::FatalError, "short FourCC in element '%s'", elem.first.c_str()); |         LogModule.report(logvisor::Fatal, "short FourCC in element '%s'", elem.first.c_str()); | ||||||
| 
 | 
 | ||||||
|     switch (*reinterpret_cast<const uint32_t*>(elem.first.data())) |     switch (*reinterpret_cast<const uint32_t*>(elem.first.data())) | ||||||
|     { |     { | ||||||
| @ -914,7 +914,7 @@ void EmitterElementFactory::read(Athena::io::YAMLDocReader& r) | |||||||
|     r.leaveSubRecord(); |     r.leaveSubRecord(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void EmitterElementFactory::write(Athena::io::YAMLDocWriter& w) const | void EmitterElementFactory::write(athena::io::YAMLDocWriter& w) const | ||||||
| { | { | ||||||
|     if (m_elem) |     if (m_elem) | ||||||
|     { |     { | ||||||
| @ -932,7 +932,7 @@ size_t EmitterElementFactory::binarySize(size_t __isz) const | |||||||
|         return __isz + 4; |         return __isz + 4; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void EmitterElementFactory::read(Athena::io::IStreamReader& r) | void EmitterElementFactory::read(athena::io::IStreamReader& r) | ||||||
| { | { | ||||||
|     uint32_t clsId; |     uint32_t clsId; | ||||||
|     r.readBytesToBuf(&clsId, 4); |     r.readBytesToBuf(&clsId, 4); | ||||||
| @ -955,13 +955,13 @@ void EmitterElementFactory::read(Athena::io::IStreamReader& r) | |||||||
|         return; |         return; | ||||||
|     default: |     default: | ||||||
|         m_elem.reset(); |         m_elem.reset(); | ||||||
|         LogModule.report(LogVisor::FatalError, "Unknown EmitterElement class %.4s @%" PRIi64, &clsId, r.position()); |         LogModule.report(logvisor::Fatal, "Unknown EmitterElement class %.4s @%" PRIi64, &clsId, r.position()); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     m_elem->read(r); |     m_elem->read(r); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void EmitterElementFactory::write(Athena::io::IStreamWriter& w) const | void EmitterElementFactory::write(athena::io::IStreamWriter& w) const | ||||||
| { | { | ||||||
|     if (m_elem) |     if (m_elem) | ||||||
|     { |     { | ||||||
|  | |||||||
| @ -7,7 +7,7 @@ namespace DataSpec | |||||||
| { | { | ||||||
| namespace DNAParticle | namespace DNAParticle | ||||||
| { | { | ||||||
| extern LogVisor::LogModule LogModule; | extern logvisor::Module LogModule; | ||||||
| 
 | 
 | ||||||
| struct IElement : BigYAML | struct IElement : BigYAML | ||||||
| { | { | ||||||
| @ -23,11 +23,11 @@ struct RealElementFactory : BigYAML | |||||||
|     std::unique_ptr<IRealElement> m_elem; |     std::unique_ptr<IRealElement> m_elem; | ||||||
|     operator bool() const {return m_elem.operator bool();} |     operator bool() const {return m_elem.operator bool();} | ||||||
| 
 | 
 | ||||||
|     void read(Athena::io::YAMLDocReader& r); |     void read(athena::io::YAMLDocReader& r); | ||||||
|     void write(Athena::io::YAMLDocWriter& w) const; |     void write(athena::io::YAMLDocWriter& w) const; | ||||||
|     size_t binarySize(size_t __isz) const; |     size_t binarySize(size_t __isz) const; | ||||||
|     void read(Athena::io::IStreamReader& r); |     void read(athena::io::IStreamReader& r); | ||||||
|     void write(Athena::io::IStreamWriter& w) const; |     void write(athena::io::IStreamWriter& w) const; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| struct IIntElement : IElement {Delete _d;}; | struct IIntElement : IElement {Delete _d;}; | ||||||
| @ -37,11 +37,11 @@ struct IntElementFactory : BigYAML | |||||||
|     std::unique_ptr<IIntElement> m_elem; |     std::unique_ptr<IIntElement> m_elem; | ||||||
|     operator bool() const {return m_elem.operator bool();} |     operator bool() const {return m_elem.operator bool();} | ||||||
| 
 | 
 | ||||||
|     void read(Athena::io::YAMLDocReader& r); |     void read(athena::io::YAMLDocReader& r); | ||||||
|     void write(Athena::io::YAMLDocWriter& w) const; |     void write(athena::io::YAMLDocWriter& w) const; | ||||||
|     size_t binarySize(size_t __isz) const; |     size_t binarySize(size_t __isz) const; | ||||||
|     void read(Athena::io::IStreamReader& r); |     void read(athena::io::IStreamReader& r); | ||||||
|     void write(Athena::io::IStreamWriter& w) const; |     void write(athena::io::IStreamWriter& w) const; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| struct IVectorElement : IElement {Delete _d;}; | struct IVectorElement : IElement {Delete _d;}; | ||||||
| @ -51,11 +51,11 @@ struct VectorElementFactory : BigYAML | |||||||
|     std::unique_ptr<IVectorElement> m_elem; |     std::unique_ptr<IVectorElement> m_elem; | ||||||
|     operator bool() const {return m_elem.operator bool();} |     operator bool() const {return m_elem.operator bool();} | ||||||
| 
 | 
 | ||||||
|     void read(Athena::io::YAMLDocReader& r); |     void read(athena::io::YAMLDocReader& r); | ||||||
|     void write(Athena::io::YAMLDocWriter& w) const; |     void write(athena::io::YAMLDocWriter& w) const; | ||||||
|     size_t binarySize(size_t __isz) const; |     size_t binarySize(size_t __isz) const; | ||||||
|     void read(Athena::io::IStreamReader& r); |     void read(athena::io::IStreamReader& r); | ||||||
|     void write(Athena::io::IStreamWriter& w) const; |     void write(athena::io::IStreamWriter& w) const; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| struct IColorElement : IElement {Delete _d;}; | struct IColorElement : IElement {Delete _d;}; | ||||||
| @ -65,11 +65,11 @@ struct ColorElementFactory : BigYAML | |||||||
|     std::unique_ptr<IColorElement> m_elem; |     std::unique_ptr<IColorElement> m_elem; | ||||||
|     operator bool() const {return m_elem.operator bool();} |     operator bool() const {return m_elem.operator bool();} | ||||||
| 
 | 
 | ||||||
|     void read(Athena::io::YAMLDocReader& r); |     void read(athena::io::YAMLDocReader& r); | ||||||
|     void write(Athena::io::YAMLDocWriter& w) const; |     void write(athena::io::YAMLDocWriter& w) const; | ||||||
|     size_t binarySize(size_t __isz) const; |     size_t binarySize(size_t __isz) const; | ||||||
|     void read(Athena::io::IStreamReader& r); |     void read(athena::io::IStreamReader& r); | ||||||
|     void write(Athena::io::IStreamWriter& w) const; |     void write(athena::io::IStreamWriter& w) const; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| struct IModVectorElement : IElement {Delete _d;}; | struct IModVectorElement : IElement {Delete _d;}; | ||||||
| @ -79,11 +79,11 @@ struct ModVectorElementFactory : BigYAML | |||||||
|     std::unique_ptr<IModVectorElement> m_elem; |     std::unique_ptr<IModVectorElement> m_elem; | ||||||
|     operator bool() const {return m_elem.operator bool();} |     operator bool() const {return m_elem.operator bool();} | ||||||
| 
 | 
 | ||||||
|     void read(Athena::io::YAMLDocReader& r); |     void read(athena::io::YAMLDocReader& r); | ||||||
|     void write(Athena::io::YAMLDocWriter& w) const; |     void write(athena::io::YAMLDocWriter& w) const; | ||||||
|     size_t binarySize(size_t __isz) const; |     size_t binarySize(size_t __isz) const; | ||||||
|     void read(Athena::io::IStreamReader& r); |     void read(athena::io::IStreamReader& r); | ||||||
|     void write(Athena::io::IStreamWriter& w) const; |     void write(athena::io::IStreamWriter& w) const; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| struct IEmitterElement : IElement {Delete _d;}; | struct IEmitterElement : IElement {Delete _d;}; | ||||||
| @ -93,11 +93,11 @@ struct EmitterElementFactory : BigYAML | |||||||
|     std::unique_ptr<IEmitterElement> m_elem; |     std::unique_ptr<IEmitterElement> m_elem; | ||||||
|     operator bool() const {return m_elem.operator bool();} |     operator bool() const {return m_elem.operator bool();} | ||||||
| 
 | 
 | ||||||
|     void read(Athena::io::YAMLDocReader& r); |     void read(athena::io::YAMLDocReader& r); | ||||||
|     void write(Athena::io::YAMLDocWriter& w) const; |     void write(athena::io::YAMLDocWriter& w) const; | ||||||
|     size_t binarySize(size_t __isz) const; |     size_t binarySize(size_t __isz) const; | ||||||
|     void read(Athena::io::IStreamReader& r); |     void read(athena::io::IStreamReader& r); | ||||||
|     void write(Athena::io::IStreamWriter& w) const; |     void write(athena::io::IStreamWriter& w) const; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| struct IUVElement : IElement {Delete _d;}; | struct IUVElement : IElement {Delete _d;}; | ||||||
| @ -108,11 +108,11 @@ struct BoolHelper : IElement | |||||||
|     bool value = false; |     bool value = false; | ||||||
|     operator bool() const {return value;} |     operator bool() const {return value;} | ||||||
|     BoolHelper& operator=(bool val) {value = val; return *this;} |     BoolHelper& operator=(bool val) {value = val; return *this;} | ||||||
|     void read(Athena::io::YAMLDocReader& r) |     void read(athena::io::YAMLDocReader& r) | ||||||
|     { |     { | ||||||
|         value = r.readBool(nullptr); |         value = r.readBool(nullptr); | ||||||
|     } |     } | ||||||
|     void write(Athena::io::YAMLDocWriter& w) const |     void write(athena::io::YAMLDocWriter& w) const | ||||||
|     { |     { | ||||||
|         w.writeBool(nullptr, value); |         w.writeBool(nullptr, value); | ||||||
|     } |     } | ||||||
| @ -120,7 +120,7 @@ struct BoolHelper : IElement | |||||||
|     { |     { | ||||||
|         return __isz + 5; |         return __isz + 5; | ||||||
|     } |     } | ||||||
|     void read(Athena::io::IStreamReader& r) |     void read(athena::io::IStreamReader& r) | ||||||
|     { |     { | ||||||
|         uint32_t clsId; |         uint32_t clsId; | ||||||
|         r.readBytesToBuf(&clsId, 4); |         r.readBytesToBuf(&clsId, 4); | ||||||
| @ -129,7 +129,7 @@ struct BoolHelper : IElement | |||||||
|         else |         else | ||||||
|             value = false; |             value = false; | ||||||
|     } |     } | ||||||
|     void write(Athena::io::IStreamWriter& w) const |     void write(athena::io::IStreamWriter& w) const | ||||||
|     { |     { | ||||||
|         w.writeBytes((atInt8*)"CNST", 4); |         w.writeBytes((atInt8*)"CNST", 4); | ||||||
|         w.writeBool(value); |         w.writeBool(value); | ||||||
| @ -150,11 +150,11 @@ struct REConstant : IRealElement | |||||||
|     Delete _d; |     Delete _d; | ||||||
|     Value<float> val; |     Value<float> val; | ||||||
| 
 | 
 | ||||||
|     void read(Athena::io::YAMLDocReader& r) |     void read(athena::io::YAMLDocReader& r) | ||||||
|     { |     { | ||||||
|         val = r.readFloat(nullptr); |         val = r.readFloat(nullptr); | ||||||
|     } |     } | ||||||
|     void write(Athena::io::YAMLDocWriter& w) const |     void write(athena::io::YAMLDocWriter& w) const | ||||||
|     { |     { | ||||||
|         w.writeFloat(nullptr, val); |         w.writeFloat(nullptr, val); | ||||||
|     } |     } | ||||||
| @ -162,11 +162,11 @@ struct REConstant : IRealElement | |||||||
|     { |     { | ||||||
|         return __isz + 4; |         return __isz + 4; | ||||||
|     } |     } | ||||||
|     void read(Athena::io::IStreamReader& r) |     void read(athena::io::IStreamReader& r) | ||||||
|     { |     { | ||||||
|         val = r.readFloatBig(); |         val = r.readFloatBig(); | ||||||
|     } |     } | ||||||
|     void write(Athena::io::IStreamWriter& w) const |     void write(athena::io::IStreamWriter& w) const | ||||||
|     { |     { | ||||||
|         w.writeFloatBig(val); |         w.writeFloatBig(val); | ||||||
|     } |     } | ||||||
| @ -463,11 +463,11 @@ struct IEConstant : IIntElement | |||||||
|     Delete _d; |     Delete _d; | ||||||
|     Value<atUint32> val; |     Value<atUint32> val; | ||||||
| 
 | 
 | ||||||
|     void read(Athena::io::YAMLDocReader& r) |     void read(athena::io::YAMLDocReader& r) | ||||||
|     { |     { | ||||||
|         val = r.readUint32(nullptr); |         val = r.readUint32(nullptr); | ||||||
|     } |     } | ||||||
|     void write(Athena::io::YAMLDocWriter& w) const |     void write(athena::io::YAMLDocWriter& w) const | ||||||
|     { |     { | ||||||
|         w.writeUint32(nullptr, val); |         w.writeUint32(nullptr, val); | ||||||
|     } |     } | ||||||
| @ -475,11 +475,11 @@ struct IEConstant : IIntElement | |||||||
|     { |     { | ||||||
|         return __isz + 4; |         return __isz + 4; | ||||||
|     } |     } | ||||||
|     void read(Athena::io::IStreamReader& r) |     void read(athena::io::IStreamReader& r) | ||||||
|     { |     { | ||||||
|         val = r.readUint32Big(); |         val = r.readUint32Big(); | ||||||
|     } |     } | ||||||
|     void write(Athena::io::IStreamWriter& w) const |     void write(athena::io::IStreamWriter& w) const | ||||||
|     { |     { | ||||||
|         w.writeUint32Big(val); |         w.writeUint32Big(val); | ||||||
|     } |     } | ||||||
| @ -624,7 +624,7 @@ struct VEConstant : IVectorElement | |||||||
|     Delete _d; |     Delete _d; | ||||||
|     RealElementFactory comps[3]; |     RealElementFactory comps[3]; | ||||||
| 
 | 
 | ||||||
|     void read(Athena::io::YAMLDocReader& r) |     void read(athena::io::YAMLDocReader& r) | ||||||
|     { |     { | ||||||
|         for (int i=0 ; i<3 ; ++i) |         for (int i=0 ; i<3 ; ++i) | ||||||
|         { |         { | ||||||
| @ -633,7 +633,7 @@ struct VEConstant : IVectorElement | |||||||
|             r.leaveSubRecord(); |             r.leaveSubRecord(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     void write(Athena::io::YAMLDocWriter& w) const |     void write(athena::io::YAMLDocWriter& w) const | ||||||
|     { |     { | ||||||
|         w.enterSubVector(nullptr); |         w.enterSubVector(nullptr); | ||||||
|         for (int i=0 ; i<3 ; ++i) |         for (int i=0 ; i<3 ; ++i) | ||||||
| @ -650,13 +650,13 @@ struct VEConstant : IVectorElement | |||||||
|         __isz = comps[1].binarySize(__isz); |         __isz = comps[1].binarySize(__isz); | ||||||
|         return comps[2].binarySize(__isz); |         return comps[2].binarySize(__isz); | ||||||
|     } |     } | ||||||
|     void read(Athena::io::IStreamReader& r) |     void read(athena::io::IStreamReader& r) | ||||||
|     { |     { | ||||||
|         comps[0].read(r); |         comps[0].read(r); | ||||||
|         comps[1].read(r); |         comps[1].read(r); | ||||||
|         comps[2].read(r); |         comps[2].read(r); | ||||||
|     } |     } | ||||||
|     void write(Athena::io::IStreamWriter& w) const |     void write(athena::io::IStreamWriter& w) const | ||||||
|     { |     { | ||||||
|         comps[0].write(w); |         comps[0].write(w); | ||||||
|         comps[1].write(w); |         comps[1].write(w); | ||||||
| @ -772,7 +772,7 @@ struct CEConstant : IColorElement | |||||||
|     Delete _d; |     Delete _d; | ||||||
|     RealElementFactory comps[4]; |     RealElementFactory comps[4]; | ||||||
| 
 | 
 | ||||||
|     void read(Athena::io::YAMLDocReader& r) |     void read(athena::io::YAMLDocReader& r) | ||||||
|     { |     { | ||||||
|         for (int i=0 ; i<4 ; ++i) |         for (int i=0 ; i<4 ; ++i) | ||||||
|         { |         { | ||||||
| @ -781,7 +781,7 @@ struct CEConstant : IColorElement | |||||||
|             r.leaveSubRecord(); |             r.leaveSubRecord(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     void write(Athena::io::YAMLDocWriter& w) const |     void write(athena::io::YAMLDocWriter& w) const | ||||||
|     { |     { | ||||||
|         w.enterSubVector(nullptr); |         w.enterSubVector(nullptr); | ||||||
|         for (int i=0 ; i<4 ; ++i) |         for (int i=0 ; i<4 ; ++i) | ||||||
| @ -799,14 +799,14 @@ struct CEConstant : IColorElement | |||||||
|         __isz = comps[2].binarySize(__isz); |         __isz = comps[2].binarySize(__isz); | ||||||
|         return comps[3].binarySize(__isz); |         return comps[3].binarySize(__isz); | ||||||
|     } |     } | ||||||
|     void read(Athena::io::IStreamReader& r) |     void read(athena::io::IStreamReader& r) | ||||||
|     { |     { | ||||||
|         comps[0].read(r); |         comps[0].read(r); | ||||||
|         comps[1].read(r); |         comps[1].read(r); | ||||||
|         comps[2].read(r); |         comps[2].read(r); | ||||||
|         comps[3].read(r); |         comps[3].read(r); | ||||||
|     } |     } | ||||||
|     void write(Athena::io::IStreamWriter& w) const |     void write(athena::io::IStreamWriter& w) const | ||||||
|     { |     { | ||||||
|         comps[0].write(w); |         comps[0].write(w); | ||||||
|         comps[1].write(w); |         comps[1].write(w); | ||||||
| @ -902,7 +902,7 @@ struct MVEConstant : IModVectorElement | |||||||
|     Delete _d; |     Delete _d; | ||||||
|     RealElementFactory comps[3]; |     RealElementFactory comps[3]; | ||||||
| 
 | 
 | ||||||
|     void read(Athena::io::YAMLDocReader& r) |     void read(athena::io::YAMLDocReader& r) | ||||||
|     { |     { | ||||||
|         for (int i=0 ; i<3 ; ++i) |         for (int i=0 ; i<3 ; ++i) | ||||||
|         { |         { | ||||||
| @ -911,7 +911,7 @@ struct MVEConstant : IModVectorElement | |||||||
|             r.leaveSubRecord(); |             r.leaveSubRecord(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     void write(Athena::io::YAMLDocWriter& w) const |     void write(athena::io::YAMLDocWriter& w) const | ||||||
|     { |     { | ||||||
|         w.enterSubVector(nullptr); |         w.enterSubVector(nullptr); | ||||||
|         for (int i=0 ; i<3 ; ++i) |         for (int i=0 ; i<3 ; ++i) | ||||||
| @ -928,13 +928,13 @@ struct MVEConstant : IModVectorElement | |||||||
|         __isz = comps[1].binarySize(__isz); |         __isz = comps[1].binarySize(__isz); | ||||||
|         return comps[2].binarySize(__isz); |         return comps[2].binarySize(__isz); | ||||||
|     } |     } | ||||||
|     void read(Athena::io::IStreamReader& r) |     void read(athena::io::IStreamReader& r) | ||||||
|     { |     { | ||||||
|         comps[0].read(r); |         comps[0].read(r); | ||||||
|         comps[1].read(r); |         comps[1].read(r); | ||||||
|         comps[2].read(r); |         comps[2].read(r); | ||||||
|     } |     } | ||||||
|     void write(Athena::io::IStreamWriter& w) const |     void write(athena::io::IStreamWriter& w) const | ||||||
|     { |     { | ||||||
|         comps[0].write(w); |         comps[0].write(w); | ||||||
|         comps[1].write(w); |         comps[1].write(w); | ||||||
| @ -1039,7 +1039,7 @@ struct EESimpleEmitterTR : EESimpleEmitter | |||||||
| { | { | ||||||
|     Delete _d; |     Delete _d; | ||||||
| 
 | 
 | ||||||
|     void read(Athena::io::YAMLDocReader& r) |     void read(athena::io::YAMLDocReader& r) | ||||||
|     { |     { | ||||||
|         position.m_elem.reset(); |         position.m_elem.reset(); | ||||||
|         velocity.m_elem.reset(); |         velocity.m_elem.reset(); | ||||||
| @ -1054,7 +1054,7 @@ struct EESimpleEmitterTR : EESimpleEmitter | |||||||
|             r.leaveSubRecord(); |             r.leaveSubRecord(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     void write(Athena::io::YAMLDocWriter& w) const |     void write(athena::io::YAMLDocWriter& w) const | ||||||
|     { |     { | ||||||
|         w.enterSubRecord("ILOC"); |         w.enterSubRecord("ILOC"); | ||||||
|         position.write(w); |         position.write(w); | ||||||
| @ -1070,7 +1070,7 @@ struct EESimpleEmitterTR : EESimpleEmitter | |||||||
|         __isz = velocity.binarySize(__isz); |         __isz = velocity.binarySize(__isz); | ||||||
|         return __isz; |         return __isz; | ||||||
|     } |     } | ||||||
|     void read(Athena::io::IStreamReader& r) |     void read(athena::io::IStreamReader& r) | ||||||
|     { |     { | ||||||
|         position.m_elem.reset(); |         position.m_elem.reset(); | ||||||
|         velocity.m_elem.reset(); |         velocity.m_elem.reset(); | ||||||
| @ -1084,7 +1084,7 @@ struct EESimpleEmitterTR : EESimpleEmitter | |||||||
|                 velocity.read(r); |                 velocity.read(r); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     void write(Athena::io::IStreamWriter& w) const |     void write(athena::io::IStreamWriter& w) const | ||||||
|     { |     { | ||||||
|         w.writeBytes((atInt8*)"ILOC", 4); |         w.writeBytes((atInt8*)"ILOC", 4); | ||||||
|         position.write(w); |         position.write(w); | ||||||
| @ -1099,7 +1099,7 @@ struct UVEConstant : IUVElement | |||||||
| { | { | ||||||
|     Delete _d; |     Delete _d; | ||||||
|     IDType tex; |     IDType tex; | ||||||
|     void read(Athena::io::YAMLDocReader& r) |     void read(athena::io::YAMLDocReader& r) | ||||||
|     { |     { | ||||||
|         tex.clear(); |         tex.clear(); | ||||||
|         if (r.enterSubRecord("tex")) |         if (r.enterSubRecord("tex")) | ||||||
| @ -1108,7 +1108,7 @@ struct UVEConstant : IUVElement | |||||||
|             r.leaveSubRecord(); |             r.leaveSubRecord(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     void write(Athena::io::YAMLDocWriter& w) const |     void write(athena::io::YAMLDocWriter& w) const | ||||||
|     { |     { | ||||||
|         w.enterSubRecord("tex"); |         w.enterSubRecord("tex"); | ||||||
|         tex.write(w); |         tex.write(w); | ||||||
| @ -1118,7 +1118,7 @@ struct UVEConstant : IUVElement | |||||||
|     { |     { | ||||||
|         return tex.binarySize(__isz + 4); |         return tex.binarySize(__isz + 4); | ||||||
|     } |     } | ||||||
|     void read(Athena::io::IStreamReader& r) |     void read(athena::io::IStreamReader& r) | ||||||
|     { |     { | ||||||
|         tex.clear(); |         tex.clear(); | ||||||
|         uint32_t clsId; |         uint32_t clsId; | ||||||
| @ -1126,7 +1126,7 @@ struct UVEConstant : IUVElement | |||||||
|         if (clsId == SBIG('CNST')) |         if (clsId == SBIG('CNST')) | ||||||
|             tex.read(r); |             tex.read(r); | ||||||
|     } |     } | ||||||
|     void write(Athena::io::IStreamWriter& w) const |     void write(athena::io::IStreamWriter& w) const | ||||||
|     { |     { | ||||||
|         w.writeBytes((atInt8*)"CNST", 4); |         w.writeBytes((atInt8*)"CNST", 4); | ||||||
|         tex.write(w); |         tex.write(w); | ||||||
| @ -1145,7 +1145,7 @@ struct UVEAnimTexture : IUVElement | |||||||
|     IntElementFactory strideH; |     IntElementFactory strideH; | ||||||
|     IntElementFactory cycleFrames; |     IntElementFactory cycleFrames; | ||||||
|     Value<bool> loop = false; |     Value<bool> loop = false; | ||||||
|     void read(Athena::io::YAMLDocReader& r) |     void read(athena::io::YAMLDocReader& r) | ||||||
|     { |     { | ||||||
|         tex.clear(); |         tex.clear(); | ||||||
|         if (r.enterSubRecord("tex")) |         if (r.enterSubRecord("tex")) | ||||||
| @ -1184,7 +1184,7 @@ struct UVEAnimTexture : IUVElement | |||||||
|             r.leaveSubRecord(); |             r.leaveSubRecord(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     void write(Athena::io::YAMLDocWriter& w) const |     void write(athena::io::YAMLDocWriter& w) const | ||||||
|     { |     { | ||||||
|         w.enterSubRecord("tex"); |         w.enterSubRecord("tex"); | ||||||
|         tex.write(w); |         tex.write(w); | ||||||
| @ -1217,7 +1217,7 @@ struct UVEAnimTexture : IUVElement | |||||||
|         __isz = cycleFrames.binarySize(__isz); |         __isz = cycleFrames.binarySize(__isz); | ||||||
|         return __isz; |         return __isz; | ||||||
|     } |     } | ||||||
|     void read(Athena::io::IStreamReader& r) |     void read(athena::io::IStreamReader& r) | ||||||
|     { |     { | ||||||
|         tex.clear(); |         tex.clear(); | ||||||
|         uint32_t clsId; |         uint32_t clsId; | ||||||
| @ -1233,7 +1233,7 @@ struct UVEAnimTexture : IUVElement | |||||||
|         if (clsId == SBIG('CNST')) |         if (clsId == SBIG('CNST')) | ||||||
|             loop = r.readBool(); |             loop = r.readBool(); | ||||||
|     } |     } | ||||||
|     void write(Athena::io::IStreamWriter& w) const |     void write(athena::io::IStreamWriter& w) const | ||||||
|     { |     { | ||||||
|         w.writeBytes((atInt8*)"CNST", 4); |         w.writeBytes((atInt8*)"CNST", 4); | ||||||
|         tex.write(w); |         tex.write(w); | ||||||
| @ -1255,7 +1255,7 @@ struct UVElementFactory : BigYAML | |||||||
|     std::unique_ptr<IUVElement> m_elem; |     std::unique_ptr<IUVElement> m_elem; | ||||||
|     operator bool() const {return m_elem.operator bool();} |     operator bool() const {return m_elem.operator bool();} | ||||||
| 
 | 
 | ||||||
|     void read(Athena::io::YAMLDocReader& r) |     void read(athena::io::YAMLDocReader& r) | ||||||
|     { |     { | ||||||
|         if (r.enterSubRecord("CNST")) |         if (r.enterSubRecord("CNST")) | ||||||
|         { |         { | ||||||
| @ -1273,7 +1273,7 @@ struct UVElementFactory : BigYAML | |||||||
|             m_elem.reset(); |             m_elem.reset(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void write(Athena::io::YAMLDocWriter& w) const |     void write(athena::io::YAMLDocWriter& w) const | ||||||
|     { |     { | ||||||
|         if (m_elem) |         if (m_elem) | ||||||
|         { |         { | ||||||
| @ -1291,7 +1291,7 @@ struct UVElementFactory : BigYAML | |||||||
|             return __isz + 4; |             return __isz + 4; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void read(Athena::io::IStreamReader& r) |     void read(athena::io::IStreamReader& r) | ||||||
|     { |     { | ||||||
|         uint32_t clsId; |         uint32_t clsId; | ||||||
|         r.readBytesToBuf(&clsId, 4); |         r.readBytesToBuf(&clsId, 4); | ||||||
| @ -1310,7 +1310,7 @@ struct UVElementFactory : BigYAML | |||||||
|         m_elem->read(r); |         m_elem->read(r); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void write(Athena::io::IStreamWriter& w) const |     void write(athena::io::IStreamWriter& w) const | ||||||
|     { |     { | ||||||
|         if (m_elem) |         if (m_elem) | ||||||
|         { |         { | ||||||
| @ -1339,7 +1339,7 @@ struct SpawnSystemKeyframeData : BigYAML | |||||||
|         Value<atUint32> b; |         Value<atUint32> b; | ||||||
|         Value<atUint32> c; |         Value<atUint32> c; | ||||||
| 
 | 
 | ||||||
|         void read(Athena::io::YAMLDocReader& r) |         void read(athena::io::YAMLDocReader& r) | ||||||
|         { |         { | ||||||
|             if (r.enterSubRecord("id")) |             if (r.enterSubRecord("id")) | ||||||
|             { |             { | ||||||
| @ -1362,7 +1362,7 @@ struct SpawnSystemKeyframeData : BigYAML | |||||||
|                 r.leaveSubRecord(); |                 r.leaveSubRecord(); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         void write(Athena::io::YAMLDocWriter& w) const |         void write(athena::io::YAMLDocWriter& w) const | ||||||
|         { |         { | ||||||
|             w.enterSubRecord("id"); |             w.enterSubRecord("id"); | ||||||
|             id.write(w); |             id.write(w); | ||||||
| @ -1375,14 +1375,14 @@ struct SpawnSystemKeyframeData : BigYAML | |||||||
|         { |         { | ||||||
|             return id.binarySize(__isz + 12); |             return id.binarySize(__isz + 12); | ||||||
|         } |         } | ||||||
|         void read(Athena::io::IStreamReader& r) |         void read(athena::io::IStreamReader& r) | ||||||
|         { |         { | ||||||
|             id.read(r); |             id.read(r); | ||||||
|             a = r.readUint32Big(); |             a = r.readUint32Big(); | ||||||
|             b = r.readUint32Big(); |             b = r.readUint32Big(); | ||||||
|             c = r.readUint32Big(); |             c = r.readUint32Big(); | ||||||
|         } |         } | ||||||
|         void write(Athena::io::IStreamWriter& w) const |         void write(athena::io::IStreamWriter& w) const | ||||||
|         { |         { | ||||||
|             id.write(w); |             id.write(w); | ||||||
|             w.writeUint32Big(a); |             w.writeUint32Big(a); | ||||||
| @ -1393,7 +1393,7 @@ struct SpawnSystemKeyframeData : BigYAML | |||||||
| 
 | 
 | ||||||
|     std::vector<std::pair<atUint32, std::vector<SpawnSystemKeyframeInfo>>> spawns; |     std::vector<std::pair<atUint32, std::vector<SpawnSystemKeyframeInfo>>> spawns; | ||||||
| 
 | 
 | ||||||
|     void read(Athena::io::YAMLDocReader& r) |     void read(athena::io::YAMLDocReader& r) | ||||||
|     { |     { | ||||||
|         if (r.enterSubRecord("a")) |         if (r.enterSubRecord("a")) | ||||||
|         { |         { | ||||||
| @ -1416,18 +1416,20 @@ struct SpawnSystemKeyframeData : BigYAML | |||||||
|             r.leaveSubRecord(); |             r.leaveSubRecord(); | ||||||
|         } |         } | ||||||
|         spawns.clear(); |         spawns.clear(); | ||||||
|         if (r.enterSubVector("spawns")) |         size_t spawnCount; | ||||||
|  |         if (r.enterSubVector("spawns", spawnCount)) | ||||||
|         { |         { | ||||||
|             spawns.reserve(r.getCurNode()->m_seqChildren.size()); |             spawns.reserve(spawnCount); | ||||||
|             for (const auto& child : r.getCurNode()->m_seqChildren) |             for (const auto& child : r.getCurNode()->m_seqChildren) | ||||||
|             { |             { | ||||||
|                 if (r.enterSubRecord(nullptr)) |                 if (r.enterSubRecord(nullptr)) | ||||||
|                 { |                 { | ||||||
|                     spawns.emplace_back(); |                     spawns.emplace_back(); | ||||||
|                     spawns.back().first = r.readUint32("startFrame"); |                     spawns.back().first = r.readUint32("startFrame"); | ||||||
|                     if (r.enterSubVector("systems")) |                     size_t systemCount; | ||||||
|  |                     if (r.enterSubVector("systems", systemCount)) | ||||||
|                     { |                     { | ||||||
|                         spawns.back().second.reserve(r.getCurNode()->m_seqChildren.size()); |                         spawns.back().second.reserve(systemCount); | ||||||
|                         for (const auto& in : r.getCurNode()->m_seqChildren) |                         for (const auto& in : r.getCurNode()->m_seqChildren) | ||||||
|                         { |                         { | ||||||
|                             spawns.back().second.emplace_back(); |                             spawns.back().second.emplace_back(); | ||||||
| @ -1444,7 +1446,7 @@ struct SpawnSystemKeyframeData : BigYAML | |||||||
|             r.leaveSubVector(); |             r.leaveSubVector(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     void write(Athena::io::YAMLDocWriter& w) const |     void write(athena::io::YAMLDocWriter& w) const | ||||||
|     { |     { | ||||||
|         if (spawns.empty()) |         if (spawns.empty()) | ||||||
|             return; |             return; | ||||||
| @ -1480,7 +1482,7 @@ struct SpawnSystemKeyframeData : BigYAML | |||||||
|         } |         } | ||||||
|         return __isz; |         return __isz; | ||||||
|     } |     } | ||||||
|     void read(Athena::io::IStreamReader& r) |     void read(athena::io::IStreamReader& r) | ||||||
|     { |     { | ||||||
|         uint32_t clsId; |         uint32_t clsId; | ||||||
|         r.readBytesToBuf(&clsId, 4); |         r.readBytesToBuf(&clsId, 4); | ||||||
| @ -1507,7 +1509,7 @@ struct SpawnSystemKeyframeData : BigYAML | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     void write(Athena::io::IStreamWriter& w) const |     void write(athena::io::IStreamWriter& w) const | ||||||
|     { |     { | ||||||
|         if (spawns.empty()) |         if (spawns.empty()) | ||||||
|         { |         { | ||||||
| @ -1537,7 +1539,7 @@ struct ChildResourceFactory : BigYAML | |||||||
| { | { | ||||||
|     Delete _d; |     Delete _d; | ||||||
|     IDType id; |     IDType id; | ||||||
|     void read(Athena::io::YAMLDocReader& r) |     void read(athena::io::YAMLDocReader& r) | ||||||
|     { |     { | ||||||
|         id.clear(); |         id.clear(); | ||||||
|         if (r.enterSubRecord("CNST")) |         if (r.enterSubRecord("CNST")) | ||||||
| @ -1546,7 +1548,7 @@ struct ChildResourceFactory : BigYAML | |||||||
|             r.leaveSubRecord(); |             r.leaveSubRecord(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     void write(Athena::io::YAMLDocWriter& w) const |     void write(athena::io::YAMLDocWriter& w) const | ||||||
|     { |     { | ||||||
|         if (id) |         if (id) | ||||||
|         { |         { | ||||||
| @ -1562,7 +1564,7 @@ struct ChildResourceFactory : BigYAML | |||||||
|         else |         else | ||||||
|             return __isz + 4; |             return __isz + 4; | ||||||
|     } |     } | ||||||
|     void read(Athena::io::IStreamReader& r) |     void read(athena::io::IStreamReader& r) | ||||||
|     { |     { | ||||||
|         id.clear(); |         id.clear(); | ||||||
|         uint32_t clsId; |         uint32_t clsId; | ||||||
| @ -1570,7 +1572,7 @@ struct ChildResourceFactory : BigYAML | |||||||
|         if (clsId == SBIG('CNST')) |         if (clsId == SBIG('CNST')) | ||||||
|             id.read(r); |             id.read(r); | ||||||
|     } |     } | ||||||
|     void write(Athena::io::IStreamWriter& w) const |     void write(athena::io::IStreamWriter& w) const | ||||||
|     { |     { | ||||||
|         if (id) |         if (id) | ||||||
|         { |         { | ||||||
|  | |||||||
| @ -6,12 +6,12 @@ | |||||||
| namespace DataSpec | namespace DataSpec | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| std::unique_ptr<ISTRG> LoadSTRG(Athena::io::IStreamReader& reader) | std::unique_ptr<ISTRG> LoadSTRG(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     uint32_t magic = reader.readUint32Big(); |     uint32_t magic = reader.readUint32Big(); | ||||||
|     if (magic != 0x87654321) |     if (magic != 0x87654321) | ||||||
|     { |     { | ||||||
|         LogDNACommon.report(LogVisor::Error, "invalid STRG magic"); |         LogDNACommon.report(logvisor::Error, "invalid STRG magic"); | ||||||
|         return std::unique_ptr<ISTRG>(); |         return std::unique_ptr<ISTRG>(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -3,9 +3,9 @@ | |||||||
| 
 | 
 | ||||||
| #include <string> | #include <string> | ||||||
| #include <fstream> | #include <fstream> | ||||||
| #include <HECL/HECL.hpp> | #include <hecl/hecl.hpp> | ||||||
| #include <HECL/Database.hpp> | #include <hecl/Database.hpp> | ||||||
| #include <Athena/FileWriter.hpp> | #include <athena/FileWriter.hpp> | ||||||
| #include "DNACommon.hpp" | #include "DNACommon.hpp" | ||||||
| 
 | 
 | ||||||
| namespace DataSpec | namespace DataSpec | ||||||
| @ -17,10 +17,10 @@ struct ISTRG : BigYAML | |||||||
|     virtual size_t count() const=0; |     virtual size_t count() const=0; | ||||||
|     virtual std::string getUTF8(const FourCC& lang, size_t idx) const=0; |     virtual std::string getUTF8(const FourCC& lang, size_t idx) const=0; | ||||||
|     virtual std::wstring getUTF16(const FourCC& lang, size_t idx) const=0; |     virtual std::wstring getUTF16(const FourCC& lang, size_t idx) const=0; | ||||||
|     virtual HECL::SystemString getSystemString(const FourCC& lang, size_t idx) const=0; |     virtual hecl::SystemString getSystemString(const FourCC& lang, size_t idx) const=0; | ||||||
|     virtual int32_t lookupIdx(const std::string& name) const=0; |     virtual int32_t lookupIdx(const std::string& name) const=0; | ||||||
| }; | }; | ||||||
| std::unique_ptr<ISTRG> LoadSTRG(Athena::io::IStreamReader& reader); | std::unique_ptr<ISTRG> LoadSTRG(athena::io::IStreamReader& reader); | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -6,7 +6,7 @@ | |||||||
| namespace DataSpec | namespace DataSpec | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| static LogVisor::LogModule Log("libpng"); | static logvisor::Module Log("libpng"); | ||||||
| 
 | 
 | ||||||
| /* GX uses this upsampling technique to prevent banding on downsampled texture formats */ | /* GX uses this upsampling technique to prevent banding on downsampled texture formats */ | ||||||
| static inline uint8_t Convert3To8(uint8_t v) | static inline uint8_t Convert3To8(uint8_t v) | ||||||
| @ -80,10 +80,10 @@ static inline void LookupRGBA8(const uint8_t* texels, int width, int x, int y, | |||||||
|     int bidx = (by * bwidth + bx) * 2; |     int bidx = (by * bwidth + bx) * 2; | ||||||
|     const uint16_t* artexels = (uint16_t*)&texels[32*bidx]; |     const uint16_t* artexels = (uint16_t*)&texels[32*bidx]; | ||||||
|     const uint16_t* gbtexels = (uint16_t*)&texels[32*(bidx+1)]; |     const uint16_t* gbtexels = (uint16_t*)&texels[32*(bidx+1)]; | ||||||
|     uint16_t ar = HECL::SBig(artexels[ry*4+rx]); |     uint16_t ar = hecl::SBig(artexels[ry*4+rx]); | ||||||
|     *a = ar >> 8 & 0xff; |     *a = ar >> 8 & 0xff; | ||||||
|     *r = ar & 0xff; |     *r = ar & 0xff; | ||||||
|     uint16_t gb = HECL::SBig(gbtexels[ry*4+rx]); |     uint16_t gb = hecl::SBig(gbtexels[ry*4+rx]); | ||||||
|     *g = gb >> 8 & 0xff; |     *g = gb >> 8 & 0xff; | ||||||
|     *b = gb & 0xff; |     *b = gb & 0xff; | ||||||
| } | } | ||||||
| @ -160,7 +160,7 @@ static void DecodeIA8(png_structrp png, png_infop info, | |||||||
| static const uint8_t* DecodePalette(png_structrp png, png_infop info, | static const uint8_t* DecodePalette(png_structrp png, png_infop info, | ||||||
|                                     int numEntries, const uint8_t* data) |                                     int numEntries, const uint8_t* data) | ||||||
| { | { | ||||||
|     uint32_t format = HECL::SBig(*(uint32_t*)data); |     uint32_t format = hecl::SBig(*(uint32_t*)data); | ||||||
|     data += 8; |     data += 8; | ||||||
|     png_color cEntries[256]; |     png_color cEntries[256]; | ||||||
|     png_byte aEntries[256]; |     png_byte aEntries[256]; | ||||||
| @ -184,7 +184,7 @@ static const uint8_t* DecodePalette(png_structrp png, png_infop info, | |||||||
|         const uint16_t* data16 = (uint16_t*)data; |         const uint16_t* data16 = (uint16_t*)data; | ||||||
|         for (int e=0 ; e<numEntries ; ++e) |         for (int e=0 ; e<numEntries ; ++e) | ||||||
|         { |         { | ||||||
|             uint16_t texel = HECL::SBig(data16[e]); |             uint16_t texel = hecl::SBig(data16[e]); | ||||||
|             cEntries[e].red = Convert5To8(texel >> 11 & 0x1f); |             cEntries[e].red = Convert5To8(texel >> 11 & 0x1f); | ||||||
|             cEntries[e].green = Convert6To8(texel >> 5 & 0x3f); |             cEntries[e].green = Convert6To8(texel >> 5 & 0x3f); | ||||||
|             cEntries[e].blue = Convert5To8(texel & 0x1f); |             cEntries[e].blue = Convert5To8(texel & 0x1f); | ||||||
| @ -197,7 +197,7 @@ static const uint8_t* DecodePalette(png_structrp png, png_infop info, | |||||||
|         const uint16_t* data16 = (uint16_t*)data; |         const uint16_t* data16 = (uint16_t*)data; | ||||||
|         for (int e=0 ; e<numEntries ; ++e) |         for (int e=0 ; e<numEntries ; ++e) | ||||||
|         { |         { | ||||||
|             uint16_t texel = HECL::SBig(data16[e]); |             uint16_t texel = hecl::SBig(data16[e]); | ||||||
|             if (texel & 0x8000) |             if (texel & 0x8000) | ||||||
|             { |             { | ||||||
|                 cEntries[e].red = Convert5To8(texel >> 10 & 0x1f); |                 cEntries[e].red = Convert5To8(texel >> 10 & 0x1f); | ||||||
| @ -226,7 +226,7 @@ static const uint8_t* DecodePalette(png_structrp png, png_infop info, | |||||||
| static const uint8_t* DecodePaletteSPLT(png_structrp png, png_infop info, | static const uint8_t* DecodePaletteSPLT(png_structrp png, png_infop info, | ||||||
|                                         int numEntries, const uint8_t* data) |                                         int numEntries, const uint8_t* data) | ||||||
| { | { | ||||||
|     uint32_t format = HECL::SBig(*(uint32_t*)data); |     uint32_t format = hecl::SBig(*(uint32_t*)data); | ||||||
|     data += 8; |     data += 8; | ||||||
|     png_sPLT_entry entries[256] = {}; |     png_sPLT_entry entries[256] = {}; | ||||||
|     png_sPLT_t GXEntry = |     png_sPLT_t GXEntry = | ||||||
| @ -258,7 +258,7 @@ static const uint8_t* DecodePaletteSPLT(png_structrp png, png_infop info, | |||||||
|         const uint16_t* data16 = (uint16_t*)data; |         const uint16_t* data16 = (uint16_t*)data; | ||||||
|         for (int e=0 ; e<numEntries ; ++e) |         for (int e=0 ; e<numEntries ; ++e) | ||||||
|         { |         { | ||||||
|             uint16_t texel = HECL::SBig(data16[e]); |             uint16_t texel = hecl::SBig(data16[e]); | ||||||
|             entries[e].red = Convert5To8(texel >> 11 & 0x1f); |             entries[e].red = Convert5To8(texel >> 11 & 0x1f); | ||||||
|             entries[e].green = Convert6To8(texel >> 5 & 0x3f); |             entries[e].green = Convert6To8(texel >> 5 & 0x3f); | ||||||
|             entries[e].blue = Convert5To8(texel & 0x1f); |             entries[e].blue = Convert5To8(texel & 0x1f); | ||||||
| @ -273,7 +273,7 @@ static const uint8_t* DecodePaletteSPLT(png_structrp png, png_infop info, | |||||||
|         const uint16_t* data16 = (uint16_t*)data; |         const uint16_t* data16 = (uint16_t*)data; | ||||||
|         for (int e=0 ; e<numEntries ; ++e) |         for (int e=0 ; e<numEntries ; ++e) | ||||||
|         { |         { | ||||||
|             uint16_t texel = HECL::SBig(data16[e]); |             uint16_t texel = hecl::SBig(data16[e]); | ||||||
|             if (texel & 0x8000) |             if (texel & 0x8000) | ||||||
|             { |             { | ||||||
|                 entries[e].red = Convert5To8(texel >> 10 & 0x1f); |                 entries[e].red = Convert5To8(texel >> 10 & 0x1f); | ||||||
| @ -369,7 +369,7 @@ static void DecodeRGB565(png_structrp png, png_infop info, | |||||||
|     { |     { | ||||||
|         for (int x=0 ; x<width ; ++x) |         for (int x=0 ; x<width ; ++x) | ||||||
|         { |         { | ||||||
|             uint16_t texel = HECL::SBig(Lookup16BPP(texels, width, x, y)); |             uint16_t texel = hecl::SBig(Lookup16BPP(texels, width, x, y)); | ||||||
|             buf[x*3] = Convert5To8(texel >> 11 & 0x1f); |             buf[x*3] = Convert5To8(texel >> 11 & 0x1f); | ||||||
|             buf[x*3+1] = Convert6To8(texel >> 5 & 0x3f); |             buf[x*3+1] = Convert6To8(texel >> 5 & 0x3f); | ||||||
|             buf[x*3+2] = Convert5To8(texel & 0x1f); |             buf[x*3+2] = Convert5To8(texel & 0x1f); | ||||||
| @ -390,7 +390,7 @@ static void DecodeRGB5A3(png_structrp png, png_infop info, | |||||||
|     { |     { | ||||||
|         for (int x=0 ; x<width ; ++x) |         for (int x=0 ; x<width ; ++x) | ||||||
|         { |         { | ||||||
|             uint16_t texel = HECL::SBig(Lookup16BPP(texels, width, x, y)); |             uint16_t texel = hecl::SBig(Lookup16BPP(texels, width, x, y)); | ||||||
|             if (texel & 0x8000) |             if (texel & 0x8000) | ||||||
|             { |             { | ||||||
|                 buf[x*4] = Convert5To8(texel >> 10 & 0x1f); |                 buf[x*4] = Convert5To8(texel >> 10 & 0x1f); | ||||||
| @ -473,25 +473,25 @@ static void DecodeCMPR(png_structrp png, png_infop info, | |||||||
| 
 | 
 | ||||||
| static void PNGErr(png_structp png, png_const_charp msg) | static void PNGErr(png_structp png, png_const_charp msg) | ||||||
| { | { | ||||||
|     Log.report(LogVisor::Error, msg); |     Log.report(logvisor::Error, msg); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static void PNGWarn(png_structp png, png_const_charp msg) | static void PNGWarn(png_structp png, png_const_charp msg) | ||||||
| { | { | ||||||
|     Log.report(LogVisor::Warning, msg); |     Log.report(logvisor::Warning, msg); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| bool TXTR::Extract(PAKEntryReadStream& rs, const HECL::ProjectPath& outPath) | bool TXTR::Extract(PAKEntryReadStream& rs, const hecl::ProjectPath& outPath) | ||||||
| { | { | ||||||
|     uint32_t format = rs.readUint32Big(); |     uint32_t format = rs.readUint32Big(); | ||||||
|     uint16_t width = rs.readUint16Big(); |     uint16_t width = rs.readUint16Big(); | ||||||
|     uint16_t height = rs.readUint16Big(); |     uint16_t height = rs.readUint16Big(); | ||||||
|     uint32_t numMips = rs.readUint32Big(); |     uint32_t numMips = rs.readUint32Big(); | ||||||
| 
 | 
 | ||||||
|     FILE* fp = HECL::Fopen(outPath.getAbsolutePath().c_str(), _S("wb")); |     FILE* fp = hecl::Fopen(outPath.getAbsolutePath().c_str(), _S("wb")); | ||||||
|     if (!fp) |     if (!fp) | ||||||
|     { |     { | ||||||
|         Log.report(LogVisor::Error, |         Log.report(logvisor::Error, | ||||||
|                    _S("Unable to open '%s' for writing"), |                    _S("Unable to open '%s' for writing"), | ||||||
|                    outPath.getAbsolutePath().c_str()); |                    outPath.getAbsolutePath().c_str()); | ||||||
|         return false; |         return false; | ||||||
| @ -542,7 +542,7 @@ bool TXTR::Extract(PAKEntryReadStream& rs, const HECL::ProjectPath& outPath) | |||||||
|     return true; |     return true; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| bool TXTR::Cook(const HECL::ProjectPath& inPath, const HECL::ProjectPath& outPath) | bool TXTR::Cook(const hecl::ProjectPath& inPath, const hecl::ProjectPath& outPath) | ||||||
| { | { | ||||||
|     return false; |     return false; | ||||||
| } | } | ||||||
|  | |||||||
| @ -9,8 +9,8 @@ class PAKEntryReadStream; | |||||||
| 
 | 
 | ||||||
| struct TXTR | struct TXTR | ||||||
| { | { | ||||||
|     static bool Extract(PAKEntryReadStream& rs, const HECL::ProjectPath& outPath); |     static bool Extract(PAKEntryReadStream& rs, const hecl::ProjectPath& outPath); | ||||||
|     static bool Cook(const HECL::ProjectPath& inPath, const HECL::ProjectPath& outPath); |     static bool Cook(const hecl::ProjectPath& inPath, const hecl::ProjectPath& outPath); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -1,7 +1,7 @@ | |||||||
| #ifndef _DNAMP1_AFSM_HPP_ | #ifndef _DNAMP1_AFSM_HPP_ | ||||||
| #define _DNAMP1_AFSM_HPP_ | #define _DNAMP1_AFSM_HPP_ | ||||||
| 
 | 
 | ||||||
| #include <Athena/FileWriter.hpp> | #include <athena/FileWriter.hpp> | ||||||
| #include "../DNACommon/DNACommon.hpp" | #include "../DNACommon/DNACommon.hpp" | ||||||
| #include "DNAMP1.hpp" | #include "DNAMP1.hpp" | ||||||
| 
 | 
 | ||||||
| @ -32,7 +32,7 @@ struct AFSM : public BigYAML | |||||||
|                 String<-1> name; |                 String<-1> name; | ||||||
|                 Value<float> parameter; |                 Value<float> parameter; | ||||||
|                 Value<atUint32> targetState; |                 Value<atUint32> targetState; | ||||||
|                 void read(Athena::io::IStreamReader& __dna_reader) |                 void read(athena::io::IStreamReader& __dna_reader) | ||||||
|                 { |                 { | ||||||
|                     /* name */ |                     /* name */ | ||||||
|                     name = __dna_reader.readString(-1); |                     name = __dna_reader.readString(-1); | ||||||
| @ -45,7 +45,7 @@ struct AFSM : public BigYAML | |||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
|                 void write(Athena::io::IStreamWriter& __dna_writer) const |                 void write(athena::io::IStreamWriter& __dna_writer) const | ||||||
|                 { |                 { | ||||||
|                     /* name */ |                     /* name */ | ||||||
|                     __dna_writer.writeString(name, -1); |                     __dna_writer.writeString(name, -1); | ||||||
| @ -58,7 +58,7 @@ struct AFSM : public BigYAML | |||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
|                 void read(Athena::io::YAMLDocReader& __dna_docin) |                 void read(athena::io::YAMLDocReader& __dna_docin) | ||||||
|                 { |                 { | ||||||
|                     /* name */ |                     /* name */ | ||||||
|                     name = __dna_docin.readString("name"); |                     name = __dna_docin.readString("name"); | ||||||
| @ -71,7 +71,7 @@ struct AFSM : public BigYAML | |||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
|                 void write(Athena::io::YAMLDocWriter& __dna_docout) const |                 void write(athena::io::YAMLDocWriter& __dna_docout) const | ||||||
|                 { |                 { | ||||||
|                     /* name */ |                     /* name */ | ||||||
|                     __dna_docout.writeString("name", name); |                     __dna_docout.writeString("name", name); | ||||||
| @ -86,7 +86,7 @@ struct AFSM : public BigYAML | |||||||
| 
 | 
 | ||||||
|                 static const char* DNAType() |                 static const char* DNAType() | ||||||
|                 { |                 { | ||||||
|                     return "Retro::DNAMP1::AFSM::Transition::Trigger"; |                     return "urde::DNAMP1::AFSM::Transition::Trigger"; | ||||||
|                 } |                 } | ||||||
| 
 | 
 | ||||||
|                 size_t binarySize(size_t __isz) const |                 size_t binarySize(size_t __isz) const | ||||||
| @ -98,21 +98,21 @@ struct AFSM : public BigYAML | |||||||
| 
 | 
 | ||||||
|             Vector<Trigger, DNA_COUNT(triggerCount)> triggers; |             Vector<Trigger, DNA_COUNT(triggerCount)> triggers; | ||||||
| 
 | 
 | ||||||
|             void read(Athena::io::IStreamReader& __dna_reader) |             void read(athena::io::IStreamReader& __dna_reader) | ||||||
|             { |             { | ||||||
|                 /* triggerCount */ |                 /* triggerCount */ | ||||||
|                 triggerCount = __dna_reader.readUint32Big(); |                 triggerCount = __dna_reader.readUint32Big(); | ||||||
|                 int i = 0; |                 int i = 0; | ||||||
|                 /* triggers */ |                 /* triggers */ | ||||||
|                 __dna_reader.enumerate<Trigger>(triggers, triggerCount, |                 __dna_reader.enumerate<Trigger>(triggers, triggerCount, | ||||||
|                                                 [&](Athena::io::IStreamReader& in, Trigger& tr){ |                                                 [&](athena::io::IStreamReader& in, Trigger& tr){ | ||||||
|                     tr.first = i == 0; |                     tr.first = i == 0; | ||||||
|                     tr.read(in); |                     tr.read(in); | ||||||
|                     i++; |                     i++; | ||||||
|                 }); |                 }); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             void write(Athena::io::IStreamWriter& __dna_writer) const |             void write(athena::io::IStreamWriter& __dna_writer) const | ||||||
|             { |             { | ||||||
|                 /* triggerCount */ |                 /* triggerCount */ | ||||||
|                 __dna_writer.writeInt32Big(triggerCount); |                 __dna_writer.writeInt32Big(triggerCount); | ||||||
| @ -120,31 +120,27 @@ struct AFSM : public BigYAML | |||||||
|                 __dna_writer.enumerate(triggers); |                 __dna_writer.enumerate(triggers); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             void read(Athena::io::YAMLDocReader& __dna_docin) |             void read(athena::io::YAMLDocReader& __dna_docin) | ||||||
|             { |             { | ||||||
|                 /* triggerCount */ |  | ||||||
|                 triggerCount = __dna_docin.readUint32("triggerCount"); |  | ||||||
|                 int i = 0; |                 int i = 0; | ||||||
|                 /* triggers */ |                 /* triggers */ | ||||||
|                 __dna_docin.enumerate<Trigger>("triggers", triggers, triggerCount, |                 triggerCount = __dna_docin.enumerate<Trigger>("triggers", triggers, | ||||||
|                                                [&](Athena::io::YAMLDocReader& in, Trigger& tr){ |                 [&](athena::io::YAMLDocReader& in, Trigger& tr){ | ||||||
|                     tr.first = i == 0; |                     tr.first = i == 0; | ||||||
|                     tr.read(in); |                     tr.read(in); | ||||||
|                     i++; |                     i++; | ||||||
|                 }); |                 }); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             void write(Athena::io::YAMLDocWriter& __dna_docout) const |             void write(athena::io::YAMLDocWriter& __dna_docout) const | ||||||
|             { |             { | ||||||
|                 /* triggerCount */ |  | ||||||
|                 __dna_docout.writeUint32("triggerCount", triggerCount); |  | ||||||
|                 /* triggers */ |                 /* triggers */ | ||||||
|                 __dna_docout.enumerate("triggers", triggers); |                 __dna_docout.enumerate("triggers", triggers); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             static const char* DNAType() |             static const char* DNAType() | ||||||
|             { |             { | ||||||
|                 return "Retro::DNAMP1::AFSM::Transition"; |                 return "urde::DNAMP1::AFSM::Transition"; | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             size_t binarySize(size_t __isz) const |             size_t binarySize(size_t __isz) const | ||||||
| @ -159,11 +155,11 @@ struct AFSM : public BigYAML | |||||||
| 
 | 
 | ||||||
|     Vector<State, DNA_COUNT(stateCount)> states; |     Vector<State, DNA_COUNT(stateCount)> states; | ||||||
| 
 | 
 | ||||||
|     static bool Extract(PAKEntryReadStream& rs, const HECL::ProjectPath& outPath) |     static bool Extract(PAKEntryReadStream& rs, const hecl::ProjectPath& outPath) | ||||||
|     { |     { | ||||||
|         AFSM afsm; |         AFSM afsm; | ||||||
|         afsm.read(rs); |         afsm.read(rs); | ||||||
|         FILE* fp = HECL::Fopen(outPath.getAbsolutePath().c_str(), _S("wb")); |         FILE* fp = hecl::Fopen(outPath.getAbsolutePath().c_str(), _S("wb")); | ||||||
|         afsm.toYAMLFile(fp); |         afsm.toYAMLFile(fp); | ||||||
|         fclose(fp); |         fclose(fp); | ||||||
|         return true; |         return true; | ||||||
|  | |||||||
| @ -5,7 +5,7 @@ namespace DataSpec | |||||||
| namespace DNAMP1 | namespace DNAMP1 | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| void ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::ParmInfo::read(Athena::io::IStreamReader& reader) | void ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::ParmInfo::read(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     parmType = reader.readUint32Big(); |     parmType = reader.readUint32Big(); | ||||||
|     unk1 = reader.readUint32Big(); |     unk1 = reader.readUint32Big(); | ||||||
| @ -32,7 +32,7 @@ void ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::ParmInfo::read(A | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::ParmInfo::write(Athena::io::IStreamWriter& writer) const | void ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::ParmInfo::write(athena::io::IStreamWriter& writer) const | ||||||
| { | { | ||||||
|     writer.writeUint32Big(parmType); |     writer.writeUint32Big(parmType); | ||||||
|     writer.writeUint32Big(unk1); |     writer.writeUint32Big(unk1); | ||||||
| @ -77,12 +77,13 @@ size_t ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::ParmInfo::bina | |||||||
|     return __isz; |     return __isz; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::ParmInfo::read(Athena::io::YAMLDocReader& reader) | void ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::ParmInfo::read(athena::io::YAMLDocReader& reader) | ||||||
| { | { | ||||||
|     parmType = reader.readUint32("parmType"); |     parmType = reader.readUint32("parmType"); | ||||||
|     unk1 = reader.readUint32("unk1"); |     unk1 = reader.readUint32("unk1"); | ||||||
|     unk2 = reader.readFloat("unk2"); |     unk2 = reader.readFloat("unk2"); | ||||||
|     reader.enterSubVector("parmVals"); |     size_t parmCount; | ||||||
|  |     reader.enterSubVector("parmVals", parmCount); | ||||||
|     switch (DataType(parmType)) |     switch (DataType(parmType)) | ||||||
|     { |     { | ||||||
|     case DataType::Int32: |     case DataType::Int32: | ||||||
| @ -107,7 +108,7 @@ void ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::ParmInfo::read(A | |||||||
|     reader.leaveSubVector(); |     reader.leaveSubVector(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::ParmInfo::write(Athena::io::YAMLDocWriter& writer) const | void ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::ParmInfo::write(athena::io::YAMLDocWriter& writer) const | ||||||
| { | { | ||||||
|     writer.writeUint32("parmType", parmType); |     writer.writeUint32("parmType", parmType); | ||||||
|     writer.writeUint32("unk1", unk1); |     writer.writeUint32("unk1", unk1); | ||||||
| @ -138,10 +139,10 @@ void ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::ParmInfo::write( | |||||||
| 
 | 
 | ||||||
| const char* ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::ParmInfo::DNAType() | const char* ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::ParmInfo::DNAType() | ||||||
| { | { | ||||||
|     return "Retro::DNAMP1::ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::ParmInfo"; |     return "urde::DNAMP1::ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::ParmInfo"; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::read(Athena::io::IStreamReader& reader) | void ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::read(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     id = reader.readUint32Big(); |     id = reader.readUint32Big(); | ||||||
|     atUint32 parmInfoCount = reader.readUint32Big(); |     atUint32 parmInfoCount = reader.readUint32Big(); | ||||||
| @ -152,7 +153,7 @@ void ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::read(Athena::io: | |||||||
|     animInfos.clear(); |     animInfos.clear(); | ||||||
|     animInfos.reserve(animInfoCount); |     animInfos.reserve(animInfoCount); | ||||||
|     reader.enumerate<AnimInfo>(animInfos, animInfoCount, |     reader.enumerate<AnimInfo>(animInfos, animInfoCount, | ||||||
|     [this, parmInfoCount](Athena::io::IStreamReader& reader, AnimInfo& ai) |     [this, parmInfoCount](athena::io::IStreamReader& reader, AnimInfo& ai) | ||||||
|     { |     { | ||||||
|         ai.id = reader.readUint32Big(); |         ai.id = reader.readUint32Big(); | ||||||
|         ai.parmVals.reserve(parmInfoCount); |         ai.parmVals.reserve(parmInfoCount); | ||||||
| @ -179,7 +180,7 @@ void ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::read(Athena::io: | |||||||
|     }); |     }); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::write(Athena::io::IStreamWriter& writer) const | void ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::write(athena::io::IStreamWriter& writer) const | ||||||
| { | { | ||||||
|     writer.writeUint32Big(id); |     writer.writeUint32Big(id); | ||||||
|     writer.writeUint32Big(parmInfos.size()); |     writer.writeUint32Big(parmInfos.size()); | ||||||
| @ -244,20 +245,19 @@ size_t ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::binarySize(siz | |||||||
|     return __isz; |     return __isz; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::read(Athena::io::YAMLDocReader& reader) | void ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::read(athena::io::YAMLDocReader& reader) | ||||||
| { | { | ||||||
|     id = reader.readUint32("id"); |     id = reader.readUint32("id"); | ||||||
|     atUint32 parmInfoCount = reader.readUint32("parmInfoCount"); |  | ||||||
|     atUint32 animInfoCount = reader.readUint32("animInfoCount"); |  | ||||||
| 
 | 
 | ||||||
|     reader.enumerate("parmInfos", parmInfos, parmInfoCount); |     atUint32 parmInfoCount = reader.enumerate("parmInfos", parmInfos); | ||||||
| 
 | 
 | ||||||
|     reader.enumerate<AnimInfo>("animInfos", animInfos, animInfoCount, |     reader.enumerate<AnimInfo>("animInfos", animInfos, | ||||||
|     [this, parmInfoCount](Athena::io::YAMLDocReader& reader, AnimInfo& ai) |     [this, parmInfoCount](athena::io::YAMLDocReader& reader, AnimInfo& ai) | ||||||
|     { |     { | ||||||
|         ai.id = reader.readUint32("id"); |         ai.id = reader.readUint32("id"); | ||||||
|         ai.parmVals.reserve(parmInfoCount); |         ai.parmVals.reserve(parmInfoCount); | ||||||
|         reader.enterSubVector("parmVals"); |         size_t parmValCount; | ||||||
|  |         reader.enterSubVector("parmVals", parmValCount); | ||||||
|         for (const ParmInfo& pi : parmInfos) |         for (const ParmInfo& pi : parmInfos) | ||||||
|         { |         { | ||||||
|             switch (ParmInfo::DataType(pi.parmType)) |             switch (ParmInfo::DataType(pi.parmType)) | ||||||
| @ -282,16 +282,14 @@ void ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::read(Athena::io: | |||||||
|     }); |     }); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::write(Athena::io::YAMLDocWriter& writer) const | void ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::write(athena::io::YAMLDocWriter& writer) const | ||||||
| { | { | ||||||
|     writer.writeUint32("id", id); |     writer.writeUint32("id", id); | ||||||
|     writer.writeUint32("parmInfoCount", parmInfos.size()); |  | ||||||
|     writer.writeUint32("animInfoCount", animInfos.size()); |  | ||||||
| 
 | 
 | ||||||
|     writer.enumerate("parmInfos", parmInfos); |     writer.enumerate("parmInfos", parmInfos); | ||||||
| 
 | 
 | ||||||
|     writer.enumerate<AnimInfo>("animInfos", animInfos, |     writer.enumerate<AnimInfo>("animInfos", animInfos, | ||||||
|     [this](Athena::io::YAMLDocWriter& writer, const AnimInfo& ai) |     [this](athena::io::YAMLDocWriter& writer, const AnimInfo& ai) | ||||||
|     { |     { | ||||||
|         writer.writeUint32("id", ai.id); |         writer.writeUint32("id", ai.id); | ||||||
|         auto it = ai.parmVals.begin(); |         auto it = ai.parmVals.begin(); | ||||||
| @ -325,10 +323,10 @@ void ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::write(Athena::io | |||||||
| 
 | 
 | ||||||
| const char* ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::DNAType() | const char* ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState::DNAType() | ||||||
| { | { | ||||||
|     return "Retro::DNAMP1::ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState"; |     return "urde::DNAMP1::ANCS::CharacterSet::CharacterInfo::PASDatabase::AnimState"; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::CharacterSet::CharacterInfo::read(Athena::io::IStreamReader& reader) | void ANCS::CharacterSet::CharacterInfo::read(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     idx = reader.readUint32Big(); |     idx = reader.readUint32Big(); | ||||||
|     atUint16 sectionCount = reader.readUint16Big(); |     atUint16 sectionCount = reader.readUint16Big(); | ||||||
| @ -388,7 +386,7 @@ void ANCS::CharacterSet::CharacterInfo::read(Athena::io::IStreamReader& reader) | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::CharacterSet::CharacterInfo::write(Athena::io::IStreamWriter& writer) const | void ANCS::CharacterSet::CharacterInfo::write(athena::io::IStreamWriter& writer) const | ||||||
| { | { | ||||||
|     writer.writeUint32Big(idx); |     writer.writeUint32Big(idx); | ||||||
| 
 | 
 | ||||||
| @ -524,7 +522,7 @@ size_t ANCS::CharacterSet::CharacterInfo::binarySize(size_t __isz) const | |||||||
|     return __isz; |     return __isz; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::CharacterSet::CharacterInfo::read(Athena::io::YAMLDocReader& reader) | void ANCS::CharacterSet::CharacterInfo::read(athena::io::YAMLDocReader& reader) | ||||||
| { | { | ||||||
|     idx = reader.readUint32("idx"); |     idx = reader.readUint32("idx"); | ||||||
|     atUint16 sectionCount = reader.readUint16("sectionCount"); |     atUint16 sectionCount = reader.readUint16("sectionCount"); | ||||||
| @ -533,25 +531,20 @@ void ANCS::CharacterSet::CharacterInfo::read(Athena::io::YAMLDocReader& reader) | |||||||
|     reader.enumerate("cskr", cskr); |     reader.enumerate("cskr", cskr); | ||||||
|     reader.enumerate("cinf", cinf); |     reader.enumerate("cinf", cinf); | ||||||
| 
 | 
 | ||||||
|     atUint32 animationCount = reader.readUint32("animationCount"); |     reader.enumerate("animations", animations); | ||||||
|     reader.enumerate("animations", animations, animationCount); |  | ||||||
| 
 | 
 | ||||||
|     reader.enumerate("pasDatabase", pasDatabase); |     reader.enumerate("pasDatabase", pasDatabase); | ||||||
| 
 | 
 | ||||||
|     atUint32 partCount = reader.readUint32("partCount"); |     reader.enumerate("part", partResData.part); | ||||||
|     reader.enumerate("part", partResData.part, partCount); |  | ||||||
| 
 | 
 | ||||||
|     atUint32 swhcCount = reader.readUint32("swhcCount"); |     reader.enumerate("swhc", partResData.swhc); | ||||||
|     reader.enumerate("swhc", partResData.swhc, swhcCount); |  | ||||||
| 
 | 
 | ||||||
|     atUint32 unkCount = reader.readUint32("unkCount"); |     reader.enumerate("unk", partResData.unk); | ||||||
|     reader.enumerate("unk", partResData.unk, unkCount); |  | ||||||
| 
 | 
 | ||||||
|     partResData.elsc.clear(); |     partResData.elsc.clear(); | ||||||
|     if (sectionCount > 5) |     if (sectionCount > 5) | ||||||
|     { |     { | ||||||
|         atUint32 elscCount = reader.readUint32("elscCount"); |         reader.enumerate("elsc", partResData.elsc); | ||||||
|         reader.enumerate("elsc", partResData.elsc, elscCount); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     unk1 = reader.readUint32("unk1"); |     unk1 = reader.readUint32("unk1"); | ||||||
| @ -559,15 +552,13 @@ void ANCS::CharacterSet::CharacterInfo::read(Athena::io::YAMLDocReader& reader) | |||||||
|     animAABBs.clear(); |     animAABBs.clear(); | ||||||
|     if (sectionCount > 1) |     if (sectionCount > 1) | ||||||
|     { |     { | ||||||
|         atUint32 aabbCount = reader.readUint32("animAABBCount"); |         reader.enumerate("part", animAABBs); | ||||||
|         reader.enumerate("part", animAABBs, aabbCount); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     effects.clear(); |     effects.clear(); | ||||||
|     if (sectionCount > 2) |     if (sectionCount > 2) | ||||||
|     { |     { | ||||||
|         atUint32 effectCount = reader.readUint32("effectCount"); |         reader.enumerate("effects", effects); | ||||||
|         reader.enumerate("effects", effects, effectCount); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (sectionCount > 3) |     if (sectionCount > 3) | ||||||
| @ -579,12 +570,11 @@ void ANCS::CharacterSet::CharacterInfo::read(Athena::io::YAMLDocReader& reader) | |||||||
|     animIdxs.clear(); |     animIdxs.clear(); | ||||||
|     if (sectionCount > 4) |     if (sectionCount > 4) | ||||||
|     { |     { | ||||||
|         atUint32 animIdxCount = reader.readUint32("animIdxCount"); |         reader.enumerate("animIdxs", animIdxs); | ||||||
|         reader.enumerate("animIdxs", animIdxs, animIdxCount); |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::CharacterSet::CharacterInfo::write(Athena::io::YAMLDocWriter& writer) const | void ANCS::CharacterSet::CharacterInfo::write(athena::io::YAMLDocWriter& writer) const | ||||||
| { | { | ||||||
|     writer.writeUint32("idx", idx); |     writer.writeUint32("idx", idx); | ||||||
| 
 | 
 | ||||||
| @ -608,23 +598,18 @@ void ANCS::CharacterSet::CharacterInfo::write(Athena::io::YAMLDocWriter& writer) | |||||||
|     writer.enumerate("cskr", cskr); |     writer.enumerate("cskr", cskr); | ||||||
|     writer.enumerate("cinf", cinf); |     writer.enumerate("cinf", cinf); | ||||||
| 
 | 
 | ||||||
|     writer.writeUint32("animationCount", animations.size()); |  | ||||||
|     writer.enumerate("animations", animations); |     writer.enumerate("animations", animations); | ||||||
| 
 | 
 | ||||||
|     writer.enumerate("pasDatabase", pasDatabase); |     writer.enumerate("pasDatabase", pasDatabase); | ||||||
| 
 | 
 | ||||||
|     writer.writeUint32("partCount", partResData.part.size()); |  | ||||||
|     writer.enumerate("part", partResData.part); |     writer.enumerate("part", partResData.part); | ||||||
| 
 | 
 | ||||||
|     writer.writeUint32("swhcCount", partResData.swhc.size()); |  | ||||||
|     writer.enumerate("swhc", partResData.swhc); |     writer.enumerate("swhc", partResData.swhc); | ||||||
| 
 | 
 | ||||||
|     writer.writeUint32("unkCount", partResData.unk.size()); |  | ||||||
|     writer.enumerate("unk", partResData.unk); |     writer.enumerate("unk", partResData.unk); | ||||||
| 
 | 
 | ||||||
|     if (sectionCount > 5) |     if (sectionCount > 5) | ||||||
|     { |     { | ||||||
|         writer.writeUint32("elscCount", partResData.elsc.size()); |  | ||||||
|         writer.enumerate("elsc", partResData.elsc); |         writer.enumerate("elsc", partResData.elsc); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -632,13 +617,11 @@ void ANCS::CharacterSet::CharacterInfo::write(Athena::io::YAMLDocWriter& writer) | |||||||
| 
 | 
 | ||||||
|     if (sectionCount > 1) |     if (sectionCount > 1) | ||||||
|     { |     { | ||||||
|         writer.writeUint32("animAABBCount", animAABBs.size()); |  | ||||||
|         writer.enumerate("animAABBs", animAABBs); |         writer.enumerate("animAABBs", animAABBs); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (sectionCount > 2) |     if (sectionCount > 2) | ||||||
|     { |     { | ||||||
|         writer.writeUint32("effectCount", effects.size()); |  | ||||||
|         writer.enumerate("effects", effects); |         writer.enumerate("effects", effects); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -650,17 +633,16 @@ void ANCS::CharacterSet::CharacterInfo::write(Athena::io::YAMLDocWriter& writer) | |||||||
| 
 | 
 | ||||||
|     if (sectionCount > 4) |     if (sectionCount > 4) | ||||||
|     { |     { | ||||||
|         writer.writeUint32("animIdxCount", animIdxs.size()); |  | ||||||
|         writer.enumerate("animIdxs", animIdxs); |         writer.enumerate("animIdxs", animIdxs); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| const char* ANCS::CharacterSet::CharacterInfo::DNAType() | const char* ANCS::CharacterSet::CharacterInfo::DNAType() | ||||||
| { | { | ||||||
|     return "Retro::DNAMP1::ANCS::CharacterSet::CharacterInfo"; |     return "urde::DNAMP1::ANCS::CharacterSet::CharacterInfo"; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::AnimationSet::MetaAnimFactory::read(Athena::io::IStreamReader& reader) | void ANCS::AnimationSet::MetaAnimFactory::read(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     IMetaAnim::Type type(IMetaAnim::Type(reader.readUint32Big())); |     IMetaAnim::Type type(IMetaAnim::Type(reader.readUint32Big())); | ||||||
|     switch (type) |     switch (type) | ||||||
| @ -691,7 +673,7 @@ void ANCS::AnimationSet::MetaAnimFactory::read(Athena::io::IStreamReader& reader | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::AnimationSet::MetaAnimFactory::write(Athena::io::IStreamWriter& writer) const | void ANCS::AnimationSet::MetaAnimFactory::write(athena::io::IStreamWriter& writer) const | ||||||
| { | { | ||||||
|     if (!m_anim) |     if (!m_anim) | ||||||
|         return; |         return; | ||||||
| @ -706,7 +688,7 @@ size_t ANCS::AnimationSet::MetaAnimFactory::binarySize(size_t __isz) const | |||||||
|     return m_anim->binarySize(__isz + 4); |     return m_anim->binarySize(__isz + 4); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::AnimationSet::MetaAnimFactory::read(Athena::io::YAMLDocReader& reader) | void ANCS::AnimationSet::MetaAnimFactory::read(athena::io::YAMLDocReader& reader) | ||||||
| { | { | ||||||
|     std::string type = reader.readString("type"); |     std::string type = reader.readString("type"); | ||||||
|     std::transform(type.begin(), type.end(), type.begin(), tolower); |     std::transform(type.begin(), type.end(), type.begin(), tolower); | ||||||
| @ -742,7 +724,7 @@ void ANCS::AnimationSet::MetaAnimFactory::read(Athena::io::YAMLDocReader& reader | |||||||
| 
 | 
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::AnimationSet::MetaAnimFactory::write(Athena::io::YAMLDocWriter& writer) const | void ANCS::AnimationSet::MetaAnimFactory::write(athena::io::YAMLDocWriter& writer) const | ||||||
| { | { | ||||||
|     if (!m_anim) |     if (!m_anim) | ||||||
|         return; |         return; | ||||||
| @ -752,10 +734,10 @@ void ANCS::AnimationSet::MetaAnimFactory::write(Athena::io::YAMLDocWriter& write | |||||||
| 
 | 
 | ||||||
| const char* ANCS::AnimationSet::MetaAnimFactory::DNAType() | const char* ANCS::AnimationSet::MetaAnimFactory::DNAType() | ||||||
| { | { | ||||||
|     return "Retro::DNAMP1::ANCS::AnimationSet::MetaAnimFactory"; |     return "urde::DNAMP1::ANCS::AnimationSet::MetaAnimFactory"; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::AnimationSet::MetaTransFactory::read(Athena::io::IStreamReader& reader) | void ANCS::AnimationSet::MetaTransFactory::read(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     IMetaTrans::Type type(IMetaTrans::Type(reader.readUint32Big())); |     IMetaTrans::Type type(IMetaTrans::Type(reader.readUint32Big())); | ||||||
|     switch (type) |     switch (type) | ||||||
| @ -779,7 +761,7 @@ void ANCS::AnimationSet::MetaTransFactory::read(Athena::io::IStreamReader& reade | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::AnimationSet::MetaTransFactory::write(Athena::io::IStreamWriter& writer) const | void ANCS::AnimationSet::MetaTransFactory::write(athena::io::IStreamWriter& writer) const | ||||||
| { | { | ||||||
|     if (!m_trans) |     if (!m_trans) | ||||||
|     { |     { | ||||||
| @ -797,7 +779,7 @@ size_t ANCS::AnimationSet::MetaTransFactory::binarySize(size_t __isz) const | |||||||
|     return m_trans->binarySize(__isz + 4); |     return m_trans->binarySize(__isz + 4); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::AnimationSet::MetaTransFactory::read(Athena::io::YAMLDocReader& reader) | void ANCS::AnimationSet::MetaTransFactory::read(athena::io::YAMLDocReader& reader) | ||||||
| { | { | ||||||
|     std::string type = reader.readString("type"); |     std::string type = reader.readString("type"); | ||||||
|     std::transform(type.begin(), type.end(), type.begin(), tolower); |     std::transform(type.begin(), type.end(), type.begin(), tolower); | ||||||
| @ -823,7 +805,7 @@ void ANCS::AnimationSet::MetaTransFactory::read(Athena::io::YAMLDocReader& reade | |||||||
| 
 | 
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::AnimationSet::MetaTransFactory::write(Athena::io::YAMLDocWriter& writer) const | void ANCS::AnimationSet::MetaTransFactory::write(athena::io::YAMLDocWriter& writer) const | ||||||
| { | { | ||||||
|     if (!m_trans) |     if (!m_trans) | ||||||
|     { |     { | ||||||
| @ -836,10 +818,10 @@ void ANCS::AnimationSet::MetaTransFactory::write(Athena::io::YAMLDocWriter& writ | |||||||
| 
 | 
 | ||||||
| const char* ANCS::AnimationSet::MetaTransFactory::DNAType() | const char* ANCS::AnimationSet::MetaTransFactory::DNAType() | ||||||
| { | { | ||||||
|     return "Retro::DNAMP1::ANCS::AnimationSet::MetaTransFactory"; |     return "urde::DNAMP1::ANCS::AnimationSet::MetaTransFactory"; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::AnimationSet::read(Athena::io::IStreamReader& reader) | void ANCS::AnimationSet::read(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     atUint16 sectionCount = reader.readUint16Big(); |     atUint16 sectionCount = reader.readUint16Big(); | ||||||
| 
 | 
 | ||||||
| @ -874,7 +856,7 @@ void ANCS::AnimationSet::read(Athena::io::IStreamReader& reader) | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::AnimationSet::write(Athena::io::IStreamWriter& writer) const | void ANCS::AnimationSet::write(athena::io::IStreamWriter& writer) const | ||||||
| { | { | ||||||
|     atUint16 sectionCount; |     atUint16 sectionCount; | ||||||
|     if (animResources.size()) |     if (animResources.size()) | ||||||
| @ -957,22 +939,19 @@ size_t ANCS::AnimationSet::binarySize(size_t __isz) const | |||||||
|     return __isz; |     return __isz; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::AnimationSet::read(Athena::io::YAMLDocReader& reader) | void ANCS::AnimationSet::read(athena::io::YAMLDocReader& reader) | ||||||
| { | { | ||||||
|     atUint16 sectionCount = reader.readUint16("sectionCount"); |     atUint16 sectionCount = reader.readUint16("sectionCount"); | ||||||
| 
 | 
 | ||||||
|     atUint32 animationCount = reader.readUint32("animationCount"); |     reader.enumerate("animations", animations); | ||||||
|     reader.enumerate("animations", animations, animationCount); |  | ||||||
| 
 | 
 | ||||||
|     atUint32 transitionCount = reader.readUint32("transitionCount"); |     reader.enumerate("transitions", transitions); | ||||||
|     reader.enumerate("transitions", transitions, transitionCount); |  | ||||||
|     reader.enumerate("defaultTransition", defaultTransition); |     reader.enumerate("defaultTransition", defaultTransition); | ||||||
| 
 | 
 | ||||||
|     additiveAnims.clear(); |     additiveAnims.clear(); | ||||||
|     if (sectionCount > 1) |     if (sectionCount > 1) | ||||||
|     { |     { | ||||||
|         atUint32 additiveAnimCount = reader.readUint32("additiveAnimCount"); |         reader.enumerate("additiveAnims", additiveAnims); | ||||||
|         reader.enumerate("additiveAnims", additiveAnims, additiveAnimCount); |  | ||||||
|         floatA = reader.readFloat("floatA"); |         floatA = reader.readFloat("floatA"); | ||||||
|         floatB = reader.readFloat("floatB"); |         floatB = reader.readFloat("floatB"); | ||||||
|     } |     } | ||||||
| @ -980,19 +959,17 @@ void ANCS::AnimationSet::read(Athena::io::YAMLDocReader& reader) | |||||||
|     halfTransitions.clear(); |     halfTransitions.clear(); | ||||||
|     if (sectionCount > 2) |     if (sectionCount > 2) | ||||||
|     { |     { | ||||||
|         atUint32 halfTransitionCount = reader.readUint32("halfTransitionCount"); |         reader.enumerate("halfTransitions", halfTransitions); | ||||||
|         reader.enumerate("halfTransitions", halfTransitions, halfTransitionCount); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     animResources.clear(); |     animResources.clear(); | ||||||
|     if (sectionCount > 3) |     if (sectionCount > 3) | ||||||
|     { |     { | ||||||
|         atUint32 animResourcesCount = reader.readUint32("animResourcesCount"); |         reader.enumerate("animResources", animResources); | ||||||
|         reader.enumerate("animResources", animResources, animResourcesCount); |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::AnimationSet::write(Athena::io::YAMLDocWriter& writer) const | void ANCS::AnimationSet::write(athena::io::YAMLDocWriter& writer) const | ||||||
| { | { | ||||||
|     atUint16 sectionCount; |     atUint16 sectionCount; | ||||||
|     if (animResources.size()) |     if (animResources.size()) | ||||||
| @ -1006,16 +983,13 @@ void ANCS::AnimationSet::write(Athena::io::YAMLDocWriter& writer) const | |||||||
| 
 | 
 | ||||||
|     writer.writeUint16("sectionCount", sectionCount); |     writer.writeUint16("sectionCount", sectionCount); | ||||||
| 
 | 
 | ||||||
|     writer.writeUint32("animationCount", animations.size()); |  | ||||||
|     writer.enumerate("animations", animations); |     writer.enumerate("animations", animations); | ||||||
| 
 | 
 | ||||||
|     writer.writeUint32("transitionCount", transitions.size()); |  | ||||||
|     writer.enumerate("transitions", transitions); |     writer.enumerate("transitions", transitions); | ||||||
|     writer.enumerate("defaultTransition", defaultTransition); |     writer.enumerate("defaultTransition", defaultTransition); | ||||||
| 
 | 
 | ||||||
|     if (sectionCount > 1) |     if (sectionCount > 1) | ||||||
|     { |     { | ||||||
|         writer.writeUint32("additiveAnimCount", additiveAnims.size()); |  | ||||||
|         writer.enumerate("additiveAnims", additiveAnims); |         writer.enumerate("additiveAnims", additiveAnims); | ||||||
|         writer.writeFloat("floatA", floatA); |         writer.writeFloat("floatA", floatA); | ||||||
|         writer.writeFloat("floatB", floatB); |         writer.writeFloat("floatB", floatB); | ||||||
| @ -1023,20 +997,18 @@ void ANCS::AnimationSet::write(Athena::io::YAMLDocWriter& writer) const | |||||||
| 
 | 
 | ||||||
|     if (sectionCount > 2) |     if (sectionCount > 2) | ||||||
|     { |     { | ||||||
|         writer.writeUint32("halfTransitionCount", halfTransitions.size()); |  | ||||||
|         writer.enumerate("halfTransitions", halfTransitions); |         writer.enumerate("halfTransitions", halfTransitions); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (sectionCount > 3) |     if (sectionCount > 3) | ||||||
|     { |     { | ||||||
|         writer.writeUint32("animResourcesCount", animResources.size()); |  | ||||||
|         writer.enumerate("animResources", animResources); |         writer.enumerate("animResources", animResources); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| const char* ANCS::AnimationSet::DNAType() | const char* ANCS::AnimationSet::DNAType() | ||||||
| { | { | ||||||
|     return "Retro::DNAMP1::ANCS::AnimationSet"; |     return "urde::DNAMP1::ANCS::AnimationSet"; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -9,7 +9,7 @@ | |||||||
| #include "CINF.hpp" | #include "CINF.hpp" | ||||||
| #include "CSKR.hpp" | #include "CSKR.hpp" | ||||||
| #include "ANIM.hpp" | #include "ANIM.hpp" | ||||||
| #include "Athena/FileReader.hpp" | #include "athena/FileReader.hpp" | ||||||
| 
 | 
 | ||||||
| namespace DataSpec | namespace DataSpec | ||||||
| { | { | ||||||
| @ -390,34 +390,34 @@ struct ANCS : BigYAML | |||||||
| 
 | 
 | ||||||
|     static bool Extract(const SpecBase& dataSpec, |     static bool Extract(const SpecBase& dataSpec, | ||||||
|                         PAKEntryReadStream& rs, |                         PAKEntryReadStream& rs, | ||||||
|                         const HECL::ProjectPath& outPath, |                         const hecl::ProjectPath& outPath, | ||||||
|                         PAKRouter<PAKBridge>& pakRouter, |                         PAKRouter<PAKBridge>& pakRouter, | ||||||
|                         const PAK::Entry& entry, |                         const PAK::Entry& entry, | ||||||
|                         bool force, |                         bool force, | ||||||
|                         std::function<void(const HECL::SystemChar*)> fileChanged) |                         std::function<void(const hecl::SystemChar*)> fileChanged) | ||||||
|     { |     { | ||||||
|         HECL::ProjectPath yamlPath = outPath.getWithExtension(_S(".yaml")); |         hecl::ProjectPath yamlPath = outPath.getWithExtension(_S(".yaml")); | ||||||
|         HECL::ProjectPath::Type yamlType = yamlPath.getPathType(); |         hecl::ProjectPath::Type yamlType = yamlPath.getPathType(); | ||||||
|         HECL::ProjectPath blendPath = outPath.getWithExtension(_S(".blend")); |         hecl::ProjectPath blendPath = outPath.getWithExtension(_S(".blend")); | ||||||
|         HECL::ProjectPath::Type blendType = blendPath.getPathType(); |         hecl::ProjectPath::Type blendType = blendPath.getPathType(); | ||||||
| 
 | 
 | ||||||
|         if (force || |         if (force || | ||||||
|             yamlType == HECL::ProjectPath::Type::None || |             yamlType == hecl::ProjectPath::Type::None || | ||||||
|             blendType == HECL::ProjectPath::Type::None) |             blendType == hecl::ProjectPath::Type::None) | ||||||
|         { |         { | ||||||
|             ANCS ancs; |             ANCS ancs; | ||||||
|             ancs.read(rs); |             ancs.read(rs); | ||||||
| 
 | 
 | ||||||
|             if (force || yamlType == HECL::ProjectPath::Type::None) |             if (force || yamlType == hecl::ProjectPath::Type::None) | ||||||
|             { |             { | ||||||
|                 FILE* fp = HECL::Fopen(yamlPath.getAbsolutePath().c_str(), _S("wb")); |                 FILE* fp = hecl::Fopen(yamlPath.getAbsolutePath().c_str(), _S("wb")); | ||||||
|                 ancs.toYAMLFile(fp); |                 ancs.toYAMLFile(fp); | ||||||
|                 fclose(fp); |                 fclose(fp); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if (force || blendType == HECL::ProjectPath::Type::None) |             if (force || blendType == hecl::ProjectPath::Type::None) | ||||||
|             { |             { | ||||||
|                 HECL::BlenderConnection& conn = HECL::BlenderConnection::SharedConnection(); |                 hecl::BlenderConnection& conn = hecl::BlenderConnection::SharedConnection(); | ||||||
|                 DNAANCS::ReadANCSToBlender<PAKRouter<PAKBridge>, ANCS, MaterialSet, DNACMDL::SurfaceHeader_1, 2> |                 DNAANCS::ReadANCSToBlender<PAKRouter<PAKBridge>, ANCS, MaterialSet, DNACMDL::SurfaceHeader_1, 2> | ||||||
|                         (conn, ancs, blendPath, pakRouter, entry, dataSpec, fileChanged, force); |                         (conn, ancs, blendPath, pakRouter, entry, dataSpec, fileChanged, force); | ||||||
|             } |             } | ||||||
| @ -426,19 +426,19 @@ struct ANCS : BigYAML | |||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     static bool Cook(const HECL::ProjectPath& outPath, |     static bool Cook(const hecl::ProjectPath& outPath, | ||||||
|                      const HECL::ProjectPath& inPath, |                      const hecl::ProjectPath& inPath, | ||||||
|                      const DNAANCS::Actor& actor) |                      const DNAANCS::Actor& actor) | ||||||
|     { |     { | ||||||
|         /* Search for yaml */ |         /* Search for yaml */ | ||||||
|         HECL::ProjectPath yamlPath = inPath.getWithExtension(_S(".yaml"), true); |         hecl::ProjectPath yamlPath = inPath.getWithExtension(_S(".yaml"), true); | ||||||
|         if (yamlPath.getPathType() != HECL::ProjectPath::Type::File) |         if (yamlPath.getPathType() != hecl::ProjectPath::Type::File) | ||||||
|             Log.report(LogVisor::FatalError, _S("'%s' not found as file"), |             Log.report(logvisor::Fatal, _S("'%s' not found as file"), | ||||||
|                        yamlPath.getRelativePath().c_str()); |                        yamlPath.getRelativePath().c_str()); | ||||||
| 
 | 
 | ||||||
|         Athena::io::FileReader yamlReader(yamlPath.getAbsolutePath()); |         athena::io::FileReader yamlReader(yamlPath.getAbsolutePath()); | ||||||
|         if (!BigYAML::ValidateFromYAMLFile<ANCS>(yamlReader)) |         if (!BigYAML::ValidateFromYAMLFile<ANCS>(yamlReader)) | ||||||
|             Log.report(LogVisor::FatalError, _S("'%s' is not Retro::DNAMP1::ANCS type"), |             Log.report(logvisor::Fatal, _S("'%s' is not urde::DNAMP1::ANCS type"), | ||||||
|                        yamlPath.getRelativePath().c_str()); |                        yamlPath.getRelativePath().c_str()); | ||||||
|         ANCS ancs; |         ANCS ancs; | ||||||
|         ancs.read(yamlReader); |         ancs.read(yamlReader); | ||||||
|  | |||||||
| @ -5,9 +5,9 @@ namespace DataSpec | |||||||
| namespace DNAMP1 | namespace DNAMP1 | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| using ANIMOutStream = HECL::BlenderConnection::PyOutStream::ANIMOutStream; | using ANIMOutStream = hecl::BlenderConnection::PyOutStream::ANIMOutStream; | ||||||
| 
 | 
 | ||||||
| void ANIM::IANIM::sendANIMToBlender(HECL::BlenderConnection::PyOutStream& os, const CINF& cinf) const | void ANIM::IANIM::sendANIMToBlender(hecl::BlenderConnection::PyOutStream& os, const CINF& cinf) const | ||||||
| { | { | ||||||
|     os.format("act.hecl_fps = round(%f)\n", (1.0f / mainInterval)); |     os.format("act.hecl_fps = round(%f)\n", (1.0f / mainInterval)); | ||||||
| 
 | 
 | ||||||
| @ -68,7 +68,7 @@ void ANIM::IANIM::sendANIMToBlender(HECL::BlenderConnection::PyOutStream& os, co | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANIM::ANIM0::read(Athena::io::IStreamReader& reader) | void ANIM::ANIM0::read(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     Header head; |     Header head; | ||||||
|     head.read(reader); |     head.read(reader); | ||||||
| @ -138,7 +138,7 @@ void ANIM::ANIM0::read(Athena::io::IStreamReader& reader) | |||||||
|     evnt.read(reader); |     evnt.read(reader); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANIM::ANIM0::write(Athena::io::IStreamWriter& writer) const | void ANIM::ANIM0::write(athena::io::IStreamWriter& writer) const | ||||||
| { | { | ||||||
|     Header head; |     Header head; | ||||||
|     head.unk0 = 0; |     head.unk0 = 0; | ||||||
| @ -239,7 +239,7 @@ size_t ANIM::ANIM0::binarySize(size_t __isz) const | |||||||
|     return __isz + 4; |     return __isz + 4; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANIM::ANIM2::read(Athena::io::IStreamReader& reader) | void ANIM::ANIM2::read(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     Header head; |     Header head; | ||||||
|     head.read(reader); |     head.read(reader); | ||||||
| @ -303,7 +303,7 @@ void ANIM::ANIM2::read(Athena::io::IStreamReader& reader) | |||||||
|     chanKeys = bsReader.read(bsData.get(), keyframeCount, channels, head.rotDiv, head.translationMult); |     chanKeys = bsReader.read(bsData.get(), keyframeCount, channels, head.rotDiv, head.translationMult); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANIM::ANIM2::write(Athena::io::IStreamWriter& writer) const | void ANIM::ANIM2::write(athena::io::IStreamWriter& writer) const | ||||||
| { | { | ||||||
|     Header head; |     Header head; | ||||||
|     head.evnt = evnt; |     head.evnt = evnt; | ||||||
|  | |||||||
| @ -28,7 +28,7 @@ struct ANIM : BigDNA | |||||||
|         float mainInterval = 0.0; |         float mainInterval = 0.0; | ||||||
|         UniqueID32 evnt; |         UniqueID32 evnt; | ||||||
| 
 | 
 | ||||||
|         void sendANIMToBlender(HECL::BlenderConnection::PyOutStream&, const CINF&) const; |         void sendANIMToBlender(hecl::BlenderConnection::PyOutStream&, const CINF&) const; | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     struct ANIM0 : IANIM |     struct ANIM0 : IANIM | ||||||
| @ -90,7 +90,7 @@ struct ANIM : BigDNA | |||||||
|             Value<atUint16> initTZ = 0; |             Value<atUint16> initTZ = 0; | ||||||
|             Value<atUint8> qTZ = 0; |             Value<atUint8> qTZ = 0; | ||||||
| 
 | 
 | ||||||
|             void read(Athena::io::IStreamReader& reader) |             void read(athena::io::IStreamReader& reader) | ||||||
|             { |             { | ||||||
|                 id = reader.readUint32Big(); |                 id = reader.readUint32Big(); | ||||||
|                 keyCount1 = reader.readUint16Big(); |                 keyCount1 = reader.readUint16Big(); | ||||||
| @ -111,7 +111,7 @@ struct ANIM : BigDNA | |||||||
|                     qTZ = reader.readUByte(); |                     qTZ = reader.readUByte(); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             void write(Athena::io::IStreamWriter& writer) const |             void write(athena::io::IStreamWriter& writer) const | ||||||
|             { |             { | ||||||
|                 writer.writeUint32Big(id); |                 writer.writeUint32Big(id); | ||||||
|                 writer.writeUint16Big(keyCount1); |                 writer.writeUint16Big(keyCount1); | ||||||
| @ -143,7 +143,7 @@ struct ANIM : BigDNA | |||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     std::unique_ptr<IANIM> m_anim; |     std::unique_ptr<IANIM> m_anim; | ||||||
|     void read(Athena::io::IStreamReader& reader) |     void read(athena::io::IStreamReader& reader) | ||||||
|     { |     { | ||||||
|         atUint32 version = reader.readUint32Big(); |         atUint32 version = reader.readUint32Big(); | ||||||
|         switch (version) |         switch (version) | ||||||
| @ -157,12 +157,12 @@ struct ANIM : BigDNA | |||||||
|             m_anim->read(reader); |             m_anim->read(reader); | ||||||
|             break; |             break; | ||||||
|         default: |         default: | ||||||
|             Log.report(LogVisor::Error, "unrecognized ANIM version"); |             Log.report(logvisor::Error, "unrecognized ANIM version"); | ||||||
|             break; |             break; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void write(Athena::io::IStreamWriter& writer) const |     void write(athena::io::IStreamWriter& writer) const | ||||||
|     { |     { | ||||||
|         writer.writeUint32Big(m_anim->m_version); |         writer.writeUint32Big(m_anim->m_version); | ||||||
|         m_anim->write(writer); |         m_anim->write(writer); | ||||||
| @ -173,7 +173,7 @@ struct ANIM : BigDNA | |||||||
|         return m_anim->binarySize(__isz + 4); |         return m_anim->binarySize(__isz + 4); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void sendANIMToBlender(HECL::BlenderConnection::PyOutStream& os, const CINF& cinf, bool) const |     void sendANIMToBlender(hecl::BlenderConnection::PyOutStream& os, const CINF& cinf, bool) const | ||||||
|     { |     { | ||||||
|         m_anim->sendANIMToBlender(os, cinf); |         m_anim->sendANIMToBlender(os, cinf); | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -56,7 +56,7 @@ struct CINF : BigDNA | |||||||
|         return nullptr; |         return nullptr; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void sendVertexGroupsToBlender(HECL::BlenderConnection::PyOutStream& os) const |     void sendVertexGroupsToBlender(hecl::BlenderConnection::PyOutStream& os) const | ||||||
|     { |     { | ||||||
|         for (atUint32 bid : boneIds) |         for (atUint32 bid : boneIds) | ||||||
|         { |         { | ||||||
| @ -71,7 +71,7 @@ struct CINF : BigDNA | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void sendCINFToBlender(HECL::BlenderConnection::PyOutStream& os, const UniqueID32& cinfId) const |     void sendCINFToBlender(hecl::BlenderConnection::PyOutStream& os, const UniqueID32& cinfId) const | ||||||
|     { |     { | ||||||
|         os.format("arm = bpy.data.armatures.new('CINF_%08X')\n" |         os.format("arm = bpy.data.armatures.new('CINF_%08X')\n" | ||||||
|                   "arm_obj = bpy.data.objects.new(arm.name, arm)\n" |                   "arm_obj = bpy.data.objects.new(arm.name, arm)\n" | ||||||
|  | |||||||
| @ -8,7 +8,7 @@ | |||||||
| #include "CINF.hpp" | #include "CINF.hpp" | ||||||
| #include "CSKR.hpp" | #include "CSKR.hpp" | ||||||
| 
 | 
 | ||||||
| #include <Athena/FileReader.hpp> | #include <athena/FileReader.hpp> | ||||||
| 
 | 
 | ||||||
| namespace DataSpec | namespace DataSpec | ||||||
| { | { | ||||||
| @ -19,11 +19,11 @@ struct CMDL | |||||||
| { | { | ||||||
|     static bool Extract(const SpecBase& dataSpec, |     static bool Extract(const SpecBase& dataSpec, | ||||||
|                         PAKEntryReadStream& rs, |                         PAKEntryReadStream& rs, | ||||||
|                         const HECL::ProjectPath& outPath, |                         const hecl::ProjectPath& outPath, | ||||||
|                         PAKRouter<PAKBridge>& pakRouter, |                         PAKRouter<PAKBridge>& pakRouter, | ||||||
|                         const PAK::Entry& entry, |                         const PAK::Entry& entry, | ||||||
|                         bool force, |                         bool force, | ||||||
|                         std::function<void(const HECL::SystemChar*)> fileChanged) |                         std::function<void(const hecl::SystemChar*)> fileChanged) | ||||||
|     { |     { | ||||||
|         /* Check for RigPair */ |         /* Check for RigPair */ | ||||||
|         const PAKRouter<PAKBridge>::RigPair* rp = pakRouter.lookupCMDLRigPair(entry.id); |         const PAKRouter<PAKBridge>::RigPair* rp = pakRouter.lookupCMDLRigPair(entry.id); | ||||||
| @ -39,8 +39,8 @@ struct CMDL | |||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         /* Do extract */ |         /* Do extract */ | ||||||
|         HECL::BlenderConnection& conn = HECL::BlenderConnection::SharedConnection(); |         hecl::BlenderConnection& conn = hecl::BlenderConnection::SharedConnection(); | ||||||
|         if (!conn.createBlend(outPath, HECL::BlenderConnection::BlendType::Mesh)) |         if (!conn.createBlend(outPath, hecl::BlenderConnection::BlendType::Mesh)) | ||||||
|             return false; |             return false; | ||||||
|         DNACMDL::ReadCMDLToBlender<PAKRouter<PAKBridge>, MaterialSet, std::pair<CSKR*,CINF*>, DNACMDL::SurfaceHeader_1, 2> |         DNACMDL::ReadCMDLToBlender<PAKRouter<PAKBridge>, MaterialSet, std::pair<CSKR*,CINF*>, DNACMDL::SurfaceHeader_1, 2> | ||||||
|                 (conn, rs, pakRouter, entry, dataSpec, loadRp); |                 (conn, rs, pakRouter, entry, dataSpec, loadRp); | ||||||
| @ -48,24 +48,24 @@ struct CMDL | |||||||
| 
 | 
 | ||||||
| #if 0 | #if 0 | ||||||
|         /* Cook and re-extract test */ |         /* Cook and re-extract test */ | ||||||
|         HECL::ProjectPath tempOut = outPath.getWithExtension(_S(".recook"), true); |         hecl::ProjectPath tempOut = outPath.getWithExtension(_S(".recook"), true); | ||||||
|         HECL::BlenderConnection::DataStream ds = conn.beginData(); |         hecl::BlenderConnection::DataStream ds = conn.beginData(); | ||||||
|         DNACMDL::Mesh mesh = ds.compileMesh(HECL::TopologyTriStrips, -1); |         DNACMDL::Mesh mesh = ds.compileMesh(hecl::TopologyTriStrips, -1); | ||||||
|         ds.close(); |         ds.close(); | ||||||
|         DNACMDL::WriteCMDL<MaterialSet, DNACMDL::SurfaceHeader_1_2, 2>(tempOut, outPath, mesh); |         DNACMDL::WriteCMDL<MaterialSet, DNACMDL::SurfaceHeader_1_2, 2>(tempOut, outPath, mesh); | ||||||
| 
 | 
 | ||||||
|         Athena::io::FileReader reader(tempOut.getAbsolutePath()); |         athena::io::FileReader reader(tempOut.getAbsolutePath()); | ||||||
|         HECL::ProjectPath tempBlend = outPath.getWithExtension(_S(".recook.blend"), true); |         hecl::ProjectPath tempBlend = outPath.getWithExtension(_S(".recook.blend"), true); | ||||||
|         if (!conn.createBlend(tempBlend, HECL::BlenderConnection::TypeMesh)) |         if (!conn.createBlend(tempBlend, hecl::BlenderConnection::TypeMesh)) | ||||||
|             return false; |             return false; | ||||||
|         DNACMDL::ReadCMDLToBlender<PAKRouter<PAKBridge>, MaterialSet, std::pair<CSKR*,CINF*>, DNACMDL::SurfaceHeader_1_2, 2> |         DNACMDL::ReadCMDLToBlender<PAKRouter<PAKBridge>, MaterialSet, std::pair<CSKR*,CINF*>, DNACMDL::SurfaceHeader_1_2, 2> | ||||||
|                 (conn, reader, pakRouter, entry, dataSpec, loadRp); |                 (conn, reader, pakRouter, entry, dataSpec, loadRp); | ||||||
|         return conn.saveBlend(); |         return conn.saveBlend(); | ||||||
| #elif 0 | #elif 0 | ||||||
|         /* HMDL cook test */ |         /* HMDL cook test */ | ||||||
|         HECL::ProjectPath tempOut = outPath.getWithExtension(_S(".recook"), true); |         hecl::ProjectPath tempOut = outPath.getWithExtension(_S(".recook"), true); | ||||||
|         HECL::BlenderConnection::DataStream ds = conn.beginData(); |         hecl::BlenderConnection::DataStream ds = conn.beginData(); | ||||||
|         DNACMDL::Mesh mesh = ds.compileMesh(HECL::HMDLTopology::TriStrips, 16); |         DNACMDL::Mesh mesh = ds.compileMesh(hecl::HMDLTopology::TriStrips, 16); | ||||||
|         ds.close(); |         ds.close(); | ||||||
|         DNACMDL::WriteHMDLCMDL<HMDLMaterialSet, DNACMDL::SurfaceHeader_1, 2>(tempOut, outPath, mesh); |         DNACMDL::WriteHMDLCMDL<HMDLMaterialSet, DNACMDL::SurfaceHeader_1, 2>(tempOut, outPath, mesh); | ||||||
| #endif | #endif | ||||||
| @ -81,11 +81,11 @@ struct CMDL | |||||||
|         DNACMDL::NameCMDL<PAKRouter<PAKBridge>, MaterialSet>(rs, pakRouter, entry, dataSpec); |         DNACMDL::NameCMDL<PAKRouter<PAKBridge>, MaterialSet>(rs, pakRouter, entry, dataSpec); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     static bool Cook(const HECL::ProjectPath& outPath, |     static bool Cook(const hecl::ProjectPath& outPath, | ||||||
|                      const HECL::ProjectPath& inPath, |                      const hecl::ProjectPath& inPath, | ||||||
|                      const DNACMDL::Mesh& mesh) |                      const DNACMDL::Mesh& mesh) | ||||||
|     { |     { | ||||||
|         HECL::ProjectPath tempOut = outPath.getWithExtension(_S(".recook")); |         hecl::ProjectPath tempOut = outPath.getWithExtension(_S(".recook")); | ||||||
|         if (mesh.skins.size()) |         if (mesh.skins.size()) | ||||||
|         { |         { | ||||||
|             DNACMDL::Mesh skinMesh = mesh.getContiguousSkinningVersion(); |             DNACMDL::Mesh skinMesh = mesh.getContiguousSkinningVersion(); | ||||||
| @ -94,7 +94,7 @@ struct CMDL | |||||||
| 
 | 
 | ||||||
|             /* Output skinning intermediate */ |             /* Output skinning intermediate */ | ||||||
|             auto vertCountIt = skinMesh.contiguousSkinVertCounts.cbegin(); |             auto vertCountIt = skinMesh.contiguousSkinVertCounts.cbegin(); | ||||||
|             Athena::io::FileWriter writer(outPath.getWithExtension(_S(".skin")).getAbsolutePath()); |             athena::io::FileWriter writer(outPath.getWithExtension(_S(".skin")).getAbsolutePath()); | ||||||
|             writer.writeUint32Big(skinMesh.skins.size()); |             writer.writeUint32Big(skinMesh.skins.size()); | ||||||
|             for (const std::vector<DNACMDL::Mesh::SkinBind> skin : skinMesh.skins) |             for (const std::vector<DNACMDL::Mesh::SkinBind> skin : skinMesh.skins) | ||||||
|             { |             { | ||||||
| @ -116,18 +116,18 @@ struct CMDL | |||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     static bool HMDLCook(const HECL::ProjectPath& outPath, |     static bool HMDLCook(const hecl::ProjectPath& outPath, | ||||||
|                          const HECL::ProjectPath& inPath, |                          const hecl::ProjectPath& inPath, | ||||||
|                          const DNACMDL::Mesh& mesh) |                          const DNACMDL::Mesh& mesh) | ||||||
|     { |     { | ||||||
|         HECL::ProjectPath tempOut = outPath.getWithExtension(_S(".recook")); |         hecl::ProjectPath tempOut = outPath.getWithExtension(_S(".recook")); | ||||||
|         if (mesh.skins.size()) |         if (mesh.skins.size()) | ||||||
|         { |         { | ||||||
|             if (!DNACMDL::WriteHMDLCMDL<HMDLMaterialSet, DNACMDL::SurfaceHeader_1, 2>(tempOut, inPath, mesh)) |             if (!DNACMDL::WriteHMDLCMDL<HMDLMaterialSet, DNACMDL::SurfaceHeader_1, 2>(tempOut, inPath, mesh)) | ||||||
|                 return false; |                 return false; | ||||||
| 
 | 
 | ||||||
|             /* Output skinning intermediate */ |             /* Output skinning intermediate */ | ||||||
|             Athena::io::FileWriter writer(outPath.getWithExtension(_S(".skin")).getAbsolutePath()); |             athena::io::FileWriter writer(outPath.getWithExtension(_S(".skin")).getAbsolutePath()); | ||||||
|             writer.writeUint32Big(mesh.skinBanks.banks.size()); |             writer.writeUint32Big(mesh.skinBanks.banks.size()); | ||||||
|             for (const DNACMDL::Mesh::SkinBanks::Bank& sb : mesh.skinBanks.banks) |             for (const DNACMDL::Mesh::SkinBanks::Bank& sb : mesh.skinBanks.banks) | ||||||
|             { |             { | ||||||
|  | |||||||
| @ -1,7 +1,7 @@ | |||||||
| #include "CMDLMaterials.hpp" | #include "CMDLMaterials.hpp" | ||||||
| #include "../DNAMP2/CMDLMaterials.hpp" | #include "../DNAMP2/CMDLMaterials.hpp" | ||||||
| 
 | 
 | ||||||
| using Stream = HECL::BlenderConnection::PyOutStream; | using Stream = hecl::BlenderConnection::PyOutStream; | ||||||
| 
 | 
 | ||||||
| namespace DataSpec | namespace DataSpec | ||||||
| { | { | ||||||
| @ -914,10 +914,10 @@ void MaterialSet::ConstructMaterial(Stream& out, | |||||||
|                                     unsigned matIdx) |                                     unsigned matIdx) | ||||||
| {_ConstructMaterial(out, material, groupIdx, matIdx);} | {_ConstructMaterial(out, material, groupIdx, matIdx);} | ||||||
| 
 | 
 | ||||||
| MaterialSet::Material::Material(const HECL::Backend::GX& gx, | MaterialSet::Material::Material(const hecl::Backend::GX& gx, | ||||||
|                                 const std::unordered_map<std::string, int32_t>& iprops, |                                 const std::unordered_map<std::string, int32_t>& iprops, | ||||||
|                                 const std::vector<HECL::ProjectPath>& texPathsIn, |                                 const std::vector<hecl::ProjectPath>& texPathsIn, | ||||||
|                                 std::vector<HECL::ProjectPath>& texPathsOut, |                                 std::vector<hecl::ProjectPath>& texPathsOut, | ||||||
|                                 int colorCount, |                                 int colorCount, | ||||||
|                                 int uvCount, |                                 int uvCount, | ||||||
|                                 bool lightmapUVs, |                                 bool lightmapUVs, | ||||||
| @ -969,7 +969,7 @@ MaterialSet::Material::Material(const HECL::Backend::GX& gx, | |||||||
|     textureIdxs.reserve(gx.m_tevCount); |     textureIdxs.reserve(gx.m_tevCount); | ||||||
|     for (unsigned i=0 ; i<gx.m_tevCount ; ++i) |     for (unsigned i=0 ; i<gx.m_tevCount ; ++i) | ||||||
|     { |     { | ||||||
|         const HECL::Backend::GX::TEVStage& stage = gx.m_tevs[i]; |         const hecl::Backend::GX::TEVStage& stage = gx.m_tevs[i]; | ||||||
|         tevStageTexInfo.emplace_back(); |         tevStageTexInfo.emplace_back(); | ||||||
|         TEVStageTexInfo& texInfo = tevStageTexInfo.back(); |         TEVStageTexInfo& texInfo = tevStageTexInfo.back(); | ||||||
|         if (stage.m_texGenIdx != -1) |         if (stage.m_texGenIdx != -1) | ||||||
| @ -977,7 +977,7 @@ MaterialSet::Material::Material(const HECL::Backend::GX& gx, | |||||||
|         if (stage.m_texMapIdx != -1) |         if (stage.m_texMapIdx != -1) | ||||||
|         { |         { | ||||||
|             texInfo.texSlot = textureIdxs.size(); |             texInfo.texSlot = textureIdxs.size(); | ||||||
|             const HECL::ProjectPath& texPath = texPathsIn.at(stage.m_texMapIdx); |             const hecl::ProjectPath& texPath = texPathsIn.at(stage.m_texMapIdx); | ||||||
|             texFlags |= 1 << i; |             texFlags |= 1 << i; | ||||||
|             ++textureCount; |             ++textureCount; | ||||||
|             bool found = false; |             bool found = false; | ||||||
| @ -1056,11 +1056,11 @@ MaterialSet::Material::Material(const HECL::Backend::GX& gx, | |||||||
|     ColorChannel& ch = colorChannels.back(); |     ColorChannel& ch = colorChannels.back(); | ||||||
|     for (unsigned i=0 ; i<gx.m_tevCount ; ++i) |     for (unsigned i=0 ; i<gx.m_tevCount ; ++i) | ||||||
|     { |     { | ||||||
|         const HECL::Backend::GX::TEVStage& stage = gx.m_tevs[i]; |         const hecl::Backend::GX::TEVStage& stage = gx.m_tevs[i]; | ||||||
|         for (int c=0 ; c<4 ; ++c) |         for (int c=0 ; c<4 ; ++c) | ||||||
|             if (stage.m_color[c] == HECL::Backend::GX::CC_RASC || |             if (stage.m_color[c] == hecl::Backend::GX::CC_RASC || | ||||||
|                 stage.m_color[c] == HECL::Backend::GX::CC_RASA || |                 stage.m_color[c] == hecl::Backend::GX::CC_RASA || | ||||||
|                 stage.m_alpha[c] == HECL::Backend::GX::CA_RASA) |                 stage.m_alpha[c] == hecl::Backend::GX::CA_RASA) | ||||||
|             { |             { | ||||||
|                 ch.setLighting(true); |                 ch.setLighting(true); | ||||||
|                 break; |                 break; | ||||||
| @ -1075,7 +1075,7 @@ MaterialSet::Material::Material(const HECL::Backend::GX& gx, | |||||||
|     tevStages.reserve(gx.m_tevCount); |     tevStages.reserve(gx.m_tevCount); | ||||||
|     for (unsigned i=0 ; i<gx.m_tevCount ; ++i) |     for (unsigned i=0 ; i<gx.m_tevCount ; ++i) | ||||||
|     { |     { | ||||||
|         const HECL::Backend::GX::TEVStage& stage = gx.m_tevs[i]; |         const hecl::Backend::GX::TEVStage& stage = gx.m_tevs[i]; | ||||||
|         tevStages.emplace_back(); |         tevStages.emplace_back(); | ||||||
|         TEVStage& target = tevStages.back(); |         TEVStage& target = tevStages.back(); | ||||||
| 
 | 
 | ||||||
| @ -1104,7 +1104,7 @@ MaterialSet::Material::Material(const HECL::Backend::GX& gx, | |||||||
|     tcgCount = gx.m_tcgCount; |     tcgCount = gx.m_tcgCount; | ||||||
|     for (unsigned i=0 ; i<gx.m_tcgCount ; ++i) |     for (unsigned i=0 ; i<gx.m_tcgCount ; ++i) | ||||||
|     { |     { | ||||||
|         const HECL::Backend::GX::TexCoordGen& tcg = gx.m_tcgs[i]; |         const hecl::Backend::GX::TexCoordGen& tcg = gx.m_tcgs[i]; | ||||||
|         tcgs.emplace_back(); |         tcgs.emplace_back(); | ||||||
|         TexCoordGen& target = tcgs.back(); |         TexCoordGen& target = tcgs.back(); | ||||||
|         target.setType(GX::TG_MTX3x4); |         target.setType(GX::TG_MTX3x4); | ||||||
| @ -1132,7 +1132,7 @@ MaterialSet::Material::Material(const HECL::Backend::GX& gx, | |||||||
|         bool found = false; |         bool found = false; | ||||||
|         for (unsigned t=0 ; t<gx.m_tcgCount ; ++t) |         for (unsigned t=0 ; t<gx.m_tcgCount ; ++t) | ||||||
|         { |         { | ||||||
|             const HECL::Backend::GX::TexCoordGen& tcg = gx.m_tcgs[t]; |             const hecl::Backend::GX::TexCoordGen& tcg = gx.m_tcgs[t]; | ||||||
|             if (tcg.m_mtx == GX::IDENTITY) |             if (tcg.m_mtx == GX::IDENTITY) | ||||||
|                 continue; |                 continue; | ||||||
|             if ((tcg.m_mtx - GX::TEXMTX0) / 3 == uvAnimsCount) |             if ((tcg.m_mtx - GX::TEXMTX0) / 3 == uvAnimsCount) | ||||||
| @ -1149,11 +1149,11 @@ MaterialSet::Material::Material(const HECL::Backend::GX& gx, | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| HMDLMaterialSet::Material::Material(HECL::Frontend::Frontend& FE, | HMDLMaterialSet::Material::Material(hecl::Frontend::Frontend& FE, | ||||||
|                                     const std::string& diagName, |                                     const std::string& diagName, | ||||||
|                                     const HECL::BlenderConnection::DataStream::Mesh::Material& mat, |                                     const hecl::BlenderConnection::DataStream::Mesh::Material& mat, | ||||||
|                                     const std::unordered_map<std::string, int32_t>& iprops, |                                     const std::unordered_map<std::string, int32_t>& iprops, | ||||||
|                                     const std::vector<HECL::ProjectPath>& texPaths) |                                     const std::vector<hecl::ProjectPath>& texPaths) | ||||||
| { | { | ||||||
|     auto search = iprops.find("retro_depth_sort"); |     auto search = iprops.find("retro_depth_sort"); | ||||||
|     if (search != iprops.end()) |     if (search != iprops.end()) | ||||||
| @ -1187,10 +1187,10 @@ HMDLMaterialSet::Material::Material(HECL::Frontend::Frontend& FE, | |||||||
|     if (search != iprops.end()) |     if (search != iprops.end()) | ||||||
|         flags.setLightmap(search->second != 0); |         flags.setLightmap(search->second != 0); | ||||||
| 
 | 
 | ||||||
|     for (const HECL::ProjectPath& path : mat.texs) |     for (const hecl::ProjectPath& path : mat.texs) | ||||||
|     { |     { | ||||||
|         size_t idx = 0; |         size_t idx = 0; | ||||||
|         for (const HECL::ProjectPath& tPath : texPaths) |         for (const hecl::ProjectPath& tPath : texPaths) | ||||||
|         { |         { | ||||||
|             if (path == tPath) |             if (path == tPath) | ||||||
|             { |             { | ||||||
| @ -1210,15 +1210,15 @@ HMDLMaterialSet::Material::Material(HECL::Frontend::Frontend& FE, | |||||||
| 
 | 
 | ||||||
|     uvAnimsSize = 4; |     uvAnimsSize = 4; | ||||||
|     uvAnimsCount = 0; |     uvAnimsCount = 0; | ||||||
|     for (const HECL::Frontend::IR::Instruction& inst : heclIr.m_instructions) |     for (const hecl::Frontend::IR::Instruction& inst : heclIr.m_instructions) | ||||||
|     { |     { | ||||||
|         if (inst.m_op != HECL::Frontend::IR::OpType::Call) |         if (inst.m_op != hecl::Frontend::IR::OpType::Call) | ||||||
|             continue; |             continue; | ||||||
|         if (inst.m_call.m_name.compare("Texture")) |         if (inst.m_call.m_name.compare("Texture")) | ||||||
|             continue; |             continue; | ||||||
| 
 | 
 | ||||||
|         const HECL::Frontend::IR::Instruction& sourceInst = inst.getChildInst(heclIr, 1); |         const hecl::Frontend::IR::Instruction& sourceInst = inst.getChildInst(heclIr, 1); | ||||||
|         if (sourceInst.m_op != HECL::Frontend::IR::OpType::Call) |         if (sourceInst.m_op != hecl::Frontend::IR::OpType::Call) | ||||||
|             continue; |             continue; | ||||||
|         if (sourceInst.m_call.m_name.compare(0, 11, "RetroUVMode")) |         if (sourceInst.m_call.m_name.compare(0, 11, "RetroUVMode")) | ||||||
|             continue; |             continue; | ||||||
| @ -1227,7 +1227,7 @@ HMDLMaterialSet::Material::Material(HECL::Frontend::Frontend& FE, | |||||||
|         gameArgs.reserve(sourceInst.getChildCount() - 1); |         gameArgs.reserve(sourceInst.getChildCount() - 1); | ||||||
|         for (int i=1 ; i<sourceInst.getChildCount() ; ++i) |         for (int i=1 ; i<sourceInst.getChildCount() ; ++i) | ||||||
|         { |         { | ||||||
|             const HECL::Frontend::IR::Instruction& ci = sourceInst.getChildInst(heclIr, i); |             const hecl::Frontend::IR::Instruction& ci = sourceInst.getChildInst(heclIr, i); | ||||||
|             gameArgs.push_back(ci.getImmVec()); |             gameArgs.push_back(ci.getImmVec()); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
| @ -1248,7 +1248,7 @@ MaterialSet::Material::UVAnimation::UVAnimation(const std::string& gameFunction, | |||||||
|     { |     { | ||||||
|         mode = Mode::Scroll; |         mode = Mode::Scroll; | ||||||
|         if (gameArgs.size() < 2) |         if (gameArgs.size() < 2) | ||||||
|             Log.report(LogVisor::FatalError, "Mode2 UV anim requires 2 vector arguments"); |             Log.report(logvisor::Fatal, "Mode2 UV anim requires 2 vector arguments"); | ||||||
|         vals[0] = gameArgs[0].vec[0]; |         vals[0] = gameArgs[0].vec[0]; | ||||||
|         vals[1] = gameArgs[0].vec[1]; |         vals[1] = gameArgs[0].vec[1]; | ||||||
|         vals[2] = gameArgs[1].vec[0]; |         vals[2] = gameArgs[1].vec[0]; | ||||||
| @ -1258,7 +1258,7 @@ MaterialSet::Material::UVAnimation::UVAnimation(const std::string& gameFunction, | |||||||
|     { |     { | ||||||
|         mode = Mode::Rotation; |         mode = Mode::Rotation; | ||||||
|         if (gameArgs.size() < 2) |         if (gameArgs.size() < 2) | ||||||
|             Log.report(LogVisor::FatalError, "Mode3 UV anim requires 2 arguments"); |             Log.report(logvisor::Fatal, "Mode3 UV anim requires 2 arguments"); | ||||||
|         vals[0] = gameArgs[0].vec[0]; |         vals[0] = gameArgs[0].vec[0]; | ||||||
|         vals[1] = gameArgs[1].vec[0]; |         vals[1] = gameArgs[1].vec[0]; | ||||||
|     } |     } | ||||||
| @ -1266,7 +1266,7 @@ MaterialSet::Material::UVAnimation::UVAnimation(const std::string& gameFunction, | |||||||
|     { |     { | ||||||
|         mode = Mode::HStrip; |         mode = Mode::HStrip; | ||||||
|         if (gameArgs.size() < 4) |         if (gameArgs.size() < 4) | ||||||
|             Log.report(LogVisor::FatalError, "Mode4 UV anim requires 4 arguments"); |             Log.report(logvisor::Fatal, "Mode4 UV anim requires 4 arguments"); | ||||||
|         vals[0] = gameArgs[0].vec[0]; |         vals[0] = gameArgs[0].vec[0]; | ||||||
|         vals[1] = gameArgs[1].vec[0]; |         vals[1] = gameArgs[1].vec[0]; | ||||||
|         vals[2] = gameArgs[2].vec[0]; |         vals[2] = gameArgs[2].vec[0]; | ||||||
| @ -1276,7 +1276,7 @@ MaterialSet::Material::UVAnimation::UVAnimation(const std::string& gameFunction, | |||||||
|     { |     { | ||||||
|         mode = Mode::VStrip; |         mode = Mode::VStrip; | ||||||
|         if (gameArgs.size() < 4) |         if (gameArgs.size() < 4) | ||||||
|             Log.report(LogVisor::FatalError, "Mode5 UV anim requires 4 arguments"); |             Log.report(logvisor::Fatal, "Mode5 UV anim requires 4 arguments"); | ||||||
|         vals[0] = gameArgs[0].vec[0]; |         vals[0] = gameArgs[0].vec[0]; | ||||||
|         vals[1] = gameArgs[1].vec[0]; |         vals[1] = gameArgs[1].vec[0]; | ||||||
|         vals[2] = gameArgs[2].vec[0]; |         vals[2] = gameArgs[2].vec[0]; | ||||||
| @ -1288,12 +1288,12 @@ MaterialSet::Material::UVAnimation::UVAnimation(const std::string& gameFunction, | |||||||
|     { |     { | ||||||
|         mode = Mode::WhoMustNotBeNamed; |         mode = Mode::WhoMustNotBeNamed; | ||||||
|         if (gameArgs.size() < 2) |         if (gameArgs.size() < 2) | ||||||
|             Log.report(LogVisor::FatalError, "Mode7 UV anim requires 2 arguments"); |             Log.report(logvisor::Fatal, "Mode7 UV anim requires 2 arguments"); | ||||||
|         vals[0] = gameArgs[0].vec[0]; |         vals[0] = gameArgs[0].vec[0]; | ||||||
|         vals[1] = gameArgs[1].vec[0]; |         vals[1] = gameArgs[1].vec[0]; | ||||||
|     } |     } | ||||||
|     else |     else | ||||||
|         Log.report(LogVisor::FatalError, "unsupported UV anim '%s'", gameFunction.c_str()); |         Log.report(logvisor::Fatal, "unsupported UV anim '%s'", gameFunction.c_str()); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -268,7 +268,7 @@ struct MaterialSet : BigDNA | |||||||
|                 Eight |                 Eight | ||||||
|             } mode; |             } mode; | ||||||
|             float vals[9]; |             float vals[9]; | ||||||
|             void read(Athena::io::IStreamReader& reader) |             void read(athena::io::IStreamReader& reader) | ||||||
|             { |             { | ||||||
|                 mode = Mode(reader.readUint32Big()); |                 mode = Mode(reader.readUint32Big()); | ||||||
|                 switch (mode) |                 switch (mode) | ||||||
| @ -303,7 +303,7 @@ struct MaterialSet : BigDNA | |||||||
|                     break; |                     break; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             void write(Athena::io::IStreamWriter& writer) const |             void write(athena::io::IStreamWriter& writer) const | ||||||
|             { |             { | ||||||
|                 writer.writeUint32Big(atUint32(mode)); |                 writer.writeUint32Big(atUint32(mode)); | ||||||
|                 switch (mode) |                 switch (mode) | ||||||
| @ -365,21 +365,21 @@ struct MaterialSet : BigDNA | |||||||
|         }; |         }; | ||||||
|         Vector<UVAnimation, DNA_COUNT(uvAnimsCount)> uvAnims; |         Vector<UVAnimation, DNA_COUNT(uvAnimsCount)> uvAnims; | ||||||
| 
 | 
 | ||||||
|         static void AddTexture(HECL::BlenderConnection::PyOutStream& out, |         static void AddTexture(hecl::BlenderConnection::PyOutStream& out, | ||||||
|                                GX::TexGenSrc type, int mtxIdx, uint32_t texIdx); |                                GX::TexGenSrc type, int mtxIdx, uint32_t texIdx); | ||||||
|         static void AddTextureAnim(HECL::BlenderConnection::PyOutStream& out, |         static void AddTextureAnim(hecl::BlenderConnection::PyOutStream& out, | ||||||
|                                    MaterialSet::Material::UVAnimation::Mode type, |                                    MaterialSet::Material::UVAnimation::Mode type, | ||||||
|                                    unsigned idx, const float* vals); |                                    unsigned idx, const float* vals); | ||||||
|         static void AddKcolor(HECL::BlenderConnection::PyOutStream& out, |         static void AddKcolor(hecl::BlenderConnection::PyOutStream& out, | ||||||
|                               const GX::Color& col, unsigned idx); |                               const GX::Color& col, unsigned idx); | ||||||
|         static void AddDynamicColor(HECL::BlenderConnection::PyOutStream& out, unsigned idx); |         static void AddDynamicColor(hecl::BlenderConnection::PyOutStream& out, unsigned idx); | ||||||
|         static void AddDynamicAlpha(HECL::BlenderConnection::PyOutStream& out, unsigned idx); |         static void AddDynamicAlpha(hecl::BlenderConnection::PyOutStream& out, unsigned idx); | ||||||
| 
 | 
 | ||||||
|         Material() = default; |         Material() = default; | ||||||
|         Material(const HECL::Backend::GX& gx, |         Material(const hecl::Backend::GX& gx, | ||||||
|                  const std::unordered_map<std::string, int32_t>& iprops, |                  const std::unordered_map<std::string, int32_t>& iprops, | ||||||
|                  const std::vector<HECL::ProjectPath>& texPathsIn, |                  const std::vector<hecl::ProjectPath>& texPathsIn, | ||||||
|                  std::vector<HECL::ProjectPath>& texPathsOut, |                  std::vector<hecl::ProjectPath>& texPathsOut, | ||||||
|                  int colorCount, |                  int colorCount, | ||||||
|                  int uvCount, |                  int uvCount, | ||||||
|                  bool lightmapUVs, |                  bool lightmapUVs, | ||||||
| @ -388,12 +388,12 @@ struct MaterialSet : BigDNA | |||||||
|     }; |     }; | ||||||
|     Vector<Material, DNA_COUNT(head.materialCount)> materials; |     Vector<Material, DNA_COUNT(head.materialCount)> materials; | ||||||
| 
 | 
 | ||||||
|     static void RegisterMaterialProps(HECL::BlenderConnection::PyOutStream& out); |     static void RegisterMaterialProps(hecl::BlenderConnection::PyOutStream& out); | ||||||
|     static void ConstructMaterial(HECL::BlenderConnection::PyOutStream& out, |     static void ConstructMaterial(hecl::BlenderConnection::PyOutStream& out, | ||||||
|                                   const MaterialSet::Material& material, |                                   const MaterialSet::Material& material, | ||||||
|                                   unsigned groupIdx, unsigned matIdx); |                                   unsigned groupIdx, unsigned matIdx); | ||||||
| 
 | 
 | ||||||
|     void readToBlender(HECL::BlenderConnection::PyOutStream& os, |     void readToBlender(hecl::BlenderConnection::PyOutStream& os, | ||||||
|                        const PAKRouter<PAKBridge>& pakRouter, |                        const PAKRouter<PAKBridge>& pakRouter, | ||||||
|                        const PAKRouter<PAKBridge>::EntryType& entry, |                        const PAKRouter<PAKBridge>::EntryType& entry, | ||||||
|                        unsigned setIdx) |                        unsigned setIdx) | ||||||
| @ -416,7 +416,7 @@ struct MaterialSet : BigDNA | |||||||
|                     ++stageIdx; |                     ++stageIdx; | ||||||
|                     continue; |                     continue; | ||||||
|                 } |                 } | ||||||
|                 const NOD::Node* node; |                 const nod::Node* node; | ||||||
|                 typename PAKRouter::EntryType* texEntry = (typename PAKRouter::EntryType*) |                 typename PAKRouter::EntryType* texEntry = (typename PAKRouter::EntryType*) | ||||||
|                 pakRouter.lookupEntry(head.textureIDs[mat.textureIdxs[texInfo.texSlot]], &node); |                 pakRouter.lookupEntry(head.textureIDs[mat.textureIdxs[texInfo.texSlot]], &node); | ||||||
|                 if (texEntry->name.size()) |                 if (texEntry->name.size()) | ||||||
| @ -427,9 +427,9 @@ struct MaterialSet : BigDNA | |||||||
|                     continue; |                     continue; | ||||||
|                 } |                 } | ||||||
|                 if (setIdx < 0) |                 if (setIdx < 0) | ||||||
|                     texEntry->name = HECL::Format("%s_%d_%d", prefix, matIdx, stageIdx); |                     texEntry->name = hecl::Format("%s_%d_%d", prefix, matIdx, stageIdx); | ||||||
|                 else |                 else | ||||||
|                     texEntry->name = HECL::Format("%s_%d_%d_%d", prefix, setIdx, matIdx, stageIdx); |                     texEntry->name = hecl::Format("%s_%d_%d_%d", prefix, setIdx, matIdx, stageIdx); | ||||||
| 
 | 
 | ||||||
|                 if (mat.flags.lightmap() && stageIdx == 0) |                 if (mat.flags.lightmap() && stageIdx == 0) | ||||||
|                 { |                 { | ||||||
| @ -468,14 +468,14 @@ struct HMDLMaterialSet : BigDNA | |||||||
|         Vector<MaterialSet::Material::UVAnimation, DNA_COUNT(uvAnimsCount)> uvAnims; |         Vector<MaterialSet::Material::UVAnimation, DNA_COUNT(uvAnimsCount)> uvAnims; | ||||||
| 
 | 
 | ||||||
|         String<-1> heclSource; |         String<-1> heclSource; | ||||||
|         HECL::Frontend::IR heclIr; |         hecl::Frontend::IR heclIr; | ||||||
| 
 | 
 | ||||||
|         Material() = default; |         Material() = default; | ||||||
|         Material(HECL::Frontend::Frontend& FE, |         Material(hecl::Frontend::Frontend& FE, | ||||||
|                  const std::string& diagName, |                  const std::string& diagName, | ||||||
|                  const HECL::BlenderConnection::DataStream::Mesh::Material& mat, |                  const hecl::BlenderConnection::DataStream::Mesh::Material& mat, | ||||||
|                  const std::unordered_map<std::string, int32_t>& iprops, |                  const std::unordered_map<std::string, int32_t>& iprops, | ||||||
|                  const std::vector<HECL::ProjectPath>& texPaths); |                  const std::vector<hecl::ProjectPath>& texPaths); | ||||||
|     }; |     }; | ||||||
|     Vector<Material, DNA_COUNT(head.materialCount)> materials; |     Vector<Material, DNA_COUNT(head.materialCount)> materials; | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -34,7 +34,7 @@ struct CSKR : BigDNA | |||||||
|         return nullptr; |         return nullptr; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void weightVertex(HECL::BlenderConnection::PyOutStream& os, const CINF& cinf, atUint32 idx) const |     void weightVertex(hecl::BlenderConnection::PyOutStream& os, const CINF& cinf, atUint32 idx) const | ||||||
|     { |     { | ||||||
|         atUint32 accum = 0; |         atUint32 accum = 0; | ||||||
|         for (const SkinningRule& rule : skinningRules) |         for (const SkinningRule& rule : skinningRules) | ||||||
|  | |||||||
| @ -18,7 +18,7 @@ namespace DataSpec | |||||||
| { | { | ||||||
| namespace DNAMP1 | namespace DNAMP1 | ||||||
| { | { | ||||||
| LogVisor::LogModule Log("Retro::DNAMP1"); | logvisor::Module Log("urde::DNAMP1"); | ||||||
| 
 | 
 | ||||||
| static bool GetNoShare(const std::string& name) | static bool GetNoShare(const std::string& name) | ||||||
| { | { | ||||||
| @ -29,12 +29,12 @@ static bool GetNoShare(const std::string& name) | |||||||
|     return true; |     return true; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| PAKBridge::PAKBridge(HECL::Database::Project& project, | PAKBridge::PAKBridge(hecl::Database::Project& project, | ||||||
|                      const NOD::Node& node, |                      const nod::Node& node, | ||||||
|                      bool doExtract) |                      bool doExtract) | ||||||
| : m_project(project), m_node(node), m_pak(false, GetNoShare(node.getName())), m_doExtract(doExtract) | : m_project(project), m_node(node), m_pak(false, GetNoShare(node.getName())), m_doExtract(doExtract) | ||||||
| { | { | ||||||
|     NOD::AthenaPartReadStream rs(node.beginReadStream()); |     nod::AthenaPartReadStream rs(node.beginReadStream()); | ||||||
|     m_pak.read(rs); |     m_pak.read(rs); | ||||||
| 
 | 
 | ||||||
|     /* Append Level String */ |     /* Append Level String */ | ||||||
| @ -60,12 +60,12 @@ PAKBridge::PAKBridge(HECL::Database::Project& project, | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static HECL::SystemString LayerName(const std::string& name) | static hecl::SystemString LayerName(const std::string& name) | ||||||
| { | { | ||||||
| #if HECL_UCS2 | #if HECL_UCS2 | ||||||
|     HECL::SystemString ret = HECL::UTF8ToWide(name); |     hecl::SystemString ret = hecl::UTF8ToWide(name); | ||||||
| #else | #else | ||||||
|     HECL::SystemString ret = name; |     hecl::SystemString ret = name; | ||||||
| #endif | #endif | ||||||
|     for (auto& ch : ret) |     for (auto& ch : ret) | ||||||
|         if (ch == _S('/') || ch == _S('\\')) |         if (ch == _S('/') || ch == _S('\\')) | ||||||
| @ -88,7 +88,7 @@ void PAKBridge::build() | |||||||
|                 mlvl.read(rs); |                 mlvl.read(rs); | ||||||
|             } |             } | ||||||
| #if HECL_UCS2 | #if HECL_UCS2 | ||||||
|             level.name = HECL::UTF8ToWide(m_pak.bestEntryName(entry)); |             level.name = hecl::UTF8ToWide(m_pak.bestEntryName(entry)); | ||||||
| #else | #else | ||||||
|             level.name = m_pak.bestEntryName(entry); |             level.name = m_pak.bestEntryName(entry); | ||||||
| #endif | #endif | ||||||
| @ -102,7 +102,7 @@ void PAKBridge::build() | |||||||
|             { |             { | ||||||
|                 worldMapEnt->name = entry.name + "_mapw"; |                 worldMapEnt->name = entry.name + "_mapw"; | ||||||
|                 PAKEntryReadStream rs = worldMapEnt->beginReadStream(m_node); |                 PAKEntryReadStream rs = worldMapEnt->beginReadStream(m_node); | ||||||
|                 rs.seek(8, Athena::Current); |                 rs.seek(8, athena::Current); | ||||||
|                 atUint32 areaCount = rs.readUint32Big(); |                 atUint32 areaCount = rs.readUint32Big(); | ||||||
|                 mapw.reserve(areaCount); |                 mapw.reserve(areaCount); | ||||||
|                 for (atUint32 i=0 ; i<areaCount ; ++i) |                 for (atUint32 i=0 ; i<areaCount ; ++i) | ||||||
| @ -145,17 +145,17 @@ void PAKBridge::build() | |||||||
|                 if (areaDeps.name.empty()) |                 if (areaDeps.name.empty()) | ||||||
|                 { |                 { | ||||||
| #if HECL_UCS2 | #if HECL_UCS2 | ||||||
|                     areaDeps.name = _S("MREA_") + HECL::UTF8ToWide(area.areaMREAId.toString()); |                     areaDeps.name = _S("MREA_") + hecl::UTF8ToWide(area.areaMREAId.toString()); | ||||||
| #else | #else | ||||||
|                     areaDeps.name = "MREA_" + area.areaMREAId.toString(); |                     areaDeps.name = "MREA_" + area.areaMREAId.toString(); | ||||||
| #endif | #endif | ||||||
|                 } |                 } | ||||||
|                 HECL::SystemChar num[16]; |                 hecl::SystemChar num[16]; | ||||||
|                 HECL::SNPrintf(num, 16, _S("%02u "), ai); |                 hecl::SNPrintf(num, 16, _S("%02u "), ai); | ||||||
|                 areaDeps.name = num + areaDeps.name; |                 areaDeps.name = num + areaDeps.name; | ||||||
| 
 | 
 | ||||||
| #if HECL_UCS2 | #if HECL_UCS2 | ||||||
|                 std::string lowerName = HECL::WideToUTF8(areaDeps.name); |                 std::string lowerName = hecl::WideToUTF8(areaDeps.name); | ||||||
| #else | #else | ||||||
|                 std::string lowerName(areaDeps.name); |                 std::string lowerName(areaDeps.name); | ||||||
| #endif | #endif | ||||||
| @ -187,7 +187,7 @@ void PAKBridge::build() | |||||||
|                     while (layer.name.size() && isspace(layer.name.back())) |                     while (layer.name.size() && isspace(layer.name.back())) | ||||||
|                         layer.name.pop_back(); |                         layer.name.pop_back(); | ||||||
| #endif | #endif | ||||||
|                     HECL::SNPrintf(num, 16, layer.active ? _S("%02ua ") : _S("%02u "), l-1); |                     hecl::SNPrintf(num, 16, layer.active ? _S("%02ua ") : _S("%02u "), l-1); | ||||||
|                     layer.name = num + layer.name; |                     layer.name = num + layer.name; | ||||||
| 
 | 
 | ||||||
|                     layer.resources.reserve(area.depLayers[l] - r); |                     layer.resources.reserve(area.depLayers[l] - r); | ||||||
| @ -228,16 +228,16 @@ void PAKBridge::addCMDLRigPairs(PAKRouter<PAKBridge>& pakRouter, | |||||||
|                 PAK::Entry* cmdlEnt = (PAK::Entry*)m_pak.lookupEntry(ci.cmdl); |                 PAK::Entry* cmdlEnt = (PAK::Entry*)m_pak.lookupEntry(ci.cmdl); | ||||||
|                 PAK::Entry* cskrEnt = (PAK::Entry*)m_pak.lookupEntry(ci.cskr); |                 PAK::Entry* cskrEnt = (PAK::Entry*)m_pak.lookupEntry(ci.cskr); | ||||||
|                 PAK::Entry* cinfEnt = (PAK::Entry*)m_pak.lookupEntry(ci.cinf); |                 PAK::Entry* cinfEnt = (PAK::Entry*)m_pak.lookupEntry(ci.cinf); | ||||||
|                 cmdlEnt->name = HECL::Format("ANCS_%08X_%s_model", entry.first.toUint32(), ci.name.c_str()); |                 cmdlEnt->name = hecl::Format("ANCS_%08X_%s_model", entry.first.toUint32(), ci.name.c_str()); | ||||||
|                 cskrEnt->name = HECL::Format("ANCS_%08X_%s_skin", entry.first.toUint32(), ci.name.c_str()); |                 cskrEnt->name = hecl::Format("ANCS_%08X_%s_skin", entry.first.toUint32(), ci.name.c_str()); | ||||||
|                 cinfEnt->name = HECL::Format("ANCS_%08X_%s_skel", entry.first.toUint32(), ci.name.c_str()); |                 cinfEnt->name = hecl::Format("ANCS_%08X_%s_skel", entry.first.toUint32(), ci.name.c_str()); | ||||||
|                 if (ci.cmdlOverlay && ci.cskrOverlay) |                 if (ci.cmdlOverlay && ci.cskrOverlay) | ||||||
|                 { |                 { | ||||||
|                     addTo[ci.cmdlOverlay] = std::make_pair(ci.cskrOverlay, ci.cinf); |                     addTo[ci.cmdlOverlay] = std::make_pair(ci.cskrOverlay, ci.cinf); | ||||||
|                     PAK::Entry* cmdlEnt = (PAK::Entry*)m_pak.lookupEntry(ci.cmdlOverlay); |                     PAK::Entry* cmdlEnt = (PAK::Entry*)m_pak.lookupEntry(ci.cmdlOverlay); | ||||||
|                     PAK::Entry* cskrEnt = (PAK::Entry*)m_pak.lookupEntry(ci.cskrOverlay); |                     PAK::Entry* cskrEnt = (PAK::Entry*)m_pak.lookupEntry(ci.cskrOverlay); | ||||||
|                     cmdlEnt->name = HECL::Format("ANCS_%08X_%s_overmodel", entry.first.toUint32(), ci.name.c_str()); |                     cmdlEnt->name = hecl::Format("ANCS_%08X_%s_overmodel", entry.first.toUint32(), ci.name.c_str()); | ||||||
|                     cskrEnt->name = HECL::Format("ANCS_%08X_%s_overskin", entry.first.toUint32(), ci.name.c_str()); |                     cskrEnt->name = hecl::Format("ANCS_%08X_%s_overskin", entry.first.toUint32(), ci.name.c_str()); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             std::map<atUint32, DNAANCS::AnimationResInfo<UniqueID32>> animInfo; |             std::map<atUint32, DNAANCS::AnimationResInfo<UniqueID32>> animInfo; | ||||||
| @ -245,11 +245,11 @@ void PAKBridge::addCMDLRigPairs(PAKRouter<PAKBridge>& pakRouter, | |||||||
|             for (auto& ae : animInfo) |             for (auto& ae : animInfo) | ||||||
|             { |             { | ||||||
|                 PAK::Entry* animEnt = (PAK::Entry*)m_pak.lookupEntry(ae.second.animId); |                 PAK::Entry* animEnt = (PAK::Entry*)m_pak.lookupEntry(ae.second.animId); | ||||||
|                 animEnt->name = HECL::Format("ANCS_%08X_%s", entry.first.toUint32(), ae.second.name.c_str()); |                 animEnt->name = hecl::Format("ANCS_%08X_%s", entry.first.toUint32(), ae.second.name.c_str()); | ||||||
|                 if (ae.second.evntId) |                 if (ae.second.evntId) | ||||||
|                 { |                 { | ||||||
|                     PAK::Entry* evntEnt = (PAK::Entry*)m_pak.lookupEntry(ae.second.evntId); |                     PAK::Entry* evntEnt = (PAK::Entry*)m_pak.lookupEntry(ae.second.evntId); | ||||||
|                     evntEnt->name = HECL::Format("ANCS_%08X_%s_evnt", entry.first.toUint32(), ae.second.name.c_str()); |                     evntEnt->name = hecl::Format("ANCS_%08X_%s_evnt", entry.first.toUint32(), ae.second.name.c_str()); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  | |||||||
| @ -9,30 +9,30 @@ namespace DataSpec | |||||||
| namespace DNAMP1 | namespace DNAMP1 | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| extern LogVisor::LogModule Log; | extern logvisor::Module Log; | ||||||
| 
 | 
 | ||||||
| /* MP1-specific, one-shot PAK traversal/extraction class */ | /* MP1-specific, one-shot PAK traversal/extraction class */ | ||||||
| class PAKBridge | class PAKBridge | ||||||
| { | { | ||||||
|     HECL::Database::Project& m_project; |     hecl::Database::Project& m_project; | ||||||
|     const NOD::Node& m_node; |     const nod::Node& m_node; | ||||||
|     PAK m_pak; |     PAK m_pak; | ||||||
| public: | public: | ||||||
|     bool m_doExtract; |     bool m_doExtract; | ||||||
|     using Level = Level<UniqueID32>; |     using Level = Level<UniqueID32>; | ||||||
|     std::unordered_map<UniqueID32, Level> m_levelDeps; |     std::unordered_map<UniqueID32, Level> m_levelDeps; | ||||||
|     HECL::SystemString m_levelString; |     hecl::SystemString m_levelString; | ||||||
| 
 | 
 | ||||||
|     PAKBridge(HECL::Database::Project& project, |     PAKBridge(hecl::Database::Project& project, | ||||||
|               const NOD::Node& node, |               const nod::Node& node, | ||||||
|               bool doExtract=true); |               bool doExtract=true); | ||||||
|     void build(); |     void build(); | ||||||
|     static ResExtractor<PAKBridge> LookupExtractor(const PAK::Entry& entry); |     static ResExtractor<PAKBridge> LookupExtractor(const PAK::Entry& entry); | ||||||
|     const std::string& getName() const {return m_node.getName();} |     const std::string& getName() const {return m_node.getName();} | ||||||
|     const HECL::SystemString& getLevelString() const {return m_levelString;} |     const hecl::SystemString& getLevelString() const {return m_levelString;} | ||||||
|     using PAKType = PAK; |     using PAKType = PAK; | ||||||
|     const PAKType& getPAK() const {return m_pak;} |     const PAKType& getPAK() const {return m_pak;} | ||||||
|     const NOD::Node& getNode() const {return m_node;} |     const nod::Node& getNode() const {return m_node;} | ||||||
| 
 | 
 | ||||||
|     void addCMDLRigPairs(PAKRouter<PAKBridge>& pakRouter, |     void addCMDLRigPairs(PAKRouter<PAKBridge>& pakRouter, | ||||||
|             std::unordered_map<UniqueID32, std::pair<UniqueID32, UniqueID32>>& addTo) const; |             std::unordered_map<UniqueID32, std::pair<UniqueID32, UniqueID32>>& addTo) const; | ||||||
|  | |||||||
| @ -5,7 +5,7 @@ namespace DataSpec | |||||||
| namespace DNAMP1 | namespace DNAMP1 | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| void DeafBabe::BlenderInit(HECL::BlenderConnection::PyOutStream& os) | void DeafBabe::BlenderInit(hecl::BlenderConnection::PyOutStream& os) | ||||||
| { | { | ||||||
|     os << "TYPE_COLORS = {'Ground':(1.0, 0.43, 0.15),\n" |     os << "TYPE_COLORS = {'Ground':(1.0, 0.43, 0.15),\n" | ||||||
|           "               'Stone':(0.28, 0.28, 0.28),\n" |           "               'Stone':(0.28, 0.28, 0.28),\n" | ||||||
|  | |||||||
| @ -86,10 +86,10 @@ struct DeafBabe : BigDNA | |||||||
|     Vector<atVec3f, DNA_COUNT(vertCount)> verts; |     Vector<atVec3f, DNA_COUNT(vertCount)> verts; | ||||||
| 
 | 
 | ||||||
|     /* Dummy MP2 member */ |     /* Dummy MP2 member */ | ||||||
|     void insertNoClimb(HECL::BlenderConnection::PyOutStream&) const {} |     void insertNoClimb(hecl::BlenderConnection::PyOutStream&) const {} | ||||||
| 
 | 
 | ||||||
|     static void BlenderInit(HECL::BlenderConnection::PyOutStream& os); |     static void BlenderInit(hecl::BlenderConnection::PyOutStream& os); | ||||||
|     void sendToBlender(HECL::BlenderConnection::PyOutStream& os) const |     void sendToBlender(hecl::BlenderConnection::PyOutStream& os) const | ||||||
|     { |     { | ||||||
|         DeafBabeSendToBlender(os, *this); |         DeafBabeSendToBlender(os, *this); | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -5,7 +5,7 @@ namespace DataSpec | |||||||
| namespace DNAMP1 | namespace DNAMP1 | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| void EVNT::read(Athena::io::IStreamReader& reader) | void EVNT::read(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     version = reader.readUint32Big(); |     version = reader.readUint32Big(); | ||||||
| 
 | 
 | ||||||
| @ -26,7 +26,7 @@ void EVNT::read(Athena::io::IStreamReader& reader) | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void EVNT::write(Athena::io::IStreamWriter& writer) const | void EVNT::write(athena::io::IStreamWriter& writer) const | ||||||
| { | { | ||||||
|     writer.writeUint32Big(version); |     writer.writeUint32Big(version); | ||||||
| 
 | 
 | ||||||
| @ -46,50 +46,42 @@ void EVNT::write(Athena::io::IStreamWriter& writer) const | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void EVNT::read(Athena::io::YAMLDocReader& reader) | void EVNT::read(athena::io::YAMLDocReader& reader) | ||||||
| { | { | ||||||
|     version = reader.readUint32("version"); |     version = reader.readUint32("version"); | ||||||
| 
 | 
 | ||||||
|     atUint32 loopCount = reader.readUint32("loopCount"); |     reader.enumerate("loopEvents", loopEvents); | ||||||
|     reader.enumerate("loopEvents", loopEvents, loopCount); |  | ||||||
| 
 | 
 | ||||||
|     uevtEvents.clear(); |     uevtEvents.clear(); | ||||||
|     atUint32 uevtCount = reader.readUint32("uevtCount"); |     reader.enumerate("uevtEvents", uevtEvents); | ||||||
|     reader.enumerate("uevtEvents", uevtEvents, uevtCount); |  | ||||||
| 
 | 
 | ||||||
|     atUint32 effectCount = reader.readUint32("effectCount"); |     reader.enumerate("effectEvents", effectEvents); | ||||||
|     reader.enumerate("effectEvents", effectEvents, effectCount); |  | ||||||
| 
 | 
 | ||||||
|     if (version == 2) |     if (version == 2) | ||||||
|     { |     { | ||||||
|         atUint32 sfxCount = reader.readUint32("sfxCount"); |         reader.enumerate("sfxEvents", sfxEvents); | ||||||
|         reader.enumerate("sfxEvents", sfxEvents, sfxCount); |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void EVNT::write(Athena::io::YAMLDocWriter& writer) const | void EVNT::write(athena::io::YAMLDocWriter& writer) const | ||||||
| { | { | ||||||
|     writer.writeUint32("version", version); |     writer.writeUint32("version", version); | ||||||
| 
 | 
 | ||||||
|     writer.writeUint32("loopCount", loopEvents.size()); |  | ||||||
|     writer.enumerate("loopEvents", loopEvents); |     writer.enumerate("loopEvents", loopEvents); | ||||||
| 
 | 
 | ||||||
|     writer.writeUint32("uevtCount", uevtEvents.size()); |  | ||||||
|     writer.enumerate("uevtEvents", uevtEvents); |     writer.enumerate("uevtEvents", uevtEvents); | ||||||
| 
 | 
 | ||||||
|     writer.writeUint32("effectCount", effectEvents.size()); |  | ||||||
|     writer.enumerate("effectEvents", effectEvents); |     writer.enumerate("effectEvents", effectEvents); | ||||||
| 
 | 
 | ||||||
|     if (version == 2) |     if (version == 2) | ||||||
|     { |     { | ||||||
|         writer.writeUint32("sfxCount", sfxEvents.size()); |  | ||||||
|         writer.enumerate("sfxEvents", sfxEvents); |         writer.enumerate("sfxEvents", sfxEvents); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| const char* EVNT::DNAType() | const char* EVNT::DNAType() | ||||||
| { | { | ||||||
|     return "Retro::DNAMP1::EVNT"; |     return "urde::DNAMP1::EVNT"; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| size_t EVNT::binarySize(size_t __isz) const | size_t EVNT::binarySize(size_t __isz) const | ||||||
|  | |||||||
| @ -66,11 +66,11 @@ struct EVNT : BigYAML | |||||||
|     }; |     }; | ||||||
|     std::vector<SFXEvent> sfxEvents; |     std::vector<SFXEvent> sfxEvents; | ||||||
| 
 | 
 | ||||||
|     static bool Extract(PAKEntryReadStream& rs, const HECL::ProjectPath& outPath) |     static bool Extract(PAKEntryReadStream& rs, const hecl::ProjectPath& outPath) | ||||||
|     { |     { | ||||||
|         EVNT evnt; |         EVNT evnt; | ||||||
|         evnt.read(rs); |         evnt.read(rs); | ||||||
|         FILE* fp = HECL::Fopen(outPath.getAbsolutePath().c_str(), _S("wb")); |         FILE* fp = hecl::Fopen(outPath.getAbsolutePath().c_str(), _S("wb")); | ||||||
|         evnt.toYAMLFile(fp); |         evnt.toYAMLFile(fp); | ||||||
|         fclose(fp); |         fclose(fp); | ||||||
|         return true; |         return true; | ||||||
|  | |||||||
| @ -5,7 +5,7 @@ namespace DataSpec | |||||||
| { | { | ||||||
| namespace DNAMP1 | namespace DNAMP1 | ||||||
| { | { | ||||||
| void FRME::read(Athena::io::IStreamReader& __dna_reader) | void FRME::read(athena::io::IStreamReader& __dna_reader) | ||||||
| { | { | ||||||
|     /* version */ |     /* version */ | ||||||
|     version = __dna_reader.readUint32Big(); |     version = __dna_reader.readUint32Big(); | ||||||
| @ -18,13 +18,13 @@ void FRME::read(Athena::io::IStreamReader& __dna_reader) | |||||||
|     /* widgetCount */ |     /* widgetCount */ | ||||||
|     widgetCount = __dna_reader.readUint32Big(); |     widgetCount = __dna_reader.readUint32Big(); | ||||||
|     /* widgets */ |     /* widgets */ | ||||||
|     __dna_reader.enumerate<Widget>(widgets, widgetCount, [this](Athena::io::IStreamReader& reader, Widget& w) { |     __dna_reader.enumerate<Widget>(widgets, widgetCount, [this](athena::io::IStreamReader& reader, Widget& w) { | ||||||
|         w.owner = this; |         w.owner = this; | ||||||
|         w.read(reader); |         w.read(reader); | ||||||
|     }); |     }); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void FRME::write(Athena::io::IStreamWriter& __dna_writer) const | void FRME::write(athena::io::IStreamWriter& __dna_writer) const | ||||||
| { | { | ||||||
|     /* version */ |     /* version */ | ||||||
|     __dna_writer.writeUint32Big(version); |     __dna_writer.writeUint32Big(version); | ||||||
| @ -46,7 +46,7 @@ size_t FRME::binarySize(size_t __isz) const | |||||||
|     return __isz + 20; |     return __isz + 20; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void FRME::Widget::read(Athena::io::IStreamReader& __dna_reader) | void FRME::Widget::read(athena::io::IStreamReader& __dna_reader) | ||||||
| { | { | ||||||
|     /* type */ |     /* type */ | ||||||
|     type.read(__dna_reader); |     type.read(__dna_reader); | ||||||
| @ -67,7 +67,7 @@ void FRME::Widget::read(Athena::io::IStreamReader& __dna_reader) | |||||||
|     case SBIG('TBGP'): widgetInfo.reset(new TBGPInfo); break; |     case SBIG('TBGP'): widgetInfo.reset(new TBGPInfo); break; | ||||||
|     case SBIG('SLGP'): widgetInfo.reset(new SLGPInfo); break; |     case SBIG('SLGP'): widgetInfo.reset(new SLGPInfo); break; | ||||||
|     default: |     default: | ||||||
|         Log.report(LogVisor::FatalError, _S("Unsupported FRME widget type %.8X"), type.toUint32()); |         Log.report(logvisor::Fatal, _S("Unsupported FRME widget type %.8X"), type.toUint32()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /* widgetInfo */ |     /* widgetInfo */ | ||||||
| @ -98,7 +98,7 @@ void FRME::Widget::read(Athena::io::IStreamReader& __dna_reader) | |||||||
|     unk4 = __dna_reader.readBool(); |     unk4 = __dna_reader.readBool(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void FRME::Widget::write(Athena::io::IStreamWriter& __dna_writer) const | void FRME::Widget::write(athena::io::IStreamWriter& __dna_writer) const | ||||||
| { | { | ||||||
|     /* type */ |     /* type */ | ||||||
|     type.write(__dna_writer); |     type.write(__dna_writer); | ||||||
| @ -143,7 +143,7 @@ size_t FRME::Widget::binarySize(size_t __isz) const | |||||||
|     return __isz + 67; |     return __isz + 67; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void FRME::Widget::CAMRInfo::read(Athena::io::IStreamReader& __dna_reader) | void FRME::Widget::CAMRInfo::read(athena::io::IStreamReader& __dna_reader) | ||||||
| { | { | ||||||
|     projectionType = ProjectionType(__dna_reader.readUint32Big()); |     projectionType = ProjectionType(__dna_reader.readUint32Big()); | ||||||
|     if (projectionType == ProjectionType::Perspective) |     if (projectionType == ProjectionType::Perspective) | ||||||
| @ -151,17 +151,17 @@ void FRME::Widget::CAMRInfo::read(Athena::io::IStreamReader& __dna_reader) | |||||||
|     else if (projectionType == ProjectionType::Orthographic) |     else if (projectionType == ProjectionType::Orthographic) | ||||||
|         projection.reset(new OrthographicProjection); |         projection.reset(new OrthographicProjection); | ||||||
|     else |     else | ||||||
|         Log.report(LogVisor::FatalError, _S("Invalid CAMR projection mode! %i"), int(projectionType)); |         Log.report(logvisor::Fatal, _S("Invalid CAMR projection mode! %i"), int(projectionType)); | ||||||
| 
 | 
 | ||||||
|     projection->read(__dna_reader); |     projection->read(__dna_reader); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void FRME::Widget::CAMRInfo::write(Athena::io::IStreamWriter& __dna_writer) const | void FRME::Widget::CAMRInfo::write(athena::io::IStreamWriter& __dna_writer) const | ||||||
| { | { | ||||||
|     if (!projection) |     if (!projection) | ||||||
|         Log.report(LogVisor::FatalError, _S("Invalid CAMR projection object!")); |         Log.report(logvisor::Fatal, _S("Invalid CAMR projection object!")); | ||||||
|     if (projection->type != projectionType) |     if (projection->type != projectionType) | ||||||
|         Log.report(LogVisor::FatalError, _S("CAMR projection type does not match actual projection type!")); |         Log.report(logvisor::Fatal, _S("CAMR projection type does not match actual projection type!")); | ||||||
| 
 | 
 | ||||||
|     __dna_writer.writeUint32Big(atUint32(projectionType)); |     __dna_writer.writeUint32Big(atUint32(projectionType)); | ||||||
|     projection->write(__dna_writer); |     projection->write(__dna_writer); | ||||||
| @ -173,7 +173,7 @@ size_t FRME::Widget::CAMRInfo::binarySize(size_t __isz) const | |||||||
|     return __isz + 4; |     return __isz + 4; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void FRME::Widget::TXPNInfo::read(Athena::io::IStreamReader& __dna_reader) | void FRME::Widget::TXPNInfo::read(athena::io::IStreamReader& __dna_reader) | ||||||
| { | { | ||||||
|     IWidgetInfo::read(__dna_reader); |     IWidgetInfo::read(__dna_reader); | ||||||
|     /* frameVals[0] */ |     /* frameVals[0] */ | ||||||
| @ -213,7 +213,7 @@ void FRME::Widget::TXPNInfo::read(Athena::io::IStreamReader& __dna_reader) | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void FRME::Widget::TXPNInfo::write(Athena::io::IStreamWriter& __dna_writer) const | void FRME::Widget::TXPNInfo::write(athena::io::IStreamWriter& __dna_writer) const | ||||||
| { | { | ||||||
|     IWidgetInfo::write(__dna_writer); |     IWidgetInfo::write(__dna_writer); | ||||||
|     /* frameVals[0] */ |     /* frameVals[0] */ | ||||||
| @ -263,22 +263,22 @@ size_t FRME::Widget::TXPNInfo::binarySize(size_t __isz) const | |||||||
|     return __isz + (version == 1 ? 78 : 66); |     return __isz + (version == 1 ? 78 : 66); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| bool FRME::Extract(const SpecBase &dataSpec, PAKEntryReadStream &rs, const HECL::ProjectPath &outPath, PAKRouter<PAKBridge> &pakRouter, const PAK::Entry &entry, bool force, std::function<void (const HECL::SystemChar *)> fileChanged) | bool FRME::Extract(const SpecBase &dataSpec, PAKEntryReadStream &rs, const hecl::ProjectPath &outPath, PAKRouter<PAKBridge> &pakRouter, const PAK::Entry &entry, bool force, std::function<void (const hecl::SystemChar *)> fileChanged) | ||||||
| { | { | ||||||
|     FRME frme; |     FRME frme; | ||||||
|     frme.read(rs); |     frme.read(rs); | ||||||
| 
 | 
 | ||||||
|     HECL::BlenderConnection& conn = HECL::BlenderConnection::SharedConnection(); |     hecl::BlenderConnection& conn = hecl::BlenderConnection::SharedConnection(); | ||||||
| 
 | 
 | ||||||
| #if 0 | #if 0 | ||||||
|     if (!force && outPath.getPathType() == HECL::ProjectPath::Type::File) |     if (!force && outPath.getPathType() == hecl::ProjectPath::Type::File) | ||||||
|         return true; |         return true; | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
|     if (!conn.createBlend(outPath, HECL::BlenderConnection::BlendType::Frame)) |     if (!conn.createBlend(outPath, hecl::BlenderConnection::BlendType::Frame)) | ||||||
|         return false; |         return false; | ||||||
| 
 | 
 | ||||||
|     HECL::BlenderConnection::PyOutStream os = conn.beginPythonOut(true); |     hecl::BlenderConnection::PyOutStream os = conn.beginPythonOut(true); | ||||||
| 
 | 
 | ||||||
|     os << "import bpy, math\n" |     os << "import bpy, math\n" | ||||||
|           "from mathutils import Matrix, Quaternion\n" |           "from mathutils import Matrix, Quaternion\n" | ||||||
| @ -347,7 +347,7 @@ bool FRME::Extract(const SpecBase &dataSpec, PAKEntryReadStream &rs, const HECL: | |||||||
|         { |         { | ||||||
|             using MODLInfo = FRME::Widget::MODLInfo; |             using MODLInfo = FRME::Widget::MODLInfo; | ||||||
|             MODLInfo* info = dynamic_cast<MODLInfo*>(w.widgetInfo.get()); |             MODLInfo* info = dynamic_cast<MODLInfo*>(w.widgetInfo.get()); | ||||||
|             HECL::ProjectPath modelPath = pakRouter.getWorking(info->model); |             hecl::ProjectPath modelPath = pakRouter.getWorking(info->model); | ||||||
|             const PAKRouter<PAKBridge>::EntryType* cmdlE = pakRouter.lookupEntry(info->model, nullptr, true, true); |             const PAKRouter<PAKBridge>::EntryType* cmdlE = pakRouter.lookupEntry(info->model, nullptr, true, true); | ||||||
| 
 | 
 | ||||||
|             os.linkBlend(modelPath.getAbsolutePathUTF8().c_str(), |             os.linkBlend(modelPath.getAbsolutePathUTF8().c_str(), | ||||||
| @ -366,16 +366,16 @@ bool FRME::Extract(const SpecBase &dataSpec, PAKEntryReadStream &rs, const HECL: | |||||||
|             if (info && info->texture) |             if (info && info->texture) | ||||||
|             { |             { | ||||||
|                 std::string texName = pakRouter.getBestEntryName(info->texture); |                 std::string texName = pakRouter.getBestEntryName(info->texture); | ||||||
|                 const NOD::Node* node; |                 const nod::Node* node; | ||||||
|                 const PAKRouter<PAKBridge>::EntryType* texEntry = pakRouter.lookupEntry(info->texture, &node); |                 const PAKRouter<PAKBridge>::EntryType* texEntry = pakRouter.lookupEntry(info->texture, &node); | ||||||
|                 HECL::ProjectPath txtrPath = pakRouter.getWorking(texEntry); |                 hecl::ProjectPath txtrPath = pakRouter.getWorking(texEntry); | ||||||
|                 if (txtrPath.getPathType() == HECL::ProjectPath::Type::None) |                 if (txtrPath.getPathType() == hecl::ProjectPath::Type::None) | ||||||
|                 { |                 { | ||||||
|                     PAKEntryReadStream rs = texEntry->beginReadStream(*node); |                     PAKEntryReadStream rs = texEntry->beginReadStream(*node); | ||||||
|                     TXTR::Extract(rs, txtrPath); |                     TXTR::Extract(rs, txtrPath); | ||||||
|                 } |                 } | ||||||
|                 HECL::SystemString resPath = pakRouter.getResourceRelativePath(entry, info->texture); |                 hecl::SystemString resPath = pakRouter.getResourceRelativePath(entry, info->texture); | ||||||
|                 HECL::SystemUTF8View resPathView(resPath); |                 hecl::SystemUTF8View resPathView(resPath); | ||||||
|                 os.format("if '%s' in bpy.data.images:\n" |                 os.format("if '%s' in bpy.data.images:\n" | ||||||
|                           "    image = bpy.data.images['%s']\n" |                           "    image = bpy.data.images['%s']\n" | ||||||
|                           "else:\n" |                           "else:\n" | ||||||
|  | |||||||
| @ -3,7 +3,7 @@ | |||||||
| 
 | 
 | ||||||
| #include "../DNACommon/DNACommon.hpp" | #include "../DNACommon/DNACommon.hpp" | ||||||
| #include "DNAMP1.hpp" | #include "DNAMP1.hpp" | ||||||
| #include <Athena/FileWriter.hpp> | #include <athena/FileWriter.hpp> | ||||||
| 
 | 
 | ||||||
| namespace DataSpec | namespace DataSpec | ||||||
| { | { | ||||||
| @ -39,8 +39,8 @@ struct FRME : BigDNA | |||||||
|         struct IWidgetInfo : BigDNA |         struct IWidgetInfo : BigDNA | ||||||
|         { |         { | ||||||
|             Delete _d; |             Delete _d; | ||||||
|             virtual void read(Athena::io::IStreamReader&) {} |             virtual void read(athena::io::IStreamReader&) {} | ||||||
|             void write(Athena::io::IStreamWriter&) const {} |             void write(athena::io::IStreamWriter&) const {} | ||||||
|             size_t binarySize(size_t __isz) const { return __isz; } |             size_t binarySize(size_t __isz) const { return __isz; } | ||||||
|         }; |         }; | ||||||
| 
 | 
 | ||||||
| @ -219,11 +219,11 @@ struct FRME : BigDNA | |||||||
|     Vector<Widget, DNA_COUNT(widgetCount)> widgets; |     Vector<Widget, DNA_COUNT(widgetCount)> widgets; | ||||||
|     static bool Extract(const SpecBase& dataSpec, |     static bool Extract(const SpecBase& dataSpec, | ||||||
|                         PAKEntryReadStream& rs, |                         PAKEntryReadStream& rs, | ||||||
|                         const HECL::ProjectPath& outPath, |                         const hecl::ProjectPath& outPath, | ||||||
|                         PAKRouter<PAKBridge>& pakRouter, |                         PAKRouter<PAKBridge>& pakRouter, | ||||||
|                         const PAK::Entry& entry, |                         const PAK::Entry& entry, | ||||||
|                         bool force, |                         bool force, | ||||||
|                         std::function<void(const HECL::SystemChar*)> fileChanged); |                         std::function<void(const hecl::SystemChar*)> fileChanged); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -16,15 +16,15 @@ struct MAPA : DNAMAPA::MAPA | |||||||
| { | { | ||||||
|     static bool Extract(const SpecBase& dataSpec, |     static bool Extract(const SpecBase& dataSpec, | ||||||
|                         PAKEntryReadStream& rs, |                         PAKEntryReadStream& rs, | ||||||
|                         const HECL::ProjectPath& outPath, |                         const hecl::ProjectPath& outPath, | ||||||
|                         PAKRouter<PAKBridge>& pakRouter, |                         PAKRouter<PAKBridge>& pakRouter, | ||||||
|                         const PAK::Entry& entry, |                         const PAK::Entry& entry, | ||||||
|                         bool force, |                         bool force, | ||||||
|                         std::function<void(const HECL::SystemChar*)> fileChanged) |                         std::function<void(const hecl::SystemChar*)> fileChanged) | ||||||
|     { |     { | ||||||
|         MAPA mapa; |         MAPA mapa; | ||||||
|         mapa.read(rs); |         mapa.read(rs); | ||||||
|         HECL::BlenderConnection& conn = HECL::BlenderConnection::SharedConnection(); |         hecl::BlenderConnection& conn = hecl::BlenderConnection::SharedConnection(); | ||||||
|         return DNAMAPA::ReadMAPAToBlender(conn, mapa, outPath, pakRouter, entry, force); |         return DNAMAPA::ReadMAPAToBlender(conn, mapa, outPath, pakRouter, entry, force); | ||||||
|     } |     } | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -108,18 +108,18 @@ struct MLVL : BigYAML | |||||||
| 
 | 
 | ||||||
|     static bool Extract(const SpecBase& dataSpec, |     static bool Extract(const SpecBase& dataSpec, | ||||||
|                         PAKEntryReadStream& rs, |                         PAKEntryReadStream& rs, | ||||||
|                         const HECL::ProjectPath& outPath, |                         const hecl::ProjectPath& outPath, | ||||||
|                         PAKRouter<PAKBridge>& pakRouter, |                         PAKRouter<PAKBridge>& pakRouter, | ||||||
|                         const PAK::Entry& entry, |                         const PAK::Entry& entry, | ||||||
|                         bool force, |                         bool force, | ||||||
|                         std::function<void(const HECL::SystemChar*)> fileChanged) |                         std::function<void(const hecl::SystemChar*)> fileChanged) | ||||||
|     { |     { | ||||||
|         MLVL mlvl; |         MLVL mlvl; | ||||||
|         mlvl.read(rs); |         mlvl.read(rs); | ||||||
|         FILE* fp = HECL::Fopen(outPath.getWithExtension(_S(".yaml"), true).getAbsolutePath().c_str(), _S("w")); |         FILE* fp = hecl::Fopen(outPath.getWithExtension(_S(".yaml"), true).getAbsolutePath().c_str(), _S("w")); | ||||||
|         mlvl.toYAMLFile(fp); |         mlvl.toYAMLFile(fp); | ||||||
|         fclose(fp); |         fclose(fp); | ||||||
|         HECL::BlenderConnection& conn = HECL::BlenderConnection::SharedConnection(); |         hecl::BlenderConnection& conn = hecl::BlenderConnection::SharedConnection(); | ||||||
|         return DNAMLVL::ReadMLVLToBlender(conn, mlvl, outPath, pakRouter, |         return DNAMLVL::ReadMLVLToBlender(conn, mlvl, outPath, pakRouter, | ||||||
|                                           entry, force, fileChanged); |                                           entry, force, fileChanged); | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -2,23 +2,19 @@ | |||||||
| #include "SCLY.hpp" | #include "SCLY.hpp" | ||||||
| #include "DeafBabe.hpp" | #include "DeafBabe.hpp" | ||||||
| #include "../DNACommon/BabeDead.hpp" | #include "../DNACommon/BabeDead.hpp" | ||||||
| 
 | #include "zeus/Math.hpp" | ||||||
| #ifndef _USE_MATH_DEFINES |  | ||||||
| #define _USE_MATH_DEFINES 1 |  | ||||||
| #endif |  | ||||||
| #include <math.h> |  | ||||||
| 
 | 
 | ||||||
| namespace DataSpec | namespace DataSpec | ||||||
| { | { | ||||||
| namespace DNAMP1 | namespace DNAMP1 | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| void MREA::ReadBabeDeadToBlender_1_2(HECL::BlenderConnection::PyOutStream& os, | void MREA::ReadBabeDeadToBlender_1_2(hecl::BlenderConnection::PyOutStream& os, | ||||||
|                                      Athena::io::IStreamReader& rs) |                                      athena::io::IStreamReader& rs) | ||||||
| { | { | ||||||
|     atUint32 bdMagic = rs.readUint32Big(); |     atUint32 bdMagic = rs.readUint32Big(); | ||||||
|     if (bdMagic != 0xBABEDEAD) |     if (bdMagic != 0xBABEDEAD) | ||||||
|         Log.report(LogVisor::FatalError, "invalid BABEDEAD magic"); |         Log.report(logvisor::Fatal, "invalid BABEDEAD magic"); | ||||||
|     os << "bpy.context.scene.render.engine = 'CYCLES'\n" |     os << "bpy.context.scene.render.engine = 'CYCLES'\n" | ||||||
|           "bpy.context.scene.world.use_nodes = True\n" |           "bpy.context.scene.world.use_nodes = True\n" | ||||||
|           "bpy.context.scene.render.engine = 'BLENDER_GAME'\n" |           "bpy.context.scene.render.engine = 'BLENDER_GAME'\n" | ||||||
| @ -49,7 +45,7 @@ void MREA::AddCMDLRigPairs(PAKEntryReadStream& rs, | |||||||
|     atUint64 secStart = rs.position(); |     atUint64 secStart = rs.position(); | ||||||
|     while (curSec != head.sclySecIdx) |     while (curSec != head.sclySecIdx) | ||||||
|         secStart += head.secSizes[curSec++]; |         secStart += head.secSizes[curSec++]; | ||||||
|     rs.seek(secStart, Athena::Begin); |     rs.seek(secStart, athena::Begin); | ||||||
|     SCLY scly; |     SCLY scly; | ||||||
|     scly.read(rs); |     scly.read(rs); | ||||||
|     scly.addCMDLRigPairs(pakRouter, addTo); |     scly.addCMDLRigPairs(pakRouter, addTo); | ||||||
| @ -57,18 +53,18 @@ void MREA::AddCMDLRigPairs(PAKEntryReadStream& rs, | |||||||
| 
 | 
 | ||||||
| bool MREA::Extract(const SpecBase& dataSpec, | bool MREA::Extract(const SpecBase& dataSpec, | ||||||
|                    PAKEntryReadStream& rs, |                    PAKEntryReadStream& rs, | ||||||
|                    const HECL::ProjectPath& outPath, |                    const hecl::ProjectPath& outPath, | ||||||
|                    PAKRouter<PAKBridge>& pakRouter, |                    PAKRouter<PAKBridge>& pakRouter, | ||||||
|                    const PAK::Entry& entry, |                    const PAK::Entry& entry, | ||||||
|                    bool force, |                    bool force, | ||||||
|                    std::function<void(const HECL::SystemChar*)>) |                    std::function<void(const hecl::SystemChar*)>) | ||||||
| { | { | ||||||
|     using RigPair = std::pair<CSKR*, CINF*>; |     using RigPair = std::pair<CSKR*, CINF*>; | ||||||
|     RigPair dummy(nullptr, nullptr); |     RigPair dummy(nullptr, nullptr); | ||||||
| 
 | 
 | ||||||
|     /* Rename MREA for consistency */ |     /* Rename MREA for consistency */ | ||||||
|     HECL::ProjectPath mreaPath(outPath.getParentPath(), _S("!area.blend")); |     hecl::ProjectPath mreaPath(outPath.getParentPath(), _S("!area.blend")); | ||||||
|     if (!force && mreaPath.getPathType() == HECL::ProjectPath::Type::File) |     if (!force && mreaPath.getPathType() == hecl::ProjectPath::Type::File) | ||||||
|         return true; |         return true; | ||||||
| 
 | 
 | ||||||
|     /* Do extract */ |     /* Do extract */ | ||||||
| @ -76,12 +72,12 @@ bool MREA::Extract(const SpecBase& dataSpec, | |||||||
|     head.read(rs); |     head.read(rs); | ||||||
|     rs.seekAlign32(); |     rs.seekAlign32(); | ||||||
| 
 | 
 | ||||||
|     HECL::BlenderConnection& conn = HECL::BlenderConnection::SharedConnection(); |     hecl::BlenderConnection& conn = hecl::BlenderConnection::SharedConnection(); | ||||||
|     if (!conn.createBlend(mreaPath, HECL::BlenderConnection::BlendType::Area)) |     if (!conn.createBlend(mreaPath, hecl::BlenderConnection::BlendType::Area)) | ||||||
|         return false; |         return false; | ||||||
| 
 | 
 | ||||||
|     /* Open Py Stream and read sections */ |     /* Open Py Stream and read sections */ | ||||||
|     HECL::BlenderConnection::PyOutStream os = conn.beginPythonOut(true); |     hecl::BlenderConnection::PyOutStream os = conn.beginPythonOut(true); | ||||||
|     os.format("import bpy\n" |     os.format("import bpy\n" | ||||||
|               "import bmesh\n" |               "import bmesh\n" | ||||||
|               "from mathutils import Vector\n" |               "from mathutils import Vector\n" | ||||||
| @ -113,7 +109,7 @@ bool MREA::Extract(const SpecBase& dataSpec, | |||||||
|     atUint64 secStart = rs.position(); |     atUint64 secStart = rs.position(); | ||||||
|     matSet.read(rs); |     matSet.read(rs); | ||||||
|     matSet.readToBlender(os, pakRouter, entry, 0); |     matSet.readToBlender(os, pakRouter, entry, 0); | ||||||
|     rs.seek(secStart + head.secSizes[0], Athena::Begin); |     rs.seek(secStart + head.secSizes[0], athena::Begin); | ||||||
|     std::vector<DNACMDL::VertexAttributes> vertAttribs; |     std::vector<DNACMDL::VertexAttributes> vertAttribs; | ||||||
|     DNACMDL::GetVertexAttributes(matSet, vertAttribs); |     DNACMDL::GetVertexAttributes(matSet, vertAttribs); | ||||||
| 
 | 
 | ||||||
| @ -124,7 +120,7 @@ bool MREA::Extract(const SpecBase& dataSpec, | |||||||
|         MeshHeader mHeader; |         MeshHeader mHeader; | ||||||
|         secStart = rs.position(); |         secStart = rs.position(); | ||||||
|         mHeader.read(rs); |         mHeader.read(rs); | ||||||
|         rs.seek(secStart + head.secSizes[curSec++], Athena::Begin); |         rs.seek(secStart + head.secSizes[curSec++], athena::Begin); | ||||||
|         curSec += DNACMDL::ReadGeomSectionsToBlender<PAKRouter<PAKBridge>, MaterialSet, RigPair, DNACMDL::SurfaceHeader_1> |         curSec += DNACMDL::ReadGeomSectionsToBlender<PAKRouter<PAKBridge>, MaterialSet, RigPair, DNACMDL::SurfaceHeader_1> | ||||||
|                       (os, rs, pakRouter, entry, dummy, true, |                       (os, rs, pakRouter, entry, dummy, true, | ||||||
|                        true, vertAttribs, m, head.secCount, 0, &head.secSizes[curSec]); |                        true, vertAttribs, m, head.secCount, 0, &head.secSizes[curSec]); | ||||||
| @ -139,14 +135,14 @@ bool MREA::Extract(const SpecBase& dataSpec, | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /* Skip AROT */ |     /* Skip AROT */ | ||||||
|     rs.seek(head.secSizes[curSec++], Athena::Current); |     rs.seek(head.secSizes[curSec++], athena::Current); | ||||||
| 
 | 
 | ||||||
|     /* Read SCLY layers */ |     /* Read SCLY layers */ | ||||||
|     secStart = rs.position(); |     secStart = rs.position(); | ||||||
|     SCLY scly; |     SCLY scly; | ||||||
|     scly.read(rs); |     scly.read(rs); | ||||||
|     scly.exportToLayerDirectories(entry, pakRouter, force); |     scly.exportToLayerDirectories(entry, pakRouter, force); | ||||||
|     rs.seek(secStart + head.secSizes[curSec++], Athena::Begin); |     rs.seek(secStart + head.secSizes[curSec++], athena::Begin); | ||||||
| 
 | 
 | ||||||
|     /* Read collision meshes */ |     /* Read collision meshes */ | ||||||
|     DeafBabe collision; |     DeafBabe collision; | ||||||
| @ -154,15 +150,15 @@ bool MREA::Extract(const SpecBase& dataSpec, | |||||||
|     collision.read(rs); |     collision.read(rs); | ||||||
|     DeafBabe::BlenderInit(os); |     DeafBabe::BlenderInit(os); | ||||||
|     collision.sendToBlender(os); |     collision.sendToBlender(os); | ||||||
|     rs.seek(secStart + head.secSizes[curSec++], Athena::Begin); |     rs.seek(secStart + head.secSizes[curSec++], athena::Begin); | ||||||
| 
 | 
 | ||||||
|     /* Skip unknown section */ |     /* Skip unknown section */ | ||||||
|     rs.seek(head.secSizes[curSec++], Athena::Current); |     rs.seek(head.secSizes[curSec++], athena::Current); | ||||||
| 
 | 
 | ||||||
|     /* Read BABEDEAD Lights as Cycles emissives */ |     /* Read BABEDEAD Lights as Cycles emissives */ | ||||||
|     secStart = rs.position(); |     secStart = rs.position(); | ||||||
|     ReadBabeDeadToBlender_1_2(os, rs); |     ReadBabeDeadToBlender_1_2(os, rs); | ||||||
|     rs.seek(secStart + head.secSizes[curSec++], Athena::Begin); |     rs.seek(secStart + head.secSizes[curSec++], athena::Begin); | ||||||
| 
 | 
 | ||||||
|     /* Origins to center of mass */ |     /* Origins to center of mass */ | ||||||
|     os << "bpy.context.scene.layers[1] = True\n" |     os << "bpy.context.scene.layers[1] = True\n" | ||||||
| @ -193,15 +189,15 @@ void MREA::Name(const SpecBase& dataSpec, | |||||||
|     atUint64 secStart = rs.position(); |     atUint64 secStart = rs.position(); | ||||||
|     MaterialSet matSet; |     MaterialSet matSet; | ||||||
|     matSet.read(rs); |     matSet.read(rs); | ||||||
|     matSet.nameTextures(pakRouter, HECL::Format("MREA_%s", entry.id.toString().c_str()).c_str(), -1); |     matSet.nameTextures(pakRouter, hecl::Format("MREA_%s", entry.id.toString().c_str()).c_str(), -1); | ||||||
|     rs.seek(secStart + head.secSizes[0], Athena::Begin); |     rs.seek(secStart + head.secSizes[0], athena::Begin); | ||||||
| 
 | 
 | ||||||
|     /* Skip to SCLY */ |     /* Skip to SCLY */ | ||||||
|     atUint32 curSec = 1; |     atUint32 curSec = 1; | ||||||
|     secStart = rs.position(); |     secStart = rs.position(); | ||||||
|     while (curSec != head.sclySecIdx) |     while (curSec != head.sclySecIdx) | ||||||
|         secStart += head.secSizes[curSec++]; |         secStart += head.secSizes[curSec++]; | ||||||
|     rs.seek(secStart, Athena::Begin); |     rs.seek(secStart, athena::Begin); | ||||||
|     SCLY scly; |     SCLY scly; | ||||||
|     scly.read(rs); |     scly.read(rs); | ||||||
|     scly.nameIDs(pakRouter); |     scly.nameIDs(pakRouter); | ||||||
| @ -209,10 +205,10 @@ void MREA::Name(const SpecBase& dataSpec, | |||||||
|     /* Skip to PATH */ |     /* Skip to PATH */ | ||||||
|     while (curSec != head.pathSecIdx) |     while (curSec != head.pathSecIdx) | ||||||
|         secStart += head.secSizes[curSec++]; |         secStart += head.secSizes[curSec++]; | ||||||
|     rs.seek(secStart, Athena::Begin); |     rs.seek(secStart, athena::Begin); | ||||||
| 
 | 
 | ||||||
|     UniqueID32 pathID(rs); |     UniqueID32 pathID(rs); | ||||||
|     const NOD::Node* node; |     const nod::Node* node; | ||||||
|     PAK::Entry* pathEnt = (PAK::Entry*)pakRouter.lookupEntry(pathID, &node); |     PAK::Entry* pathEnt = (PAK::Entry*)pakRouter.lookupEntry(pathID, &node); | ||||||
|     pathEnt->name = entry.name + "_path"; |     pathEnt->name = entry.name + "_path"; | ||||||
| } | } | ||||||
|  | |||||||
| @ -100,8 +100,8 @@ struct MREA | |||||||
|         Value<float> unk9; |         Value<float> unk9; | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     static void ReadBabeDeadToBlender_1_2(HECL::BlenderConnection::PyOutStream& os, |     static void ReadBabeDeadToBlender_1_2(hecl::BlenderConnection::PyOutStream& os, | ||||||
|                                           Athena::io::IStreamReader& rs); |                                           athena::io::IStreamReader& rs); | ||||||
| 
 | 
 | ||||||
|     static void AddCMDLRigPairs(PAKEntryReadStream& rs, |     static void AddCMDLRigPairs(PAKEntryReadStream& rs, | ||||||
|                                 PAKRouter<PAKBridge>& pakRouter, |                                 PAKRouter<PAKBridge>& pakRouter, | ||||||
| @ -109,11 +109,11 @@ struct MREA | |||||||
| 
 | 
 | ||||||
|     static bool Extract(const SpecBase& dataSpec, |     static bool Extract(const SpecBase& dataSpec, | ||||||
|                         PAKEntryReadStream& rs, |                         PAKEntryReadStream& rs, | ||||||
|                         const HECL::ProjectPath& outPath, |                         const hecl::ProjectPath& outPath, | ||||||
|                         PAKRouter<PAKBridge>& pakRouter, |                         PAKRouter<PAKBridge>& pakRouter, | ||||||
|                         const PAK::Entry& entry, |                         const PAK::Entry& entry, | ||||||
|                         bool, |                         bool, | ||||||
|                         std::function<void(const HECL::SystemChar*)>); |                         std::function<void(const hecl::SystemChar*)>); | ||||||
| 
 | 
 | ||||||
|     static void Name(const SpecBase& dataSpec, |     static void Name(const SpecBase& dataSpec, | ||||||
|                      PAKEntryReadStream& rs, |                      PAKEntryReadStream& rs, | ||||||
|  | |||||||
| @ -8,11 +8,11 @@ namespace DataSpec | |||||||
| namespace DNAMP1 | namespace DNAMP1 | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| void PAK::read(Athena::io::IStreamReader& reader) | void PAK::read(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     atUint32 version = reader.readUint32Big(); |     atUint32 version = reader.readUint32Big(); | ||||||
|     if (version != 0x00030005) |     if (version != 0x00030005) | ||||||
|         Log.report(LogVisor::FatalError, "unexpected PAK magic"); |         Log.report(logvisor::Fatal, "unexpected PAK magic"); | ||||||
|     reader.readUint32Big(); |     reader.readUint32Big(); | ||||||
| 
 | 
 | ||||||
|     atUint32 nameCount = reader.readUint32Big(); |     atUint32 nameCount = reader.readUint32Big(); | ||||||
| @ -62,7 +62,7 @@ void PAK::read(Athena::io::IStreamReader& reader) | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void PAK::write(Athena::io::IStreamWriter& writer) const | void PAK::write(athena::io::IStreamWriter& writer) const | ||||||
| { | { | ||||||
|     writer.writeUint32Big(0x00030005); |     writer.writeUint32Big(0x00030005); | ||||||
|     writer.writeUint32Big(0); |     writer.writeUint32Big(0); | ||||||
| @ -98,15 +98,15 @@ size_t PAK::binarySize(size_t __isz) const | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| std::unique_ptr<atUint8[]> | std::unique_ptr<atUint8[]> | ||||||
| PAK::Entry::getBuffer(const NOD::Node& pak, atUint64& szOut) const | PAK::Entry::getBuffer(const nod::Node& pak, atUint64& szOut) const | ||||||
| { | { | ||||||
|     if (compressed) |     if (compressed) | ||||||
|     { |     { | ||||||
|         std::unique_ptr<NOD::IPartReadStream> strm = pak.beginReadStream(offset); |         std::unique_ptr<nod::IPartReadStream> strm = pak.beginReadStream(offset); | ||||||
| 
 | 
 | ||||||
|         atUint32 decompSz; |         atUint32 decompSz; | ||||||
|         strm->read(&decompSz, 4); |         strm->read(&decompSz, 4); | ||||||
|         decompSz = HECL::SBig(decompSz); |         decompSz = hecl::SBig(decompSz); | ||||||
|         atUint8* buf = new atUint8[decompSz]; |         atUint8* buf = new atUint8[decompSz]; | ||||||
|         atUint8* bufCur = buf; |         atUint8* bufCur = buf; | ||||||
| 
 | 
 | ||||||
| @ -135,7 +135,7 @@ PAK::Entry::getBuffer(const NOD::Node& pak, atUint64& szOut) const | |||||||
|             { |             { | ||||||
|                 atUint16 chunkSz; |                 atUint16 chunkSz; | ||||||
|                 strm->read(&chunkSz, 2); |                 strm->read(&chunkSz, 2); | ||||||
|                 chunkSz = HECL::SBig(chunkSz); |                 chunkSz = hecl::SBig(chunkSz); | ||||||
|                 strm->read(compBuf, chunkSz); |                 strm->read(compBuf, chunkSz); | ||||||
|                 lzo_uint dsz = rem; |                 lzo_uint dsz = rem; | ||||||
|                 lzo1x_decompress(compBuf, chunkSz, bufCur, &dsz, nullptr); |                 lzo1x_decompress(compBuf, chunkSz, bufCur, &dsz, nullptr); | ||||||
|  | |||||||
| @ -3,7 +3,7 @@ | |||||||
| 
 | 
 | ||||||
| #include <unordered_map> | #include <unordered_map> | ||||||
| 
 | 
 | ||||||
| #include <NOD/DiscBase.hpp> | #include <nod/DiscBase.hpp> | ||||||
| #include "../DNACommon/PAK.hpp" | #include "../DNACommon/PAK.hpp" | ||||||
| 
 | 
 | ||||||
| namespace DataSpec | namespace DataSpec | ||||||
| @ -38,8 +38,8 @@ struct PAK : BigDNA | |||||||
|         UniqueResult unique; |         UniqueResult unique; | ||||||
|         std::string name; /* backreferencing name for RE purposes */ |         std::string name; /* backreferencing name for RE purposes */ | ||||||
| 
 | 
 | ||||||
|         std::unique_ptr<atUint8[]> getBuffer(const NOD::Node& pak, atUint64& szOut) const; |         std::unique_ptr<atUint8[]> getBuffer(const nod::Node& pak, atUint64& szOut) const; | ||||||
|         inline PAKEntryReadStream beginReadStream(const NOD::Node& pak, atUint64 off=0) const |         inline PAKEntryReadStream beginReadStream(const nod::Node& pak, atUint64 off=0) const | ||||||
|         { |         { | ||||||
|             atUint64 sz; |             atUint64 sz; | ||||||
|             std::unique_ptr<atUint8[]> buf = getBuffer(pak, sz); |             std::unique_ptr<atUint8[]> buf = getBuffer(pak, sz); | ||||||
|  | |||||||
| @ -1,7 +1,7 @@ | |||||||
| #ifndef _DNAMP1_SCAN_HPP_ | #ifndef _DNAMP1_SCAN_HPP_ | ||||||
| #define _DNAMP1_SCAN_HPP_ | #define _DNAMP1_SCAN_HPP_ | ||||||
| 
 | 
 | ||||||
| #include <Athena/FileWriter.hpp> | #include <athena/FileWriter.hpp> | ||||||
| #include "../DNACommon/DNACommon.hpp" | #include "../DNACommon/DNACommon.hpp" | ||||||
| #include "DNAMP1.hpp" | #include "DNAMP1.hpp" | ||||||
| 
 | 
 | ||||||
| @ -59,7 +59,7 @@ struct SCAN : BigYAML | |||||||
|         Value<float>    interval;     // 0.0 - 1.0
 |         Value<float>    interval;     // 0.0 - 1.0
 | ||||||
|         Value<float>    fadeDuration; // 0.0 - 1.0
 |         Value<float>    fadeDuration; // 0.0 - 1.0
 | ||||||
| 
 | 
 | ||||||
|         void read(Athena::io::IStreamReader& __dna_reader) |         void read(athena::io::IStreamReader& __dna_reader) | ||||||
|         { |         { | ||||||
|             /* texture */ |             /* texture */ | ||||||
|             texture.read(__dna_reader); |             texture.read(__dna_reader); | ||||||
| @ -77,7 +77,7 @@ struct SCAN : BigYAML | |||||||
|             fadeDuration = __dna_reader.readFloatBig(); |             fadeDuration = __dna_reader.readFloatBig(); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         void write(Athena::io::IStreamWriter& __dna_writer) const |         void write(athena::io::IStreamWriter& __dna_writer) const | ||||||
|         { |         { | ||||||
|             /* texture */ |             /* texture */ | ||||||
|             texture.write(__dna_writer); |             texture.write(__dna_writer); | ||||||
| @ -95,7 +95,7 @@ struct SCAN : BigYAML | |||||||
|             __dna_writer.writeFloatBig(fadeDuration); |             __dna_writer.writeFloatBig(fadeDuration); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         void read(Athena::io::YAMLDocReader& __dna_docin) |         void read(athena::io::YAMLDocReader& __dna_docin) | ||||||
|         { |         { | ||||||
|             /* texture */ |             /* texture */ | ||||||
|             __dna_docin.enumerate("texture", texture); |             __dna_docin.enumerate("texture", texture); | ||||||
| @ -120,7 +120,7 @@ struct SCAN : BigYAML | |||||||
|             fadeDuration = __dna_docin.readFloat("fadeDuration"); |             fadeDuration = __dna_docin.readFloat("fadeDuration"); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         void write(Athena::io::YAMLDocWriter& __dna_docout) const |         void write(athena::io::YAMLDocWriter& __dna_docout) const | ||||||
|         { |         { | ||||||
|             /* texture */ |             /* texture */ | ||||||
|             __dna_docout.enumerate("texture", texture); |             __dna_docout.enumerate("texture", texture); | ||||||
| @ -141,7 +141,7 @@ struct SCAN : BigYAML | |||||||
|             __dna_docout.writeFloat("fadeDuration", fadeDuration); |             __dna_docout.writeFloat("fadeDuration", fadeDuration); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         const char* DNAType() { return "Retro::DNAMP1::SCAN::Texture"; } |         const char* DNAType() { return "urde::DNAMP1::SCAN::Texture"; } | ||||||
|         size_t binarySize(size_t __isz) const |         size_t binarySize(size_t __isz) const | ||||||
|         { |         { | ||||||
|             __isz = texture.binarySize(__isz); |             __isz = texture.binarySize(__isz); | ||||||
| @ -152,23 +152,23 @@ struct SCAN : BigYAML | |||||||
| 
 | 
 | ||||||
|     Texture textures[4]; |     Texture textures[4]; | ||||||
| 
 | 
 | ||||||
|     static bool Extract(PAKEntryReadStream& rs, const HECL::ProjectPath& outPath) |     static bool Extract(PAKEntryReadStream& rs, const hecl::ProjectPath& outPath) | ||||||
|     { |     { | ||||||
|         SCAN scan; |         SCAN scan; | ||||||
|         scan.read(rs); |         scan.read(rs); | ||||||
|         FILE* fp = HECL::Fopen(outPath.getAbsolutePath().c_str(), _S("wb")); |         FILE* fp = hecl::Fopen(outPath.getAbsolutePath().c_str(), _S("wb")); | ||||||
|         scan.toYAMLFile(fp); |         scan.toYAMLFile(fp); | ||||||
|         fclose(fp); |         fclose(fp); | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     static bool Cook(const HECL::ProjectPath& inPath, const HECL::ProjectPath& outPath) |     static bool Cook(const hecl::ProjectPath& inPath, const hecl::ProjectPath& outPath) | ||||||
|     { |     { | ||||||
|         SCAN scan; |         SCAN scan; | ||||||
|         FILE* fp = HECL::Fopen(inPath.getAbsolutePath().c_str(), _S("rb")); |         FILE* fp = hecl::Fopen(inPath.getAbsolutePath().c_str(), _S("rb")); | ||||||
|         scan.fromYAMLFile(fp); |         scan.fromYAMLFile(fp); | ||||||
|         fclose(fp); |         fclose(fp); | ||||||
|         Athena::io::FileWriter ws(outPath.getAbsolutePath()); |         athena::io::FileWriter ws(outPath.getAbsolutePath()); | ||||||
|         scan.write(ws); |         scan.write(ws); | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
| @ -183,7 +183,7 @@ struct SCAN : BigYAML | |||||||
|         if (scan.string) |         if (scan.string) | ||||||
|         { |         { | ||||||
|             PAK::Entry* ent = (PAK::Entry*)pakRouter.lookupEntry(scan.string); |             PAK::Entry* ent = (PAK::Entry*)pakRouter.lookupEntry(scan.string); | ||||||
|             ent->name = HECL::Format("SCAN_%s_strg", entry.id.toString().c_str()); |             ent->name = hecl::Format("SCAN_%s_strg", entry.id.toString().c_str()); | ||||||
|         } |         } | ||||||
|         for (int i=0 ; i<4 ; ++i) |         for (int i=0 ; i<4 ; ++i) | ||||||
|         { |         { | ||||||
| @ -191,7 +191,7 @@ struct SCAN : BigYAML | |||||||
|             if (tex.texture) |             if (tex.texture) | ||||||
|             { |             { | ||||||
|                 PAK::Entry* ent = (PAK::Entry*)pakRouter.lookupEntry(tex.texture); |                 PAK::Entry* ent = (PAK::Entry*)pakRouter.lookupEntry(tex.texture); | ||||||
|                 ent->name = HECL::Format("SCAN_%s_tex%d", entry.id.toString().c_str(), i+1); |                 ent->name = hecl::Format("SCAN_%s_tex%d", entry.id.toString().c_str(), i+1); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -6,21 +6,21 @@ namespace DataSpec | |||||||
| namespace DNAMP1 | namespace DNAMP1 | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| void SCLY::read(Athena::io::IStreamReader& rs) | void SCLY::read(athena::io::IStreamReader& rs) | ||||||
| { | { | ||||||
|     fourCC = rs.readUint32Little(); |     fourCC = rs.readUint32Little(); | ||||||
|     version = rs.readUint32Big(); |     version = rs.readUint32Big(); | ||||||
|     layerCount = rs.readUint32Big(); |     layerCount = rs.readUint32Big(); | ||||||
|     rs.enumerateBig(layerSizes, layerCount); |     rs.enumerateBig(layerSizes, layerCount); | ||||||
|     atUint32 i = 0; |     atUint32 i = 0; | ||||||
|     rs.enumerate<ScriptLayer>(layers, layerCount, [&i,this](Athena::io::IStreamReader& rs, ScriptLayer& layer) { |     rs.enumerate<ScriptLayer>(layers, layerCount, [&i,this](athena::io::IStreamReader& rs, ScriptLayer& layer) { | ||||||
|         atUint64 start = rs.position(); |         atUint64 start = rs.position(); | ||||||
|         layer.read(rs); |         layer.read(rs); | ||||||
|         rs.seek(start + layerSizes[i++], Athena::Begin); |         rs.seek(start + layerSizes[i++], athena::Begin); | ||||||
|     }); |     }); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void SCLY::write(Athena::io::IStreamWriter& ws) const | void SCLY::write(athena::io::IStreamWriter& ws) const | ||||||
| { | { | ||||||
|     ws.writeUint32Big(fourCC); |     ws.writeUint32Big(fourCC); | ||||||
|     ws.writeUint32Big(version); |     ws.writeUint32Big(version); | ||||||
| @ -40,14 +40,14 @@ void SCLY::exportToLayerDirectories(const PAK::Entry& entry, PAKRouter<PAKBridge | |||||||
| { | { | ||||||
|     for (atUint32 i = 0; i < layerCount; i++) |     for (atUint32 i = 0; i < layerCount; i++) | ||||||
|     { |     { | ||||||
|         HECL::ProjectPath layerPath = pakRouter.getAreaLayerWorking(entry.id, i); |         hecl::ProjectPath layerPath = pakRouter.getAreaLayerWorking(entry.id, i); | ||||||
|         if (layerPath.getPathType() == HECL::ProjectPath::Type::None) |         if (layerPath.getPathType() == hecl::ProjectPath::Type::None) | ||||||
|             layerPath.makeDir(); |             layerPath.makeDir(); | ||||||
| 
 | 
 | ||||||
|         HECL::ProjectPath yamlFile = HECL::ProjectPath(layerPath, _S("objects.yaml")); |         hecl::ProjectPath yamlFile = hecl::ProjectPath(layerPath, _S("objects.yaml")); | ||||||
|         if (force || yamlFile.getPathType() == HECL::ProjectPath::Type::None) |         if (force || yamlFile.getPathType() == hecl::ProjectPath::Type::None) | ||||||
|         { |         { | ||||||
|             FILE* yaml = HECL::Fopen(yamlFile.getAbsolutePath().c_str(), _S("wb")); |             FILE* yaml = hecl::Fopen(yamlFile.getAbsolutePath().c_str(), _S("wb")); | ||||||
|             layers[i].toYAMLFile(yaml); |             layers[i].toYAMLFile(yaml); | ||||||
|             fclose(yaml); |             fclose(yaml); | ||||||
|         } |         } | ||||||
| @ -80,33 +80,32 @@ void SCLY::ScriptLayer::nameIDs(PAKRouter<PAKBridge>& pakRouter) const | |||||||
|         obj->nameIDs(pakRouter); |         obj->nameIDs(pakRouter); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void SCLY::read(Athena::io::YAMLDocReader& docin) | void SCLY::read(athena::io::YAMLDocReader& docin) | ||||||
| { | { | ||||||
|     fourCC = docin.readUint32("fourCC"); |     fourCC = docin.readUint32("fourCC"); | ||||||
|     version = docin.readUint32("version"); |     version = docin.readUint32("version"); | ||||||
|     layerCount = docin.readUint32("layerCount"); |     layerCount = docin.enumerate("layerSizes", layerSizes); | ||||||
|     docin.enumerate("layerSizes", layerSizes, layerCount); |     docin.enumerate("layers", layers); | ||||||
|     docin.enumerate("layers", layers, layerCount); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void SCLY::write(Athena::io::YAMLDocWriter& docout) const | void SCLY::write(athena::io::YAMLDocWriter& docout) const | ||||||
| { | { | ||||||
|     docout.writeUint32("fourCC", fourCC); |     docout.writeUint32("fourCC", fourCC); | ||||||
|     docout.writeUint32("version", version); |     docout.writeUint32("version", version); | ||||||
|     docout.writeUint32("layerCount", layerCount); |  | ||||||
|     docout.enumerate("layerSizes", layerSizes); |     docout.enumerate("layerSizes", layerSizes); | ||||||
|     docout.enumerate("layers", layers); |     docout.enumerate("layers", layers); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| const char* SCLY::DNAType() | const char* SCLY::DNAType() | ||||||
| { | { | ||||||
|     return "Retro::DNAMP1::SCLY"; |     return "urde::DNAMP1::SCLY"; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void SCLY::ScriptLayer::read(Athena::io::IStreamReader& rs) | void SCLY::ScriptLayer::read(athena::io::IStreamReader& rs) | ||||||
| { | { | ||||||
|     unknown = rs.readUByte(); |     unknown = rs.readUByte(); | ||||||
|     objectCount = rs.readUint32Big(); |     objectCount = rs.readUint32Big(); | ||||||
|  |     objects.clear(); | ||||||
|     objects.reserve(objectCount); |     objects.reserve(objectCount); | ||||||
|     for (atUint32 i = 0; i < objectCount; i++) |     for (atUint32 i = 0; i < objectCount; i++) | ||||||
|     { |     { | ||||||
| @ -125,20 +124,22 @@ void SCLY::ScriptLayer::read(Athena::io::IStreamReader& rs) | |||||||
|             objects.push_back(std::move(obj)); |             objects.push_back(std::move(obj)); | ||||||
|             size_t actualLen = rs.position() - start; |             size_t actualLen = rs.position() - start; | ||||||
|             if (actualLen != len) |             if (actualLen != len) | ||||||
|                 Log.report(LogVisor::FatalError, _S("Error while reading object of type 0x%.2X, did not read the expected amount of data, read 0x%x, expected 0x%x"), (atUint32)type, actualLen, len); |                 Log.report(logvisor::Fatal, _S("Error while reading object of type 0x%.2X, did not read the expected amount of data, read 0x%x, expected 0x%x"), (atUint32)type, actualLen, len); | ||||||
|             rs.seek(start + len, Athena::Begin); |             rs.seek(start + len, athena::Begin); | ||||||
|         } |         } | ||||||
|         else |         else | ||||||
|             Log.report(LogVisor::FatalError, _S("Unable to find type 0x%X in object database"), (atUint32)type); |             Log.report(logvisor::Fatal, _S("Unable to find type 0x%X in object database"), (atUint32)type); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void SCLY::ScriptLayer::read(Athena::io::YAMLDocReader& rs) | void SCLY::ScriptLayer::read(athena::io::YAMLDocReader& rs) | ||||||
| { | { | ||||||
|     unknown = rs.readUByte("unknown"); |     unknown = rs.readUByte("unknown"); | ||||||
|     objectCount = rs.readUint32("objectCount"); |     size_t objCount; | ||||||
|     objects.reserve(objectCount); |     rs.enterSubVector("objects", objCount); | ||||||
|     rs.enterSubVector("objects"); |     objectCount = objCount; | ||||||
|  |     objects.clear(); | ||||||
|  |     objects.reserve(objCount); | ||||||
|     for (atUint32 i = 0; i < objectCount; i++) |     for (atUint32 i = 0; i < objectCount; i++) | ||||||
|     { |     { | ||||||
|         rs.enterSubRecord(nullptr); |         rs.enterSubRecord(nullptr); | ||||||
| @ -154,14 +155,14 @@ void SCLY::ScriptLayer::read(Athena::io::YAMLDocReader& rs) | |||||||
|             objects.push_back(std::move(obj)); |             objects.push_back(std::move(obj)); | ||||||
|         } |         } | ||||||
|         else |         else | ||||||
|             Log.report(LogVisor::FatalError, _S("Unable to find type 0x%X in object database"), (atUint32)type); |             Log.report(logvisor::Fatal, _S("Unable to find type 0x%X in object database"), (atUint32)type); | ||||||
| 
 | 
 | ||||||
|         rs.leaveSubRecord(); |         rs.leaveSubRecord(); | ||||||
|     } |     } | ||||||
|     rs.leaveSubVector(); |     rs.leaveSubVector(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void SCLY::ScriptLayer::write(Athena::io::IStreamWriter& ws) const | void SCLY::ScriptLayer::write(athena::io::IStreamWriter& ws) const | ||||||
| { | { | ||||||
|     ws.writeUByte(unknown); |     ws.writeUByte(unknown); | ||||||
|     ws.writeUint32Big(objectCount); |     ws.writeUint32Big(objectCount); | ||||||
| @ -183,10 +184,9 @@ size_t SCLY::ScriptLayer::binarySize(size_t __isz) const | |||||||
|     return __isz; |     return __isz; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void SCLY::ScriptLayer::write(Athena::io::YAMLDocWriter& ws) const | void SCLY::ScriptLayer::write(athena::io::YAMLDocWriter& ws) const | ||||||
| { | { | ||||||
|     ws.writeUByte("unknown", unknown); |     ws.writeUByte("unknown", unknown); | ||||||
|     ws.writeUint32("objectCount", objectCount); |  | ||||||
|     ws.enterSubVector("objects"); |     ws.enterSubVector("objects"); | ||||||
|     for (const std::unique_ptr<IScriptObject>& obj : objects) |     for (const std::unique_ptr<IScriptObject>& obj : objects) | ||||||
|     { |     { | ||||||
| @ -200,7 +200,7 @@ void SCLY::ScriptLayer::write(Athena::io::YAMLDocWriter& ws) const | |||||||
| 
 | 
 | ||||||
| const char* SCLY::ScriptLayer::DNAType() | const char* SCLY::ScriptLayer::DNAType() | ||||||
| { | { | ||||||
|     return "Retro::DNAMP1::SCLY::ScriptLayer"; |     return "urde::DNAMP1::SCLY::ScriptLayer"; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -26,8 +26,8 @@ struct SCLY : BigYAML | |||||||
|         Value<atUint8> unknown; |         Value<atUint8> unknown; | ||||||
|         Value<atUint32> objectCount; |         Value<atUint32> objectCount; | ||||||
|         Vector<std::unique_ptr<IScriptObject>, DNA_COUNT(objectCount)> objects; |         Vector<std::unique_ptr<IScriptObject>, DNA_COUNT(objectCount)> objects; | ||||||
|         void read(Athena::io::IStreamReader &rs); |         void read(athena::io::IStreamReader &rs); | ||||||
|         void write(Athena::io::IStreamWriter &ws) const; |         void write(athena::io::IStreamWriter &ws) const; | ||||||
|         size_t binarySize(size_t __isz) const; |         size_t binarySize(size_t __isz) const; | ||||||
|         void addCMDLRigPairs(PAKRouter<PAKBridge>& pakRouter, |         void addCMDLRigPairs(PAKRouter<PAKBridge>& pakRouter, | ||||||
|                 std::unordered_map<UniqueID32, std::pair<UniqueID32, UniqueID32>>& addTo) const; |                 std::unordered_map<UniqueID32, std::pair<UniqueID32, UniqueID32>>& addTo) const; | ||||||
| @ -35,8 +35,8 @@ struct SCLY : BigYAML | |||||||
|     }; |     }; | ||||||
|     Vector<ScriptLayer, DNA_COUNT(layerCount)> layers; |     Vector<ScriptLayer, DNA_COUNT(layerCount)> layers; | ||||||
| 
 | 
 | ||||||
|     void read(Athena::io::IStreamReader &rs); |     void read(athena::io::IStreamReader &rs); | ||||||
|     void write(Athena::io::IStreamWriter &ws) const; |     void write(athena::io::IStreamWriter &ws) const; | ||||||
|     size_t binarySize(size_t __isz) const; |     size_t binarySize(size_t __isz) const; | ||||||
| 
 | 
 | ||||||
|     void exportToLayerDirectories(const PAK::Entry &, PAKRouter<PAKBridge>&, bool) const; |     void exportToLayerDirectories(const PAK::Entry &, PAKRouter<PAKBridge>&, bool) const; | ||||||
|  | |||||||
| @ -6,7 +6,7 @@ namespace DataSpec | |||||||
| namespace DNAMP1 | namespace DNAMP1 | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| void STRG::_read(Athena::io::IStreamReader& reader) | void STRG::_read(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     atUint32 langCount = reader.readUint32Big(); |     atUint32 langCount = reader.readUint32Big(); | ||||||
|     atUint32 strCount = reader.readUint32Big(); |     atUint32 strCount = reader.readUint32Big(); | ||||||
| @ -38,20 +38,20 @@ void STRG::_read(Athena::io::IStreamReader& reader) | |||||||
|         langMap.emplace(item.first, &item.second); |         langMap.emplace(item.first, &item.second); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void STRG::read(Athena::io::IStreamReader& reader) | void STRG::read(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     atUint32 magic = reader.readUint32Big(); |     atUint32 magic = reader.readUint32Big(); | ||||||
|     if (magic != 0x87654321) |     if (magic != 0x87654321) | ||||||
|         Log.report(LogVisor::Error, "invalid STRG magic"); |         Log.report(logvisor::Error, "invalid STRG magic"); | ||||||
| 
 | 
 | ||||||
|     atUint32 version = reader.readUint32Big(); |     atUint32 version = reader.readUint32Big(); | ||||||
|     if (version != 0) |     if (version != 0) | ||||||
|         Log.report(LogVisor::Error, "invalid STRG version"); |         Log.report(logvisor::Error, "invalid STRG version"); | ||||||
| 
 | 
 | ||||||
|     _read(reader); |     _read(reader); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void STRG::write(Athena::io::IStreamWriter& writer) const | void STRG::write(athena::io::IStreamWriter& writer) const | ||||||
| { | { | ||||||
|     writer.writeUint32Big(0x87654321); |     writer.writeUint32Big(0x87654321); | ||||||
|     writer.writeUint32Big(0); |     writer.writeUint32Big(0); | ||||||
| @ -131,9 +131,9 @@ size_t STRG::binarySize(size_t __isz) const | |||||||
|     return __isz; |     return __isz; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void STRG::read(Athena::io::YAMLDocReader& reader) | void STRG::read(athena::io::YAMLDocReader& reader) | ||||||
| { | { | ||||||
|     const Athena::io::YAMLNode* root = reader.getRootNode(); |     const athena::io::YAMLNode* root = reader.getRootNode(); | ||||||
| 
 | 
 | ||||||
|     /* Validate Pass */ |     /* Validate Pass */ | ||||||
|     if (root->m_type == YAML_MAPPING_NODE) |     if (root->m_type == YAML_MAPPING_NODE) | ||||||
| @ -142,19 +142,19 @@ void STRG::read(Athena::io::YAMLDocReader& reader) | |||||||
|         { |         { | ||||||
|             if (lang.first.size() != 4) |             if (lang.first.size() != 4) | ||||||
|             { |             { | ||||||
|                 Log.report(LogVisor::Warning, "STRG language string '%s' must be exactly 4 characters; skipping", lang.first.c_str()); |                 Log.report(logvisor::Warning, "STRG language string '%s' must be exactly 4 characters; skipping", lang.first.c_str()); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (lang.second->m_type != YAML_SEQUENCE_NODE) |             if (lang.second->m_type != YAML_SEQUENCE_NODE) | ||||||
|             { |             { | ||||||
|                 Log.report(LogVisor::Warning, "STRG language string '%s' must contain a sequence; skipping", lang.first.c_str()); |                 Log.report(logvisor::Warning, "STRG language string '%s' must contain a sequence; skipping", lang.first.c_str()); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             for (const auto& str : lang.second->m_seqChildren) |             for (const auto& str : lang.second->m_seqChildren) | ||||||
|             { |             { | ||||||
|                 if (str->m_type != YAML_SCALAR_NODE) |                 if (str->m_type != YAML_SCALAR_NODE) | ||||||
|                 { |                 { | ||||||
|                     Log.report(LogVisor::Warning, "STRG language '%s' must contain all scalars; skipping", lang.first.c_str()); |                     Log.report(logvisor::Warning, "STRG language '%s' must contain all scalars; skipping", lang.first.c_str()); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @ -162,7 +162,7 @@ void STRG::read(Athena::io::YAMLDocReader& reader) | |||||||
|     } |     } | ||||||
|     else |     else | ||||||
|     { |     { | ||||||
|         Log.report(LogVisor::Warning, "STRG must have a mapping root node; skipping"); |         Log.report(logvisor::Warning, "STRG must have a mapping root node; skipping"); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -172,7 +172,7 @@ void STRG::read(Athena::io::YAMLDocReader& reader) | |||||||
|     { |     { | ||||||
|         std::vector<std::wstring> strs; |         std::vector<std::wstring> strs; | ||||||
|         for (const auto& str : lang.second->m_seqChildren) |         for (const auto& str : lang.second->m_seqChildren) | ||||||
|             strs.emplace_back(HECL::UTF8ToWide(str->m_scalarString)); |             strs.emplace_back(hecl::UTF8ToWide(str->m_scalarString)); | ||||||
|         langs.emplace_back(FourCC(lang.first.c_str()), strs); |         langs.emplace_back(FourCC(lang.first.c_str()), strs); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -182,7 +182,7 @@ void STRG::read(Athena::io::YAMLDocReader& reader) | |||||||
|         langMap.emplace(item.first, &item.second); |         langMap.emplace(item.first, &item.second); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void STRG::write(Athena::io::YAMLDocWriter& writer) const | void STRG::write(athena::io::YAMLDocWriter& writer) const | ||||||
| { | { | ||||||
|     for (const auto& lang : langs) |     for (const auto& lang : langs) | ||||||
|     { |     { | ||||||
| @ -195,7 +195,7 @@ void STRG::write(Athena::io::YAMLDocWriter& writer) const | |||||||
| 
 | 
 | ||||||
| const char* STRG::DNAType() | const char* STRG::DNAType() | ||||||
| { | { | ||||||
|     return "Retro::DNAMP1::STRG"; |     return "urde::DNAMP1::STRG"; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -15,7 +15,7 @@ struct STRG : ISTRG | |||||||
| { | { | ||||||
|     DECL_YAML |     DECL_YAML | ||||||
|     Delete expl; |     Delete expl; | ||||||
|     void _read(Athena::io::IStreamReader& reader); |     void _read(athena::io::IStreamReader& reader); | ||||||
|     std::vector<std::pair<FourCC, std::vector<std::wstring>>> langs; |     std::vector<std::pair<FourCC, std::vector<std::wstring>>> langs; | ||||||
|     std::unordered_map<FourCC, std::vector<std::wstring>*> langMap; |     std::unordered_map<FourCC, std::vector<std::wstring>*> langMap; | ||||||
| 
 | 
 | ||||||
| @ -36,7 +36,7 @@ struct STRG : ISTRG | |||||||
|     { |     { | ||||||
|         auto search = langMap.find(lang); |         auto search = langMap.find(lang); | ||||||
|         if (search != langMap.end()) |         if (search != langMap.end()) | ||||||
|             return HECL::WideToUTF8(search->second->at(idx)); |             return hecl::WideToUTF8(search->second->at(idx)); | ||||||
|         return std::string(); |         return std::string(); | ||||||
|     } |     } | ||||||
|     inline std::wstring getUTF16(const FourCC& lang, size_t idx) const |     inline std::wstring getUTF16(const FourCC& lang, size_t idx) const | ||||||
| @ -46,35 +46,35 @@ struct STRG : ISTRG | |||||||
|             return search->second->at(idx); |             return search->second->at(idx); | ||||||
|         return std::wstring(); |         return std::wstring(); | ||||||
|     } |     } | ||||||
|     inline HECL::SystemString getSystemString(const FourCC& lang, size_t idx) const |     inline hecl::SystemString getSystemString(const FourCC& lang, size_t idx) const | ||||||
|     { |     { | ||||||
|         auto search = langMap.find(lang); |         auto search = langMap.find(lang); | ||||||
|         if (search != langMap.end()) |         if (search != langMap.end()) | ||||||
| #if HECL_UCS2 | #if HECL_UCS2 | ||||||
|             return search->second->at(idx); |             return search->second->at(idx); | ||||||
| #else | #else | ||||||
|             return HECL::WideToUTF8(search->second->at(idx)); |             return hecl::WideToUTF8(search->second->at(idx)); | ||||||
| #endif | #endif | ||||||
|         return HECL::SystemString(); |         return hecl::SystemString(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     static bool Extract(PAKEntryReadStream& rs, const HECL::ProjectPath& outPath) |     static bool Extract(PAKEntryReadStream& rs, const hecl::ProjectPath& outPath) | ||||||
|     { |     { | ||||||
|         STRG strg; |         STRG strg; | ||||||
|         strg.read(rs); |         strg.read(rs); | ||||||
|         FILE* fp = HECL::Fopen(outPath.getAbsolutePath().c_str(), _S("wb")); |         FILE* fp = hecl::Fopen(outPath.getAbsolutePath().c_str(), _S("wb")); | ||||||
|         strg.toYAMLFile(fp); |         strg.toYAMLFile(fp); | ||||||
|         fclose(fp); |         fclose(fp); | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     static bool Cook(const HECL::ProjectPath& inPath, const HECL::ProjectPath& outPath) |     static bool Cook(const hecl::ProjectPath& inPath, const hecl::ProjectPath& outPath) | ||||||
|     { |     { | ||||||
|         STRG strg; |         STRG strg; | ||||||
|         FILE* fp = HECL::Fopen(inPath.getAbsolutePath().c_str(), _S("rb")); |         FILE* fp = hecl::Fopen(inPath.getAbsolutePath().c_str(), _S("rb")); | ||||||
|         strg.fromYAMLFile(fp); |         strg.fromYAMLFile(fp); | ||||||
|         fclose(fp); |         fclose(fp); | ||||||
|         Athena::io::FileWriter ws(outPath.getAbsolutePath()); |         athena::io::FileWriter ws(outPath.getAbsolutePath()); | ||||||
|         strg.write(ws); |         strg.write(ws); | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -31,7 +31,7 @@ struct Oculus : IScriptObject | |||||||
|     /* Trilogy addition */ |     /* Trilogy addition */ | ||||||
|     Value<float> unknown8; |     Value<float> unknown8; | ||||||
| 
 | 
 | ||||||
|     void read(Athena::io::IStreamReader& __dna_reader) |     void read(athena::io::IStreamReader& __dna_reader) | ||||||
|     { |     { | ||||||
|         IScriptObject::read(__dna_reader); |         IScriptObject::read(__dna_reader); | ||||||
|         /* name */ |         /* name */ | ||||||
| @ -71,7 +71,7 @@ struct Oculus : IScriptObject | |||||||
|             unknown8 = 0.0; |             unknown8 = 0.0; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void write(Athena::io::IStreamWriter& __dna_writer) const |     void write(athena::io::IStreamWriter& __dna_writer) const | ||||||
|     { |     { | ||||||
|         IScriptObject::write(__dna_writer); |         IScriptObject::write(__dna_writer); | ||||||
|         /* name */ |         /* name */ | ||||||
| @ -109,7 +109,7 @@ struct Oculus : IScriptObject | |||||||
|             __dna_writer.writeFloatBig(unknown8); |             __dna_writer.writeFloatBig(unknown8); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void read(Athena::io::YAMLDocReader& __dna_docin) |     void read(athena::io::YAMLDocReader& __dna_docin) | ||||||
|     { |     { | ||||||
|         IScriptObject::read(__dna_docin); |         IScriptObject::read(__dna_docin); | ||||||
|         /* name */ |         /* name */ | ||||||
| @ -149,7 +149,7 @@ struct Oculus : IScriptObject | |||||||
|             unknown8 = 0.0; |             unknown8 = 0.0; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void write(Athena::io::YAMLDocWriter& __dna_docout) const |     void write(athena::io::YAMLDocWriter& __dna_docout) const | ||||||
|     { |     { | ||||||
|         IScriptObject::write(__dna_docout); |         IScriptObject::write(__dna_docout); | ||||||
|         /* name */ |         /* name */ | ||||||
| @ -189,7 +189,7 @@ struct Oculus : IScriptObject | |||||||
| 
 | 
 | ||||||
|     static const char* DNAType() |     static const char* DNAType() | ||||||
|     { |     { | ||||||
|         return "Retro::DNAMP1::Oculus"; |         return "urde::DNAMP1::Oculus"; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void addCMDLRigPairs(PAKRouter<PAKBridge>& pakRouter, |     void addCMDLRigPairs(PAKRouter<PAKBridge>& pakRouter, | ||||||
|  | |||||||
| @ -10,7 +10,7 @@ UniqueID32 AnimationParameters::getCINF(PAKRouter<PAKBridge>& pakRouter) const | |||||||
| { | { | ||||||
|     if (!animationCharacterSet) |     if (!animationCharacterSet) | ||||||
|         return UniqueID32(); |         return UniqueID32(); | ||||||
|     const NOD::Node* node; |     const nod::Node* node; | ||||||
|     const PAK::Entry* ancsEnt = pakRouter.lookupEntry(animationCharacterSet, &node); |     const PAK::Entry* ancsEnt = pakRouter.lookupEntry(animationCharacterSet, &node); | ||||||
|     ANCS ancs; |     ANCS ancs; | ||||||
|     { |     { | ||||||
|  | |||||||
| @ -124,7 +124,7 @@ struct Ridley : IScriptObject | |||||||
|     /* Trilogy addition */ |     /* Trilogy addition */ | ||||||
|     DamageInfo damageInfo9; |     DamageInfo damageInfo9; | ||||||
| 
 | 
 | ||||||
|     void read(Athena::io::IStreamReader& __dna_reader) |     void read(athena::io::IStreamReader& __dna_reader) | ||||||
|     { |     { | ||||||
|         IScriptObject::read(__dna_reader); |         IScriptObject::read(__dna_reader); | ||||||
|         /* name */ |         /* name */ | ||||||
| @ -234,7 +234,7 @@ struct Ridley : IScriptObject | |||||||
|             damageInfo9.read(__dna_reader); |             damageInfo9.read(__dna_reader); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void write(Athena::io::IStreamWriter& __dna_writer) const |     void write(athena::io::IStreamWriter& __dna_writer) const | ||||||
|     { |     { | ||||||
|         IScriptObject::write(__dna_writer); |         IScriptObject::write(__dna_writer); | ||||||
|         /* name */ |         /* name */ | ||||||
| @ -344,7 +344,7 @@ struct Ridley : IScriptObject | |||||||
|             damageInfo9.write(__dna_writer); |             damageInfo9.write(__dna_writer); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void read(Athena::io::YAMLDocReader& __dna_docin) |     void read(athena::io::YAMLDocReader& __dna_docin) | ||||||
|     { |     { | ||||||
|         IScriptObject::read(__dna_docin); |         IScriptObject::read(__dna_docin); | ||||||
|         /* name */ |         /* name */ | ||||||
| @ -454,7 +454,7 @@ struct Ridley : IScriptObject | |||||||
|             __dna_docin.enumerate("damageInfo9", damageInfo9); |             __dna_docin.enumerate("damageInfo9", damageInfo9); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void write(Athena::io::YAMLDocWriter& __dna_docout) const |     void write(athena::io::YAMLDocWriter& __dna_docout) const | ||||||
|     { |     { | ||||||
|         IScriptObject::write(__dna_docout); |         IScriptObject::write(__dna_docout); | ||||||
|         /* name */ |         /* name */ | ||||||
| @ -566,7 +566,7 @@ struct Ridley : IScriptObject | |||||||
| 
 | 
 | ||||||
|     static const char* DNAType() |     static const char* DNAType() | ||||||
|     { |     { | ||||||
|         return "Retro::DNAMP1::Ridley"; |         return "urde::DNAMP1::Ridley"; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void addCMDLRigPairs(PAKRouter<PAKBridge>& pakRouter, |     void addCMDLRigPairs(PAKRouter<PAKBridge>& pakRouter, | ||||||
|  | |||||||
| @ -41,7 +41,7 @@ struct WorldTeleporter : IScriptObject | |||||||
|     Value<float> unknown15; |     Value<float> unknown15; | ||||||
|     Value<float> unknown16; |     Value<float> unknown16; | ||||||
|      |      | ||||||
|     void read(Athena::io::IStreamReader& __dna_reader) |     void read(athena::io::IStreamReader& __dna_reader) | ||||||
|     { |     { | ||||||
|         IScriptObject::read(__dna_reader); |         IScriptObject::read(__dna_reader); | ||||||
|         /* name */ |         /* name */ | ||||||
| @ -104,7 +104,7 @@ struct WorldTeleporter : IScriptObject | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     void write(Athena::io::IStreamWriter& __dna_writer) const |     void write(athena::io::IStreamWriter& __dna_writer) const | ||||||
|     { |     { | ||||||
|         IScriptObject::write(__dna_writer); |         IScriptObject::write(__dna_writer); | ||||||
|         /* name */ |         /* name */ | ||||||
| @ -160,7 +160,7 @@ struct WorldTeleporter : IScriptObject | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     void read(Athena::io::YAMLDocReader& __dna_docin) |     void read(athena::io::YAMLDocReader& __dna_docin) | ||||||
|     { |     { | ||||||
|         IScriptObject::read(__dna_docin); |         IScriptObject::read(__dna_docin); | ||||||
|         /* name */ |         /* name */ | ||||||
| @ -223,7 +223,7 @@ struct WorldTeleporter : IScriptObject | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|      |      | ||||||
|     void write(Athena::io::YAMLDocWriter& __dna_docout) const |     void write(athena::io::YAMLDocWriter& __dna_docout) const | ||||||
|     { |     { | ||||||
|         IScriptObject::write(__dna_docout); |         IScriptObject::write(__dna_docout); | ||||||
|         /* name */ |         /* name */ | ||||||
| @ -281,7 +281,7 @@ struct WorldTeleporter : IScriptObject | |||||||
|      |      | ||||||
|     static const char* DNAType() |     static const char* DNAType() | ||||||
|     { |     { | ||||||
|         return "Retro::DNAMP1::WorldTeleporter"; |         return "urde::DNAMP1::WorldTeleporter"; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void nameIDs(PAKRouter<PAKBridge>& pakRouter) const |     void nameIDs(PAKRouter<PAKBridge>& pakRouter) const | ||||||
|  | |||||||
| @ -15,7 +15,7 @@ struct CTweakGame : ITweakGame | |||||||
|     String<-1> m_ruinsArea; // ????
 |     String<-1> m_ruinsArea; // ????
 | ||||||
| 
 | 
 | ||||||
|     virtual const std::string& GetWorldPrefix() const { return m_worldPrefix; } |     virtual const std::string& GetWorldPrefix() const { return m_worldPrefix; } | ||||||
|     CTweakGame(Athena::io::IStreamReader& in) { this->read(in); } |     CTweakGame(athena::io::IStreamReader& in) { this->read(in); } | ||||||
| }; | }; | ||||||
| } | } | ||||||
| } | } | ||||||
|  | |||||||
| @ -15,7 +15,7 @@ struct CTweakParticle : ITweakParticle | |||||||
|     String<-1> m_powerBeam; |     String<-1> m_powerBeam; | ||||||
|     String<-1> m_genThrust; |     String<-1> m_genThrust; | ||||||
| 
 | 
 | ||||||
|     CTweakParticle(Athena::io::IStreamReader& reader) { this->read(reader); } |     CTweakParticle(athena::io::IStreamReader& reader) { this->read(reader); } | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -15,7 +15,7 @@ struct CTweakPlayer : ITweakPlayer | |||||||
|     Value<float> m_rightDiv; |     Value<float> m_rightDiv; | ||||||
|     float GetLeftLogicalThreshold() const {return m_leftDiv;} |     float GetLeftLogicalThreshold() const {return m_leftDiv;} | ||||||
|     float GetRightLogicalThreshold() const {return m_rightDiv;} |     float GetRightLogicalThreshold() const {return m_rightDiv;} | ||||||
|     CTweakPlayer(Athena::io::IStreamReader& reader) {this->read(reader);} |     CTweakPlayer(athena::io::IStreamReader& reader) {this->read(reader);} | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -13,7 +13,7 @@ struct CTweakPlayerControl : ITweakPlayerControl | |||||||
|     DECL_YAML |     DECL_YAML | ||||||
|     Vector<atUint32, DNA_COUNT(65)> m_mappings; |     Vector<atUint32, DNA_COUNT(65)> m_mappings; | ||||||
|     atUint32 GetMapping(atUint32 command) const {return m_mappings[command];} |     atUint32 GetMapping(atUint32 command) const {return m_mappings[command];} | ||||||
|     CTweakPlayerControl(Athena::io::IStreamReader& reader) {this->read(reader);} |     CTweakPlayerControl(athena::io::IStreamReader& reader) {this->read(reader);} | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -5,7 +5,7 @@ namespace DataSpec | |||||||
| namespace DNAMP2 | namespace DNAMP2 | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| void ANCS::CharacterSet::CharacterInfo::read(Athena::io::IStreamReader& reader) | void ANCS::CharacterSet::CharacterInfo::read(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     idx = reader.readUint32Big(); |     idx = reader.readUint32Big(); | ||||||
|     atUint16 sectionCount = reader.readUint16Big(); |     atUint16 sectionCount = reader.readUint16Big(); | ||||||
| @ -78,7 +78,7 @@ void ANCS::CharacterSet::CharacterInfo::read(Athena::io::IStreamReader& reader) | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::CharacterSet::CharacterInfo::write(Athena::io::IStreamWriter& writer) const | void ANCS::CharacterSet::CharacterInfo::write(athena::io::IStreamWriter& writer) const | ||||||
| { | { | ||||||
|     writer.writeUint32Big(idx); |     writer.writeUint32Big(idx); | ||||||
| 
 | 
 | ||||||
| @ -238,7 +238,7 @@ size_t ANCS::CharacterSet::CharacterInfo::binarySize(size_t __isz) const | |||||||
|     return __isz; |     return __isz; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::CharacterSet::CharacterInfo::read(Athena::io::YAMLDocReader& reader) | void ANCS::CharacterSet::CharacterInfo::read(athena::io::YAMLDocReader& reader) | ||||||
| { | { | ||||||
|     idx = reader.readUint32("idx"); |     idx = reader.readUint32("idx"); | ||||||
|     atUint16 sectionCount = reader.readUint16("sectionCount"); |     atUint16 sectionCount = reader.readUint16("sectionCount"); | ||||||
| @ -247,43 +247,34 @@ void ANCS::CharacterSet::CharacterInfo::read(Athena::io::YAMLDocReader& reader) | |||||||
|     reader.enumerate("cskr", cskr); |     reader.enumerate("cskr", cskr); | ||||||
|     reader.enumerate("cinf", cinf); |     reader.enumerate("cinf", cinf); | ||||||
| 
 | 
 | ||||||
|     atUint32 animationCount = reader.readUint32("animationCount"); |     reader.enumerate("animations", animations); | ||||||
|     reader.enumerate("animations", animations, animationCount); |  | ||||||
| 
 | 
 | ||||||
|     reader.enumerate("pasDatabase", pasDatabase); |     reader.enumerate("pasDatabase", pasDatabase); | ||||||
| 
 | 
 | ||||||
|     atUint32 partCount = reader.readUint32("partCount"); |     reader.enumerate("part", partResData.part); | ||||||
|     reader.enumerate("part", partResData.part, partCount); |  | ||||||
| 
 | 
 | ||||||
|     atUint32 swhcCount = reader.readUint32("swhcCount"); |     reader.enumerate("swhc", partResData.swhc); | ||||||
|     reader.enumerate("swhc", partResData.swhc, swhcCount); |  | ||||||
| 
 | 
 | ||||||
|     atUint32 unkCount = reader.readUint32("unkCount"); |     reader.enumerate("unk", partResData.unk); | ||||||
|     reader.enumerate("unk", partResData.unk, unkCount); |  | ||||||
| 
 | 
 | ||||||
|     atUint32 elscCount = reader.readUint32("elscCount"); |     reader.enumerate("elsc", partResData.elsc); | ||||||
|     reader.enumerate("elsc", partResData.elsc, elscCount); |  | ||||||
| 
 | 
 | ||||||
|     atUint32 spscCount = reader.readUint32("spscCount"); |     reader.enumerate("spsc", partResData.spsc); | ||||||
|     reader.enumerate("spsc", partResData.spsc, spscCount); |  | ||||||
| 
 | 
 | ||||||
|     atUint32 unk2Count = reader.readUint32("unk2Count"); |     reader.enumerate("unk2", partResData.unk2); | ||||||
|     reader.enumerate("unk2", partResData.unk2, unk2Count); |  | ||||||
| 
 | 
 | ||||||
|     unk1 = reader.readUint32("unk1"); |     unk1 = reader.readUint32("unk1"); | ||||||
| 
 | 
 | ||||||
|     animAABBs.clear(); |     animAABBs.clear(); | ||||||
|     if (sectionCount > 1) |     if (sectionCount > 1) | ||||||
|     { |     { | ||||||
|         atUint32 aabbCount = reader.readUint32("animAABBCount"); |         reader.enumerate("part", animAABBs); | ||||||
|         reader.enumerate("part", animAABBs, aabbCount); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     effects.clear(); |     effects.clear(); | ||||||
|     if (sectionCount > 2) |     if (sectionCount > 2) | ||||||
|     { |     { | ||||||
|         atUint32 effectCount = reader.readUint32("effectCount"); |         reader.enumerate("effects", effects); | ||||||
|         reader.enumerate("effects", effects, effectCount); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (sectionCount > 3) |     if (sectionCount > 3) | ||||||
| @ -295,8 +286,7 @@ void ANCS::CharacterSet::CharacterInfo::read(Athena::io::YAMLDocReader& reader) | |||||||
|     animIdxs.clear(); |     animIdxs.clear(); | ||||||
|     if (sectionCount > 4) |     if (sectionCount > 4) | ||||||
|     { |     { | ||||||
|         atUint32 animIdxCount = reader.readUint32("animIdxCount"); |         reader.enumerate("animIdxs", animIdxs); | ||||||
|         reader.enumerate("animIdxs", animIdxs, animIdxCount); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     extents.clear(); |     extents.clear(); | ||||||
| @ -304,12 +294,11 @@ void ANCS::CharacterSet::CharacterInfo::read(Athena::io::YAMLDocReader& reader) | |||||||
|     { |     { | ||||||
|         unk4 = reader.readUint32("unk4"); |         unk4 = reader.readUint32("unk4"); | ||||||
|         unk5 = reader.readUByte("unk5"); |         unk5 = reader.readUByte("unk5"); | ||||||
|         atUint32 extentsCount = reader.readUint32("extentsCount"); |         reader.enumerate("extents", extents); | ||||||
|         reader.enumerate("extents", extents, extentsCount); |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::CharacterSet::CharacterInfo::write(Athena::io::YAMLDocWriter& writer) const | void ANCS::CharacterSet::CharacterInfo::write(athena::io::YAMLDocWriter& writer) const | ||||||
| { | { | ||||||
|     writer.writeUint32("idx", idx); |     writer.writeUint32("idx", idx); | ||||||
| 
 | 
 | ||||||
| @ -335,40 +324,31 @@ void ANCS::CharacterSet::CharacterInfo::write(Athena::io::YAMLDocWriter& writer) | |||||||
|     writer.enumerate("cskr", cskr); |     writer.enumerate("cskr", cskr); | ||||||
|     writer.enumerate("cinf", cinf); |     writer.enumerate("cinf", cinf); | ||||||
| 
 | 
 | ||||||
|     writer.writeUint32("animationCount", animations.size()); |  | ||||||
|     writer.enumerate("animations", animations); |     writer.enumerate("animations", animations); | ||||||
| 
 | 
 | ||||||
|     writer.enumerate("pasDatabase", pasDatabase); |     writer.enumerate("pasDatabase", pasDatabase); | ||||||
| 
 | 
 | ||||||
|     writer.writeUint32("partCount", partResData.part.size()); |  | ||||||
|     writer.enumerate("part", partResData.part); |     writer.enumerate("part", partResData.part); | ||||||
| 
 | 
 | ||||||
|     writer.writeUint32("swhcCount", partResData.swhc.size()); |  | ||||||
|     writer.enumerate("swhc", partResData.swhc); |     writer.enumerate("swhc", partResData.swhc); | ||||||
| 
 | 
 | ||||||
|     writer.writeUint32("unkCount", partResData.unk.size()); |  | ||||||
|     writer.enumerate("unk", partResData.unk); |     writer.enumerate("unk", partResData.unk); | ||||||
| 
 | 
 | ||||||
|     writer.writeUint32("elscCount", partResData.elsc.size()); |  | ||||||
|     writer.enumerate("elsc", partResData.elsc); |     writer.enumerate("elsc", partResData.elsc); | ||||||
| 
 | 
 | ||||||
|     writer.writeUint32("spscCount", partResData.spsc.size()); |  | ||||||
|     writer.enumerate("spsc", partResData.spsc); |     writer.enumerate("spsc", partResData.spsc); | ||||||
| 
 | 
 | ||||||
|     writer.writeUint32("unk2Count", partResData.unk2.size()); |  | ||||||
|     writer.enumerate("unk2", partResData.unk2); |     writer.enumerate("unk2", partResData.unk2); | ||||||
| 
 | 
 | ||||||
|     writer.writeUint32("unk1", unk1); |     writer.writeUint32("unk1", unk1); | ||||||
| 
 | 
 | ||||||
|     if (sectionCount > 1) |     if (sectionCount > 1) | ||||||
|     { |     { | ||||||
|         writer.writeUint32("animAABBCount", animAABBs.size()); |  | ||||||
|         writer.enumerate("animAABBs", animAABBs); |         writer.enumerate("animAABBs", animAABBs); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (sectionCount > 2) |     if (sectionCount > 2) | ||||||
|     { |     { | ||||||
|         writer.writeUint32("effectCount", effects.size()); |  | ||||||
|         writer.enumerate("effects", effects); |         writer.enumerate("effects", effects); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -380,7 +360,6 @@ void ANCS::CharacterSet::CharacterInfo::write(Athena::io::YAMLDocWriter& writer) | |||||||
| 
 | 
 | ||||||
|     if (sectionCount > 4) |     if (sectionCount > 4) | ||||||
|     { |     { | ||||||
|         writer.writeUint32("animIdxCount", animIdxs.size()); |  | ||||||
|         writer.enumerate("animIdxs", animIdxs); |         writer.enumerate("animIdxs", animIdxs); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -388,17 +367,16 @@ void ANCS::CharacterSet::CharacterInfo::write(Athena::io::YAMLDocWriter& writer) | |||||||
|     { |     { | ||||||
|         writer.writeUint32("unk4", unk4); |         writer.writeUint32("unk4", unk4); | ||||||
|         writer.writeUByte("unk5", unk5); |         writer.writeUByte("unk5", unk5); | ||||||
|         writer.writeUint32("extentsCount", extents.size()); |  | ||||||
|         writer.enumerate("extents", extents); |         writer.enumerate("extents", extents); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| const char* ANCS::CharacterSet::CharacterInfo::DNAType() | const char* ANCS::CharacterSet::CharacterInfo::DNAType() | ||||||
| { | { | ||||||
|     return "Retro::DNAMP2::ANCS::CharacterSet::CharacterInfo"; |     return "urde::DNAMP2::ANCS::CharacterSet::CharacterInfo"; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::AnimationSet::read(Athena::io::IStreamReader& reader) | void ANCS::AnimationSet::read(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     atUint16 sectionCount = reader.readUint16Big(); |     atUint16 sectionCount = reader.readUint16Big(); | ||||||
| 
 | 
 | ||||||
| @ -433,7 +411,7 @@ void ANCS::AnimationSet::read(Athena::io::IStreamReader& reader) | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::AnimationSet::write(Athena::io::IStreamWriter& writer) const | void ANCS::AnimationSet::write(athena::io::IStreamWriter& writer) const | ||||||
| { | { | ||||||
|     atUint16 sectionCount; |     atUint16 sectionCount; | ||||||
|     if (evnts.size()) |     if (evnts.size()) | ||||||
| @ -516,22 +494,19 @@ size_t ANCS::AnimationSet::binarySize(size_t __isz) const | |||||||
|     return __isz; |     return __isz; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::AnimationSet::read(Athena::io::YAMLDocReader& reader) | void ANCS::AnimationSet::read(athena::io::YAMLDocReader& reader) | ||||||
| { | { | ||||||
|     atUint16 sectionCount = reader.readUint16("sectionCount"); |     atUint16 sectionCount = reader.readUint16("sectionCount"); | ||||||
| 
 | 
 | ||||||
|     atUint32 animationCount = reader.readUint32("animationCount"); |     reader.enumerate("animations", animations); | ||||||
|     reader.enumerate("animations", animations, animationCount); |  | ||||||
| 
 | 
 | ||||||
|     atUint32 transitionCount = reader.readUint32("transitionCount"); |     reader.enumerate("transitions", transitions); | ||||||
|     reader.enumerate("transitions", transitions, transitionCount); |  | ||||||
|     reader.enumerate("defaultTransition", defaultTransition); |     reader.enumerate("defaultTransition", defaultTransition); | ||||||
| 
 | 
 | ||||||
|     additiveAnims.clear(); |     additiveAnims.clear(); | ||||||
|     if (sectionCount > 1) |     if (sectionCount > 1) | ||||||
|     { |     { | ||||||
|         atUint32 additiveAnimCount = reader.readUint32("additiveAnimCount"); |         reader.enumerate("additiveAnims", additiveAnims); | ||||||
|         reader.enumerate("additiveAnims", additiveAnims, additiveAnimCount); |  | ||||||
|         floatA = reader.readFloat("floatA"); |         floatA = reader.readFloat("floatA"); | ||||||
|         floatB = reader.readFloat("floatB"); |         floatB = reader.readFloat("floatB"); | ||||||
|     } |     } | ||||||
| @ -539,19 +514,17 @@ void ANCS::AnimationSet::read(Athena::io::YAMLDocReader& reader) | |||||||
|     halfTransitions.clear(); |     halfTransitions.clear(); | ||||||
|     if (sectionCount > 2) |     if (sectionCount > 2) | ||||||
|     { |     { | ||||||
|         atUint32 halfTransitionCount = reader.readUint32("halfTransitionCount"); |         reader.enumerate("halfTransitions", halfTransitions); | ||||||
|         reader.enumerate("halfTransitions", halfTransitions, halfTransitionCount); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     evnts.clear(); |     evnts.clear(); | ||||||
|     if (sectionCount > 3) |     if (sectionCount > 3) | ||||||
|     { |     { | ||||||
|         atUint32 evntsCount = reader.readUint32("evntsCount"); |         reader.enumerate("evnts", evnts); | ||||||
|         reader.enumerate("evnts", evnts, evntsCount); |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::AnimationSet::write(Athena::io::YAMLDocWriter& writer) const | void ANCS::AnimationSet::write(athena::io::YAMLDocWriter& writer) const | ||||||
| { | { | ||||||
|     atUint16 sectionCount; |     atUint16 sectionCount; | ||||||
|     if (evnts.size()) |     if (evnts.size()) | ||||||
| @ -565,16 +538,13 @@ void ANCS::AnimationSet::write(Athena::io::YAMLDocWriter& writer) const | |||||||
| 
 | 
 | ||||||
|     writer.writeUint16("sectionCount", sectionCount); |     writer.writeUint16("sectionCount", sectionCount); | ||||||
| 
 | 
 | ||||||
|     writer.writeUint32("animationCount", animations.size()); |  | ||||||
|     writer.enumerate("animations", animations); |     writer.enumerate("animations", animations); | ||||||
| 
 | 
 | ||||||
|     writer.writeUint32("transitionCount", transitions.size()); |  | ||||||
|     writer.enumerate("transitions", transitions); |     writer.enumerate("transitions", transitions); | ||||||
|     writer.enumerate("defaultTransition", defaultTransition); |     writer.enumerate("defaultTransition", defaultTransition); | ||||||
| 
 | 
 | ||||||
|     if (sectionCount > 1) |     if (sectionCount > 1) | ||||||
|     { |     { | ||||||
|         writer.writeUint32("additiveAnimCount", additiveAnims.size()); |  | ||||||
|         writer.enumerate("additiveAnims", additiveAnims); |         writer.enumerate("additiveAnims", additiveAnims); | ||||||
|         writer.writeFloat("floatA", floatA); |         writer.writeFloat("floatA", floatA); | ||||||
|         writer.writeFloat("floatB", floatB); |         writer.writeFloat("floatB", floatB); | ||||||
| @ -582,23 +552,21 @@ void ANCS::AnimationSet::write(Athena::io::YAMLDocWriter& writer) const | |||||||
| 
 | 
 | ||||||
|     if (sectionCount > 2) |     if (sectionCount > 2) | ||||||
|     { |     { | ||||||
|         writer.writeUint32("halfTransitionCount", halfTransitions.size()); |  | ||||||
|         writer.enumerate("halfTransitions", halfTransitions); |         writer.enumerate("halfTransitions", halfTransitions); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (sectionCount > 3) |     if (sectionCount > 3) | ||||||
|     { |     { | ||||||
|         writer.writeUint32("evntsCount", evnts.size()); |  | ||||||
|         writer.enumerate("evnts", evnts); |         writer.enumerate("evnts", evnts); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| const char* ANCS::AnimationSet::DNAType() | const char* ANCS::AnimationSet::DNAType() | ||||||
| { | { | ||||||
|     return "Retro::DNAMP2::ANCS::AnimationSet"; |     return "urde::DNAMP2::ANCS::AnimationSet"; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::AnimationSet::EVNT::read(Athena::io::IStreamReader& reader) | void ANCS::AnimationSet::EVNT::read(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     version = reader.readUint32Big(); |     version = reader.readUint32Big(); | ||||||
| 
 | 
 | ||||||
| @ -619,7 +587,7 @@ void ANCS::AnimationSet::EVNT::read(Athena::io::IStreamReader& reader) | |||||||
|     reader.enumerate(sfxEvents, sfxCount); |     reader.enumerate(sfxEvents, sfxCount); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::AnimationSet::EVNT::write(Athena::io::IStreamWriter& writer) const | void ANCS::AnimationSet::EVNT::write(athena::io::IStreamWriter& writer) const | ||||||
| { | { | ||||||
|     writer.writeUint32Big(version); |     writer.writeUint32Big(version); | ||||||
| 
 | 
 | ||||||
| @ -661,50 +629,42 @@ size_t ANCS::AnimationSet::EVNT::binarySize(size_t __isz) const | |||||||
|     return __isz; |     return __isz; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::AnimationSet::EVNT::read(Athena::io::YAMLDocReader& reader) | void ANCS::AnimationSet::EVNT::read(athena::io::YAMLDocReader& reader) | ||||||
| { | { | ||||||
|     version = reader.readUint32("version"); |     version = reader.readUint32("version"); | ||||||
| 
 | 
 | ||||||
|     atUint32 loopCount = reader.readUint32("loopCount"); |     reader.enumerate("loopEvents", loopEvents); | ||||||
|     reader.enumerate("loopEvents", loopEvents, loopCount); |  | ||||||
| 
 | 
 | ||||||
|     uevtEvents.clear(); |     uevtEvents.clear(); | ||||||
|     if (version == 2) |     if (version == 2) | ||||||
|     { |     { | ||||||
|         atUint32 uevtCount = reader.readUint32("uevtCount"); |         reader.enumerate("uevtEvents", uevtEvents); | ||||||
|         reader.enumerate("uevtEvents", uevtEvents, uevtCount); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     atUint32 effectCount = reader.readUint32("effectCount"); |     reader.enumerate("effectEvents", effectEvents); | ||||||
|     reader.enumerate("effectEvents", effectEvents, effectCount); |  | ||||||
| 
 | 
 | ||||||
|     atUint32 sfxCount = reader.readUint32("sfxCount"); |     reader.enumerate("sfxEvents", sfxEvents); | ||||||
|     reader.enumerate("sfxEvents", sfxEvents, sfxCount); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANCS::AnimationSet::EVNT::write(Athena::io::YAMLDocWriter& writer) const | void ANCS::AnimationSet::EVNT::write(athena::io::YAMLDocWriter& writer) const | ||||||
| { | { | ||||||
|     writer.writeUint32("version", version); |     writer.writeUint32("version", version); | ||||||
| 
 | 
 | ||||||
|     writer.writeUint32("loopCount", loopEvents.size()); |  | ||||||
|     writer.enumerate("loopEvents", loopEvents); |     writer.enumerate("loopEvents", loopEvents); | ||||||
| 
 | 
 | ||||||
|     if (version == 2) |     if (version == 2) | ||||||
|     { |     { | ||||||
|         writer.writeUint32("uevtCount", uevtEvents.size()); |  | ||||||
|         writer.enumerate("uevtEvents", uevtEvents); |         writer.enumerate("uevtEvents", uevtEvents); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     writer.writeUint32("effectCount", effectEvents.size()); |  | ||||||
|     writer.enumerate("effectEvents", effectEvents); |     writer.enumerate("effectEvents", effectEvents); | ||||||
| 
 | 
 | ||||||
|     writer.writeUint32("sfxCount", sfxEvents.size()); |  | ||||||
|     writer.enumerate("sfxEvents", sfxEvents); |     writer.enumerate("sfxEvents", sfxEvents); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| const char* ANCS::AnimationSet::EVNT::DNAType() | const char* ANCS::AnimationSet::EVNT::DNAType() | ||||||
| { | { | ||||||
|     return "Retro::DNAMP2::ANCS::AnimationSet::EVNT"; |     return "urde::DNAMP2::ANCS::AnimationSet::EVNT"; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -213,34 +213,34 @@ struct ANCS : BigYAML | |||||||
| 
 | 
 | ||||||
|     static bool Extract(const SpecBase& dataSpec, |     static bool Extract(const SpecBase& dataSpec, | ||||||
|                         PAKEntryReadStream& rs, |                         PAKEntryReadStream& rs, | ||||||
|                         const HECL::ProjectPath& outPath, |                         const hecl::ProjectPath& outPath, | ||||||
|                         PAKRouter<PAKBridge>& pakRouter, |                         PAKRouter<PAKBridge>& pakRouter, | ||||||
|                         const DNAMP1::PAK::Entry& entry, |                         const DNAMP1::PAK::Entry& entry, | ||||||
|                         bool force, |                         bool force, | ||||||
|                         std::function<void(const HECL::SystemChar*)> fileChanged) |                         std::function<void(const hecl::SystemChar*)> fileChanged) | ||||||
|     { |     { | ||||||
|         HECL::ProjectPath yamlPath = outPath.getWithExtension(_S(".yaml")); |         hecl::ProjectPath yamlPath = outPath.getWithExtension(_S(".yaml")); | ||||||
|         HECL::ProjectPath::Type yamlType = yamlPath.getPathType(); |         hecl::ProjectPath::Type yamlType = yamlPath.getPathType(); | ||||||
|         HECL::ProjectPath blendPath = outPath.getWithExtension(_S(".blend")); |         hecl::ProjectPath blendPath = outPath.getWithExtension(_S(".blend")); | ||||||
|         HECL::ProjectPath::Type blendType = blendPath.getPathType(); |         hecl::ProjectPath::Type blendType = blendPath.getPathType(); | ||||||
| 
 | 
 | ||||||
|         if (force || |         if (force || | ||||||
|             yamlType == HECL::ProjectPath::Type::None || |             yamlType == hecl::ProjectPath::Type::None || | ||||||
|             blendType == HECL::ProjectPath::Type::None) |             blendType == hecl::ProjectPath::Type::None) | ||||||
|         { |         { | ||||||
|             ANCS ancs; |             ANCS ancs; | ||||||
|             ancs.read(rs); |             ancs.read(rs); | ||||||
| 
 | 
 | ||||||
|             if (force || yamlType == HECL::ProjectPath::Type::None) |             if (force || yamlType == hecl::ProjectPath::Type::None) | ||||||
|             { |             { | ||||||
|                 FILE* fp = HECL::Fopen(yamlPath.getAbsolutePath().c_str(), _S("wb")); |                 FILE* fp = hecl::Fopen(yamlPath.getAbsolutePath().c_str(), _S("wb")); | ||||||
|                 ancs.toYAMLFile(fp); |                 ancs.toYAMLFile(fp); | ||||||
|                 fclose(fp); |                 fclose(fp); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if (force || blendType == HECL::ProjectPath::Type::None) |             if (force || blendType == hecl::ProjectPath::Type::None) | ||||||
|             { |             { | ||||||
|                 HECL::BlenderConnection& conn = HECL::BlenderConnection::SharedConnection(); |                 hecl::BlenderConnection& conn = hecl::BlenderConnection::SharedConnection(); | ||||||
|                 DNAANCS::ReadANCSToBlender<PAKRouter<PAKBridge>, ANCS, MaterialSet, DNACMDL::SurfaceHeader_2, 4> |                 DNAANCS::ReadANCSToBlender<PAKRouter<PAKBridge>, ANCS, MaterialSet, DNACMDL::SurfaceHeader_2, 4> | ||||||
|                         (conn, ancs, blendPath, pakRouter, entry, dataSpec, fileChanged, force); |                         (conn, ancs, blendPath, pakRouter, entry, dataSpec, fileChanged, force); | ||||||
|             } |             } | ||||||
|  | |||||||
| @ -5,9 +5,9 @@ namespace DataSpec | |||||||
| namespace DNAMP2 | namespace DNAMP2 | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| using ANIMOutStream = HECL::BlenderConnection::PyOutStream::ANIMOutStream; | using ANIMOutStream = hecl::BlenderConnection::PyOutStream::ANIMOutStream; | ||||||
| 
 | 
 | ||||||
| void ANIM::IANIM::sendANIMToBlender(HECL::BlenderConnection::PyOutStream& os, const CINF& cinf) const | void ANIM::IANIM::sendANIMToBlender(hecl::BlenderConnection::PyOutStream& os, const CINF& cinf) const | ||||||
| { | { | ||||||
|     os.format("act.hecl_fps = round(%f)\n", (1.0f / mainInterval)); |     os.format("act.hecl_fps = round(%f)\n", (1.0f / mainInterval)); | ||||||
| 
 | 
 | ||||||
| @ -92,7 +92,7 @@ void ANIM::IANIM::sendANIMToBlender(HECL::BlenderConnection::PyOutStream& os, co | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANIM::ANIM0::read(Athena::io::IStreamReader& reader) | void ANIM::ANIM0::read(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     Header head; |     Header head; | ||||||
|     head.read(reader); |     head.read(reader); | ||||||
| @ -215,7 +215,7 @@ void ANIM::ANIM0::read(Athena::io::IStreamReader& reader) | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANIM::ANIM0::write(Athena::io::IStreamWriter& writer) const | void ANIM::ANIM0::write(athena::io::IStreamWriter& writer) const | ||||||
| { | { | ||||||
|     Header head; |     Header head; | ||||||
|     head.unk0 = 0; |     head.unk0 = 0; | ||||||
| @ -372,7 +372,7 @@ size_t ANIM::ANIM0::binarySize(size_t __isz) const | |||||||
|     return __isz; |     return __isz; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANIM::ANIM2::read(Athena::io::IStreamReader& reader) | void ANIM::ANIM2::read(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     Header head; |     Header head; | ||||||
|     head.read(reader); |     head.read(reader); | ||||||
| @ -450,7 +450,7 @@ void ANIM::ANIM2::read(Athena::io::IStreamReader& reader) | |||||||
|     chanKeys = bsReader.read(bsData.get(), keyframeCount, channels, head.rotDiv, head.translationMult); |     chanKeys = bsReader.read(bsData.get(), keyframeCount, channels, head.rotDiv, head.translationMult); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANIM::ANIM2::write(Athena::io::IStreamWriter& writer) const | void ANIM::ANIM2::write(athena::io::IStreamWriter& writer) const | ||||||
| { | { | ||||||
|     Header head; |     Header head; | ||||||
|     head.unk1 = 1; |     head.unk1 = 1; | ||||||
|  | |||||||
| @ -27,7 +27,7 @@ struct ANIM : BigDNA | |||||||
|         std::vector<std::vector<DNAANIM::Value>> chanKeys; |         std::vector<std::vector<DNAANIM::Value>> chanKeys; | ||||||
|         float mainInterval = 0.0; |         float mainInterval = 0.0; | ||||||
| 
 | 
 | ||||||
|         void sendANIMToBlender(HECL::BlenderConnection::PyOutStream&, const CINF&) const; |         void sendANIMToBlender(hecl::BlenderConnection::PyOutStream&, const CINF&) const; | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     struct ANIM0 : IANIM |     struct ANIM0 : IANIM | ||||||
| @ -97,7 +97,7 @@ struct ANIM : BigDNA | |||||||
|             Value<atUint16> initSZ = 0; |             Value<atUint16> initSZ = 0; | ||||||
|             Value<atUint8> qSZ = 0; |             Value<atUint8> qSZ = 0; | ||||||
| 
 | 
 | ||||||
|             void read(Athena::io::IStreamReader& reader) |             void read(athena::io::IStreamReader& reader) | ||||||
|             { |             { | ||||||
|                 id = reader.readUByte(); |                 id = reader.readUByte(); | ||||||
|                 keyCount1 = reader.readUint16Big(); |                 keyCount1 = reader.readUint16Big(); | ||||||
| @ -131,7 +131,7 @@ struct ANIM : BigDNA | |||||||
|                     qSZ = reader.readUByte(); |                     qSZ = reader.readUByte(); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             void write(Athena::io::IStreamWriter& writer) const |             void write(athena::io::IStreamWriter& writer) const | ||||||
|             { |             { | ||||||
|                 writer.writeUByte(id); |                 writer.writeUByte(id); | ||||||
|                 writer.writeUint16Big(keyCount1); |                 writer.writeUint16Big(keyCount1); | ||||||
| @ -180,7 +180,7 @@ struct ANIM : BigDNA | |||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     std::unique_ptr<IANIM> m_anim; |     std::unique_ptr<IANIM> m_anim; | ||||||
|     void read(Athena::io::IStreamReader& reader) |     void read(athena::io::IStreamReader& reader) | ||||||
|     { |     { | ||||||
|         atUint32 version = reader.readUint32Big(); |         atUint32 version = reader.readUint32Big(); | ||||||
|         switch (version) |         switch (version) | ||||||
| @ -194,12 +194,12 @@ struct ANIM : BigDNA | |||||||
|             m_anim->read(reader); |             m_anim->read(reader); | ||||||
|             break; |             break; | ||||||
|         default: |         default: | ||||||
|             Log.report(LogVisor::FatalError, "unrecognized ANIM version"); |             Log.report(logvisor::Fatal, "unrecognized ANIM version"); | ||||||
|             break; |             break; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void write(Athena::io::IStreamWriter& writer) const |     void write(athena::io::IStreamWriter& writer) const | ||||||
|     { |     { | ||||||
|         writer.writeUint32Big(m_anim->m_version); |         writer.writeUint32Big(m_anim->m_version); | ||||||
|         m_anim->write(writer); |         m_anim->write(writer); | ||||||
| @ -210,7 +210,7 @@ struct ANIM : BigDNA | |||||||
|         return m_anim->binarySize(__isz + 4); |         return m_anim->binarySize(__isz + 4); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void sendANIMToBlender(HECL::BlenderConnection::PyOutStream& os, const CINF& cinf, bool) const |     void sendANIMToBlender(hecl::BlenderConnection::PyOutStream& os, const CINF& cinf, bool) const | ||||||
|     { |     { | ||||||
|         m_anim->sendANIMToBlender(os, cinf); |         m_anim->sendANIMToBlender(os, cinf); | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -57,7 +57,7 @@ struct CINF : BigDNA | |||||||
|         return nullptr; |         return nullptr; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void sendVertexGroupsToBlender(HECL::BlenderConnection::PyOutStream& os) const |     void sendVertexGroupsToBlender(hecl::BlenderConnection::PyOutStream& os) const | ||||||
|     { |     { | ||||||
|         for (atUint32 bid : boneIds) |         for (atUint32 bid : boneIds) | ||||||
|         { |         { | ||||||
| @ -72,7 +72,7 @@ struct CINF : BigDNA | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void sendCINFToBlender(HECL::BlenderConnection::PyOutStream& os, const UniqueID32& cinfId) const |     void sendCINFToBlender(hecl::BlenderConnection::PyOutStream& os, const UniqueID32& cinfId) const | ||||||
|     { |     { | ||||||
|         os.format("arm = bpy.data.armatures.new('CINF_%08X')\n" |         os.format("arm = bpy.data.armatures.new('CINF_%08X')\n" | ||||||
|                   "arm_obj = bpy.data.objects.new(arm.name, arm)\n" |                   "arm_obj = bpy.data.objects.new(arm.name, arm)\n" | ||||||
|  | |||||||
| @ -17,11 +17,11 @@ struct CMDL | |||||||
| { | { | ||||||
|     static bool Extract(const SpecBase& dataSpec, |     static bool Extract(const SpecBase& dataSpec, | ||||||
|                         PAKEntryReadStream& rs, |                         PAKEntryReadStream& rs, | ||||||
|                         const HECL::ProjectPath& outPath, |                         const hecl::ProjectPath& outPath, | ||||||
|                         PAKRouter<PAKBridge>& pakRouter, |                         PAKRouter<PAKBridge>& pakRouter, | ||||||
|                         const DNAMP1::PAK::Entry& entry, |                         const DNAMP1::PAK::Entry& entry, | ||||||
|                         bool, |                         bool, | ||||||
|                         std::function<void(const HECL::SystemChar*)>) |                         std::function<void(const hecl::SystemChar*)>) | ||||||
|     { |     { | ||||||
|         /* Check for RigPair */ |         /* Check for RigPair */ | ||||||
|         const PAKRouter<PAKBridge>::RigPair* rp = pakRouter.lookupCMDLRigPair(entry.id); |         const PAKRouter<PAKBridge>::RigPair* rp = pakRouter.lookupCMDLRigPair(entry.id); | ||||||
| @ -37,8 +37,8 @@ struct CMDL | |||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         /* Do extract */ |         /* Do extract */ | ||||||
|         HECL::BlenderConnection& conn = HECL::BlenderConnection::SharedConnection(); |         hecl::BlenderConnection& conn = hecl::BlenderConnection::SharedConnection(); | ||||||
|         if (!conn.createBlend(outPath, HECL::BlenderConnection::BlendType::Mesh)) |         if (!conn.createBlend(outPath, hecl::BlenderConnection::BlendType::Mesh)) | ||||||
|             return false; |             return false; | ||||||
|         DNACMDL::ReadCMDLToBlender<PAKRouter<PAKBridge>, MaterialSet, std::pair<CSKR*,CINF*>, DNACMDL::SurfaceHeader_2, 4> |         DNACMDL::ReadCMDLToBlender<PAKRouter<PAKBridge>, MaterialSet, std::pair<CSKR*,CINF*>, DNACMDL::SurfaceHeader_2, 4> | ||||||
|                 (conn, rs, pakRouter, entry, dataSpec, loadRp); |                 (conn, rs, pakRouter, entry, dataSpec, loadRp); | ||||||
|  | |||||||
| @ -59,15 +59,15 @@ struct MaterialSet : BigDNA | |||||||
|     }; |     }; | ||||||
|     Vector<Material, DNA_COUNT(head.materialCount)> materials; |     Vector<Material, DNA_COUNT(head.materialCount)> materials; | ||||||
| 
 | 
 | ||||||
|     static void RegisterMaterialProps(HECL::BlenderConnection::PyOutStream& out) |     static void RegisterMaterialProps(hecl::BlenderConnection::PyOutStream& out) | ||||||
|     { |     { | ||||||
|         DNAMP1::MaterialSet::RegisterMaterialProps(out); |         DNAMP1::MaterialSet::RegisterMaterialProps(out); | ||||||
|     } |     } | ||||||
|     static void ConstructMaterial(HECL::BlenderConnection::PyOutStream& out, |     static void ConstructMaterial(hecl::BlenderConnection::PyOutStream& out, | ||||||
|                                   const MaterialSet::Material& material, |                                   const MaterialSet::Material& material, | ||||||
|                                   unsigned groupIdx, unsigned matIdx); |                                   unsigned groupIdx, unsigned matIdx); | ||||||
| 
 | 
 | ||||||
|     void readToBlender(HECL::BlenderConnection::PyOutStream& os, |     void readToBlender(hecl::BlenderConnection::PyOutStream& os, | ||||||
|                        const PAKRouter<PAKBridge>& pakRouter, |                        const PAKRouter<PAKBridge>& pakRouter, | ||||||
|                        const PAKRouter<PAKBridge>::EntryType& entry, |                        const PAKRouter<PAKBridge>::EntryType& entry, | ||||||
|                        unsigned setIdx) |                        unsigned setIdx) | ||||||
|  | |||||||
| @ -20,7 +20,7 @@ struct CSKR : DNAMP1::CSKR | |||||||
|         return nullptr; |         return nullptr; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void weightVertex(HECL::BlenderConnection::PyOutStream& os, const CINF& cinf, atUint32 idx) const |     void weightVertex(hecl::BlenderConnection::PyOutStream& os, const CINF& cinf, atUint32 idx) const | ||||||
|     { |     { | ||||||
|         atUint32 accum = 0; |         atUint32 accum = 0; | ||||||
|         for (const SkinningRule& rule : skinningRules) |         for (const SkinningRule& rule : skinningRules) | ||||||
|  | |||||||
| @ -13,7 +13,7 @@ namespace DataSpec | |||||||
| { | { | ||||||
| namespace DNAMP2 | namespace DNAMP2 | ||||||
| { | { | ||||||
| LogVisor::LogModule Log("Retro::DNAMP2"); | logvisor::Module Log("urde::DNAMP2"); | ||||||
| 
 | 
 | ||||||
| static bool GetNoShare(const std::string& name) | static bool GetNoShare(const std::string& name) | ||||||
| { | { | ||||||
| @ -24,12 +24,12 @@ static bool GetNoShare(const std::string& name) | |||||||
|     return true; |     return true; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| PAKBridge::PAKBridge(HECL::Database::Project& project, | PAKBridge::PAKBridge(hecl::Database::Project& project, | ||||||
|                      const NOD::Node& node, |                      const nod::Node& node, | ||||||
|                      bool doExtract) |                      bool doExtract) | ||||||
| : m_project(project), m_node(node), m_pak(true, GetNoShare(node.getName())), m_doExtract(doExtract) | : m_project(project), m_node(node), m_pak(true, GetNoShare(node.getName())), m_doExtract(doExtract) | ||||||
| { | { | ||||||
|     NOD::AthenaPartReadStream rs(node.beginReadStream()); |     nod::AthenaPartReadStream rs(node.beginReadStream()); | ||||||
|     m_pak.read(rs); |     m_pak.read(rs); | ||||||
| 
 | 
 | ||||||
|     /* Append Level String */ |     /* Append Level String */ | ||||||
| @ -54,12 +54,12 @@ PAKBridge::PAKBridge(HECL::Database::Project& project, | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static HECL::SystemString LayerName(const std::string& name) | static hecl::SystemString LayerName(const std::string& name) | ||||||
| { | { | ||||||
| #if HECL_UCS2 | #if HECL_UCS2 | ||||||
|     HECL::SystemString ret = HECL::UTF8ToWide(name); |     hecl::SystemString ret = hecl::UTF8ToWide(name); | ||||||
| #else | #else | ||||||
|     HECL::SystemString ret = name; |     hecl::SystemString ret = name; | ||||||
| #endif | #endif | ||||||
|     for (auto& ch : ret) |     for (auto& ch : ret) | ||||||
|         if (ch == _S('/') || ch == _S('\\')) |         if (ch == _S('/') || ch == _S('\\')) | ||||||
| @ -82,7 +82,7 @@ void PAKBridge::build() | |||||||
|                 mlvl.read(rs); |                 mlvl.read(rs); | ||||||
|             } |             } | ||||||
| #if HECL_UCS2 | #if HECL_UCS2 | ||||||
|             level.name = HECL::UTF8ToWide(m_pak.bestEntryName(entry)); |             level.name = hecl::UTF8ToWide(m_pak.bestEntryName(entry)); | ||||||
| #else | #else | ||||||
|             level.name = m_pak.bestEntryName(entry); |             level.name = m_pak.bestEntryName(entry); | ||||||
| #endif | #endif | ||||||
| @ -95,7 +95,7 @@ void PAKBridge::build() | |||||||
|             if (worldMapEnt) |             if (worldMapEnt) | ||||||
|             { |             { | ||||||
|                 PAKEntryReadStream rs = worldMapEnt->beginReadStream(m_node); |                 PAKEntryReadStream rs = worldMapEnt->beginReadStream(m_node); | ||||||
|                 rs.seek(8, Athena::Current); |                 rs.seek(8, athena::Current); | ||||||
|                 atUint32 areaCount = rs.readUint32Big(); |                 atUint32 areaCount = rs.readUint32Big(); | ||||||
|                 mapw.reserve(areaCount); |                 mapw.reserve(areaCount); | ||||||
|                 for (atUint32 i=0 ; i<areaCount ; ++i) |                 for (atUint32 i=0 ; i<areaCount ; ++i) | ||||||
| @ -130,21 +130,21 @@ void PAKBridge::build() | |||||||
|                 if (areaDeps.name.empty()) |                 if (areaDeps.name.empty()) | ||||||
|                 { |                 { | ||||||
| #if HECL_UCS2 | #if HECL_UCS2 | ||||||
|                     areaDeps.name = HECL::UTF8ToWide(area.internalAreaName); |                     areaDeps.name = hecl::UTF8ToWide(area.internalAreaName); | ||||||
| #else | #else | ||||||
|                     areaDeps.name = area.internalAreaName; |                     areaDeps.name = area.internalAreaName; | ||||||
| #endif | #endif | ||||||
|                     if (areaDeps.name.empty()) |                     if (areaDeps.name.empty()) | ||||||
|                     { |                     { | ||||||
| #if HECL_UCS2 | #if HECL_UCS2 | ||||||
|                         areaDeps.name = _S("MREA_") + HECL::UTF8ToWide(area.areaMREAId.toString()); |                         areaDeps.name = _S("MREA_") + hecl::UTF8ToWide(area.areaMREAId.toString()); | ||||||
| #else | #else | ||||||
|                         areaDeps.name = "MREA_" + area.areaMREAId.toString(); |                         areaDeps.name = "MREA_" + area.areaMREAId.toString(); | ||||||
| #endif | #endif | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 HECL::SystemChar num[16]; |                 hecl::SystemChar num[16]; | ||||||
|                 HECL::SNPrintf(num, 16, _S("%02u "), ai); |                 hecl::SNPrintf(num, 16, _S("%02u "), ai); | ||||||
|                 areaDeps.name = num + areaDeps.name; |                 areaDeps.name = num + areaDeps.name; | ||||||
| 
 | 
 | ||||||
|                 areaDeps.layers.reserve(area.depLayerCount-1); |                 areaDeps.layers.reserve(area.depLayerCount-1); | ||||||
| @ -163,7 +163,7 @@ void PAKBridge::build() | |||||||
|                     while (layer.name.size() && isspace(layer.name.back())) |                     while (layer.name.size() && isspace(layer.name.back())) | ||||||
|                         layer.name.pop_back(); |                         layer.name.pop_back(); | ||||||
| #endif | #endif | ||||||
|                     HECL::SNPrintf(num, 16, layer.active ? _S("%02ua ") : _S("%02u "), l-1); |                     hecl::SNPrintf(num, 16, layer.active ? _S("%02ua ") : _S("%02u "), l-1); | ||||||
|                     layer.name = num + layer.name; |                     layer.name = num + layer.name; | ||||||
| 
 | 
 | ||||||
|                     layer.resources.reserve(area.depLayers[l] - r); |                     layer.resources.reserve(area.depLayers[l] - r); | ||||||
|  | |||||||
| @ -9,31 +9,31 @@ namespace DataSpec | |||||||
| namespace DNAMP2 | namespace DNAMP2 | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| extern LogVisor::LogModule Log; | extern logvisor::Module Log; | ||||||
| 
 | 
 | ||||||
| /* MP2-specific, one-shot PAK traversal/extraction class */ | /* MP2-specific, one-shot PAK traversal/extraction class */ | ||||||
| class PAKBridge | class PAKBridge | ||||||
| { | { | ||||||
|     HECL::Database::Project& m_project; |     hecl::Database::Project& m_project; | ||||||
|     const NOD::Node& m_node; |     const nod::Node& m_node; | ||||||
|     DNAMP1::PAK m_pak; |     DNAMP1::PAK m_pak; | ||||||
| public: | public: | ||||||
|     bool m_doExtract; |     bool m_doExtract; | ||||||
|     using Level = Level<UniqueID32>; |     using Level = Level<UniqueID32>; | ||||||
|     std::unordered_map<UniqueID32, Level> m_levelDeps; |     std::unordered_map<UniqueID32, Level> m_levelDeps; | ||||||
|     HECL::SystemString m_levelString; |     hecl::SystemString m_levelString; | ||||||
| 
 | 
 | ||||||
|     PAKBridge(HECL::Database::Project& project, |     PAKBridge(hecl::Database::Project& project, | ||||||
|               const NOD::Node& node, |               const nod::Node& node, | ||||||
|               bool doExtract=true); |               bool doExtract=true); | ||||||
|     void build(); |     void build(); | ||||||
|     static ResExtractor<PAKBridge> LookupExtractor(const DNAMP1::PAK::Entry& entry); |     static ResExtractor<PAKBridge> LookupExtractor(const DNAMP1::PAK::Entry& entry); | ||||||
|     const std::string& getName() const {return m_node.getName();} |     const std::string& getName() const {return m_node.getName();} | ||||||
|     const HECL::SystemString& getLevelString() const {return m_levelString;} |     const hecl::SystemString& getLevelString() const {return m_levelString;} | ||||||
| 
 | 
 | ||||||
|     using PAKType = DNAMP1::PAK; |     using PAKType = DNAMP1::PAK; | ||||||
|     const PAKType& getPAK() const {return m_pak;} |     const PAKType& getPAK() const {return m_pak;} | ||||||
|     const NOD::Node& getNode() const {return m_node;} |     const nod::Node& getNode() const {return m_node;} | ||||||
| 
 | 
 | ||||||
|     void addCMDLRigPairs(PAKRouter<PAKBridge>& pakRouter, |     void addCMDLRigPairs(PAKRouter<PAKBridge>& pakRouter, | ||||||
|             std::unordered_map<UniqueID32, std::pair<UniqueID32, UniqueID32>>& addTo) const; |             std::unordered_map<UniqueID32, std::pair<UniqueID32, UniqueID32>>& addTo) const; | ||||||
|  | |||||||
| @ -65,11 +65,11 @@ struct DeafBabe : BigDNA | |||||||
|     Value<atUint32> vertCount; |     Value<atUint32> vertCount; | ||||||
|     Vector<atVec3f, DNA_COUNT(vertCount)> verts; |     Vector<atVec3f, DNA_COUNT(vertCount)> verts; | ||||||
| 
 | 
 | ||||||
|     static void BlenderInit(HECL::BlenderConnection::PyOutStream& os) |     static void BlenderInit(hecl::BlenderConnection::PyOutStream& os) | ||||||
|     { |     { | ||||||
|         DNAMP1::DeafBabe::BlenderInit(os); |         DNAMP1::DeafBabe::BlenderInit(os); | ||||||
|     } |     } | ||||||
|     void insertNoClimb(HECL::BlenderConnection::PyOutStream& os) const |     void insertNoClimb(hecl::BlenderConnection::PyOutStream& os) const | ||||||
|     { |     { | ||||||
|         for (atInt16 edgeIdx : noClimbEdges) |         for (atInt16 edgeIdx : noClimbEdges) | ||||||
|         { |         { | ||||||
| @ -82,7 +82,7 @@ struct DeafBabe : BigDNA | |||||||
|                       edge.verts[0], edge.verts[1]); |                       edge.verts[0], edge.verts[1]); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     void sendToBlender(HECL::BlenderConnection::PyOutStream& os) const |     void sendToBlender(hecl::BlenderConnection::PyOutStream& os) const | ||||||
|     { |     { | ||||||
|         DeafBabeSendToBlender(os, *this); |         DeafBabeSendToBlender(os, *this); | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -13,15 +13,15 @@ struct MAPA : DNAMAPA::MAPA | |||||||
| { | { | ||||||
|     static bool Extract(const SpecBase& dataSpec, |     static bool Extract(const SpecBase& dataSpec, | ||||||
|                         PAKEntryReadStream& rs, |                         PAKEntryReadStream& rs, | ||||||
|                         const HECL::ProjectPath& outPath, |                         const hecl::ProjectPath& outPath, | ||||||
|                         PAKRouter<PAKBridge>& pakRouter, |                         PAKRouter<PAKBridge>& pakRouter, | ||||||
|                         const DNAMP1::PAK::Entry& entry, |                         const DNAMP1::PAK::Entry& entry, | ||||||
|                         bool force, |                         bool force, | ||||||
|                         std::function<void(const HECL::SystemChar*)> fileChanged) |                         std::function<void(const hecl::SystemChar*)> fileChanged) | ||||||
|     { |     { | ||||||
|         MAPA mapa; |         MAPA mapa; | ||||||
|         mapa.read(rs); |         mapa.read(rs); | ||||||
|         HECL::BlenderConnection& conn = HECL::BlenderConnection::SharedConnection(); |         hecl::BlenderConnection& conn = hecl::BlenderConnection::SharedConnection(); | ||||||
|         return DNAMAPA::ReadMAPAToBlender(conn, mapa, outPath, pakRouter, entry, force); |         return DNAMAPA::ReadMAPAToBlender(conn, mapa, outPath, pakRouter, entry, force); | ||||||
|     } |     } | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -96,18 +96,18 @@ struct MLVL : BigYAML | |||||||
| 
 | 
 | ||||||
|     static bool Extract(const SpecBase& dataSpec, |     static bool Extract(const SpecBase& dataSpec, | ||||||
|                         PAKEntryReadStream& rs, |                         PAKEntryReadStream& rs, | ||||||
|                         const HECL::ProjectPath& outPath, |                         const hecl::ProjectPath& outPath, | ||||||
|                         PAKRouter<PAKBridge>& pakRouter, |                         PAKRouter<PAKBridge>& pakRouter, | ||||||
|                         const DNAMP1::PAK::Entry& entry, |                         const DNAMP1::PAK::Entry& entry, | ||||||
|                         bool force, |                         bool force, | ||||||
|                         std::function<void(const HECL::SystemChar*)> fileChanged) |                         std::function<void(const hecl::SystemChar*)> fileChanged) | ||||||
|     { |     { | ||||||
|         MLVL mlvl; |         MLVL mlvl; | ||||||
|         mlvl.read(rs); |         mlvl.read(rs); | ||||||
|         FILE* fp = HECL::Fopen(outPath.getWithExtension(_S(".yaml"), true).getAbsolutePath().c_str(), _S("wb")); |         FILE* fp = hecl::Fopen(outPath.getWithExtension(_S(".yaml"), true).getAbsolutePath().c_str(), _S("wb")); | ||||||
|         mlvl.toYAMLFile(fp); |         mlvl.toYAMLFile(fp); | ||||||
|         fclose(fp); |         fclose(fp); | ||||||
|         HECL::BlenderConnection& conn = HECL::BlenderConnection::SharedConnection(); |         hecl::BlenderConnection& conn = hecl::BlenderConnection::SharedConnection(); | ||||||
|         return DNAMLVL::ReadMLVLToBlender(conn, mlvl, outPath, pakRouter, |         return DNAMLVL::ReadMLVLToBlender(conn, mlvl, outPath, pakRouter, | ||||||
|                                           entry, force, fileChanged); |                                           entry, force, fileChanged); | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -1,4 +1,4 @@ | |||||||
| #include <Athena/FileWriter.hpp> | #include <athena/FileWriter.hpp> | ||||||
| #include <lzo/lzo1x.h> | #include <lzo/lzo1x.h> | ||||||
| #include "MREA.hpp" | #include "MREA.hpp" | ||||||
| #include "../DNAMP1/MREA.hpp" | #include "../DNAMP1/MREA.hpp" | ||||||
| @ -13,7 +13,7 @@ namespace DNAMP2 | |||||||
| void MREA::StreamReader::nextBlock() | void MREA::StreamReader::nextBlock() | ||||||
| { | { | ||||||
|     if (m_nextBlk >= m_blkCount) |     if (m_nextBlk >= m_blkCount) | ||||||
|         Log.report(LogVisor::FatalError, "MREA stream overrun"); |         Log.report(logvisor::Fatal, "MREA stream overrun"); | ||||||
| 
 | 
 | ||||||
|     BlockInfo& info = m_blockInfos[m_nextBlk++]; |     BlockInfo& info = m_blockInfos[m_nextBlk++]; | ||||||
| 
 | 
 | ||||||
| @ -68,7 +68,7 @@ void MREA::StreamReader::nextBlock() | |||||||
|     m_blkSz = info.decompSize; |     m_blkSz = info.decompSize; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| MREA::StreamReader::StreamReader(Athena::io::IStreamReader& source, atUint32 blkCount) | MREA::StreamReader::StreamReader(athena::io::IStreamReader& source, atUint32 blkCount) | ||||||
| : m_compBufSz(0x4120), m_compBuf(new atUint8[0x4120]), | : m_compBufSz(0x4120), m_compBuf(new atUint8[0x4120]), | ||||||
|   m_decompBufSz(0x4120), m_decompBuf(new atUint8[0x4120]), |   m_decompBufSz(0x4120), m_decompBuf(new atUint8[0x4120]), | ||||||
|   m_source(source), m_blkCount(blkCount) |   m_source(source), m_blkCount(blkCount) | ||||||
| @ -86,16 +86,16 @@ MREA::StreamReader::StreamReader(Athena::io::IStreamReader& source, atUint32 blk | |||||||
|     nextBlock(); |     nextBlock(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void MREA::StreamReader::seek(atInt64 diff, Athena::SeekOrigin whence) | void MREA::StreamReader::seek(atInt64 diff, athena::SeekOrigin whence) | ||||||
| { | { | ||||||
|     atUint64 target = diff; |     atUint64 target = diff; | ||||||
|     if (whence == Athena::Current) |     if (whence == athena::Current) | ||||||
|         target = m_pos + diff; |         target = m_pos + diff; | ||||||
|     else if (whence == Athena::End) |     else if (whence == athena::End) | ||||||
|         target = m_totalDecompLen - diff; |         target = m_totalDecompLen - diff; | ||||||
| 
 | 
 | ||||||
|     if (target >= m_totalDecompLen) |     if (target >= m_totalDecompLen) | ||||||
|         Log.report(LogVisor::FatalError, "MREA stream seek overrun"); |         Log.report(logvisor::Fatal, "MREA stream seek overrun"); | ||||||
| 
 | 
 | ||||||
|     /* Determine which block contains position */ |     /* Determine which block contains position */ | ||||||
|     atUint32 dAccum = 0; |     atUint32 dAccum = 0; | ||||||
| @ -117,7 +117,7 @@ void MREA::StreamReader::seek(atInt64 diff, Athena::SeekOrigin whence) | |||||||
|     /* Seek source if needed */ |     /* Seek source if needed */ | ||||||
|     if (bIdx != m_nextBlk-1) |     if (bIdx != m_nextBlk-1) | ||||||
|     { |     { | ||||||
|         m_source.seek(m_blkBase + cAccum, Athena::Begin); |         m_source.seek(m_blkBase + cAccum, athena::Begin); | ||||||
|         m_nextBlk = bIdx; |         m_nextBlk = bIdx; | ||||||
|         nextBlock(); |         nextBlock(); | ||||||
|     } |     } | ||||||
| @ -147,7 +147,7 @@ atUint64 MREA::StreamReader::readUBytesToBuf(void* buf, atUint64 len) | |||||||
|     return len; |     return len; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void MREA::StreamReader::writeDecompInfos(Athena::io::IStreamWriter& writer) const | void MREA::StreamReader::writeDecompInfos(athena::io::IStreamWriter& writer) const | ||||||
| { | { | ||||||
|     for (const BlockInfo& info : m_blockInfos) |     for (const BlockInfo& info : m_blockInfos) | ||||||
|     { |     { | ||||||
| @ -159,18 +159,18 @@ void MREA::StreamReader::writeDecompInfos(Athena::io::IStreamWriter& writer) con | |||||||
| 
 | 
 | ||||||
| bool MREA::Extract(const SpecBase& dataSpec, | bool MREA::Extract(const SpecBase& dataSpec, | ||||||
|                    PAKEntryReadStream& rs, |                    PAKEntryReadStream& rs, | ||||||
|                    const HECL::ProjectPath& outPath, |                    const hecl::ProjectPath& outPath, | ||||||
|                    PAKRouter<PAKBridge>& pakRouter, |                    PAKRouter<PAKBridge>& pakRouter, | ||||||
|                    const DNAMP1::PAK::Entry& entry, |                    const DNAMP1::PAK::Entry& entry, | ||||||
|                    bool force, |                    bool force, | ||||||
|                    std::function<void(const HECL::SystemChar*)>) |                    std::function<void(const hecl::SystemChar*)>) | ||||||
| { | { | ||||||
|     using RigPair = std::pair<CSKR*, CINF*>; |     using RigPair = std::pair<CSKR*, CINF*>; | ||||||
|     RigPair dummy(nullptr, nullptr); |     RigPair dummy(nullptr, nullptr); | ||||||
| 
 | 
 | ||||||
|     /* Rename MREA for consistency */ |     /* Rename MREA for consistency */ | ||||||
|     HECL::ProjectPath mreaPath(outPath.getParentPath(), _S("!area.blend")); |     hecl::ProjectPath mreaPath(outPath.getParentPath(), _S("!area.blend")); | ||||||
|     if (!force && mreaPath.getPathType() == HECL::ProjectPath::Type::File) |     if (!force && mreaPath.getPathType() == hecl::ProjectPath::Type::File) | ||||||
|         return true; |         return true; | ||||||
| 
 | 
 | ||||||
|     /* Do extract */ |     /* Do extract */ | ||||||
| @ -180,7 +180,7 @@ bool MREA::Extract(const SpecBase& dataSpec, | |||||||
| 
 | 
 | ||||||
|     /* MREA decompression stream */ |     /* MREA decompression stream */ | ||||||
|     StreamReader drs(rs, head.compressedBlockCount); |     StreamReader drs(rs, head.compressedBlockCount); | ||||||
|     Athena::io::FileWriter mreaDecompOut(pakRouter.getCooked(&entry).getWithExtension(_S(".decomp")).getAbsolutePath()); |     athena::io::FileWriter mreaDecompOut(pakRouter.getCooked(&entry).getWithExtension(_S(".decomp")).getAbsolutePath()); | ||||||
|     head.write(mreaDecompOut); |     head.write(mreaDecompOut); | ||||||
|     mreaDecompOut.seekAlign32(); |     mreaDecompOut.seekAlign32(); | ||||||
|     drs.writeDecompInfos(mreaDecompOut); |     drs.writeDecompInfos(mreaDecompOut); | ||||||
| @ -188,11 +188,11 @@ bool MREA::Extract(const SpecBase& dataSpec, | |||||||
|     atUint64 decompLen = drs.length(); |     atUint64 decompLen = drs.length(); | ||||||
|     mreaDecompOut.writeBytes(drs.readBytes(decompLen).get(), decompLen); |     mreaDecompOut.writeBytes(drs.readBytes(decompLen).get(), decompLen); | ||||||
|     mreaDecompOut.close(); |     mreaDecompOut.close(); | ||||||
|     drs.seek(0, Athena::Begin); |     drs.seek(0, athena::Begin); | ||||||
| 
 | 
 | ||||||
|     /* Start up blender connection */ |     /* Start up blender connection */ | ||||||
|     HECL::BlenderConnection& conn = HECL::BlenderConnection::SharedConnection(); |     hecl::BlenderConnection& conn = hecl::BlenderConnection::SharedConnection(); | ||||||
|     if (!conn.createBlend(mreaPath, HECL::BlenderConnection::BlendType::Area)) |     if (!conn.createBlend(mreaPath, hecl::BlenderConnection::BlendType::Area)) | ||||||
|         return false; |         return false; | ||||||
| 
 | 
 | ||||||
|     /* Calculate offset to EGMC section */ |     /* Calculate offset to EGMC section */ | ||||||
| @ -201,15 +201,15 @@ bool MREA::Extract(const SpecBase& dataSpec, | |||||||
|         egmcOffset += head.secSizes[i]; |         egmcOffset += head.secSizes[i]; | ||||||
| 
 | 
 | ||||||
|     /* Load EGMC if possible so we can assign meshes to scanIds */ |     /* Load EGMC if possible so we can assign meshes to scanIds */ | ||||||
|     drs.seek(egmcOffset, Athena::Begin); |     drs.seek(egmcOffset, athena::Begin); | ||||||
|     UniqueID32 egmcId(drs); |     UniqueID32 egmcId(drs); | ||||||
|     DNACommon::EGMC egmc; |     DNACommon::EGMC egmc; | ||||||
|     bool hasEGMC = pakRouter.lookupAndReadDNA(egmcId, egmc); |     bool hasEGMC = pakRouter.lookupAndReadDNA(egmcId, egmc); | ||||||
| 
 | 
 | ||||||
|     drs.seek(0, Athena::Begin); |     drs.seek(0, athena::Begin); | ||||||
| 
 | 
 | ||||||
|     /* Open Py Stream and read sections */ |     /* Open Py Stream and read sections */ | ||||||
|     HECL::BlenderConnection::PyOutStream os = conn.beginPythonOut(true); |     hecl::BlenderConnection::PyOutStream os = conn.beginPythonOut(true); | ||||||
|     os.format("import bpy\n" |     os.format("import bpy\n" | ||||||
|               "import bmesh\n" |               "import bmesh\n" | ||||||
|               "from mathutils import Vector\n" |               "from mathutils import Vector\n" | ||||||
| @ -241,7 +241,7 @@ bool MREA::Extract(const SpecBase& dataSpec, | |||||||
|     atUint64 secStart = drs.position(); |     atUint64 secStart = drs.position(); | ||||||
|     matSet.read(drs); |     matSet.read(drs); | ||||||
|     matSet.readToBlender(os, pakRouter, entry, 0); |     matSet.readToBlender(os, pakRouter, entry, 0); | ||||||
|     drs.seek(secStart + head.secSizes[0], Athena::Begin); |     drs.seek(secStart + head.secSizes[0], athena::Begin); | ||||||
|     std::vector<DNACMDL::VertexAttributes> vertAttribs; |     std::vector<DNACMDL::VertexAttributes> vertAttribs; | ||||||
|     DNACMDL::GetVertexAttributes(matSet, vertAttribs); |     DNACMDL::GetVertexAttributes(matSet, vertAttribs); | ||||||
| 
 | 
 | ||||||
| @ -252,7 +252,7 @@ bool MREA::Extract(const SpecBase& dataSpec, | |||||||
|         MeshHeader mHeader; |         MeshHeader mHeader; | ||||||
|         secStart = drs.position(); |         secStart = drs.position(); | ||||||
|         mHeader.read(drs); |         mHeader.read(drs); | ||||||
|         drs.seek(secStart + head.secSizes[curSec++], Athena::Begin); |         drs.seek(secStart + head.secSizes[curSec++], athena::Begin); | ||||||
|         curSec += DNACMDL::ReadGeomSectionsToBlender<PAKRouter<PAKBridge>, MaterialSet, RigPair, DNACMDL::SurfaceHeader_2> |         curSec += DNACMDL::ReadGeomSectionsToBlender<PAKRouter<PAKBridge>, MaterialSet, RigPair, DNACMDL::SurfaceHeader_2> | ||||||
|                       (os, drs, pakRouter, entry, dummy, true, |                       (os, drs, pakRouter, entry, dummy, true, | ||||||
|                        true, vertAttribs, m, head.secCount, 0, &head.secSizes[curSec]); |                        true, vertAttribs, m, head.secCount, 0, &head.secSizes[curSec]); | ||||||
| @ -266,25 +266,25 @@ bool MREA::Extract(const SpecBase& dataSpec, | |||||||
|                   mHeader.visorFlags.thermalLevelStr()); |                   mHeader.visorFlags.thermalLevelStr()); | ||||||
| 
 | 
 | ||||||
|         /* Seek through AROT-relation sections */ |         /* Seek through AROT-relation sections */ | ||||||
|         drs.seek(head.secSizes[curSec++], Athena::Current); |         drs.seek(head.secSizes[curSec++], athena::Current); | ||||||
|         drs.seek(head.secSizes[curSec++], Athena::Current); |         drs.seek(head.secSizes[curSec++], athena::Current); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /* Skip AROT */ |     /* Skip AROT */ | ||||||
|     drs.seek(head.secSizes[curSec++], Athena::Current); |     drs.seek(head.secSizes[curSec++], athena::Current); | ||||||
| 
 | 
 | ||||||
|     /* Skip BVH */ |     /* Skip BVH */ | ||||||
|     drs.seek(head.secSizes[curSec++], Athena::Current); |     drs.seek(head.secSizes[curSec++], athena::Current); | ||||||
| 
 | 
 | ||||||
|     /* Skip Bitmap */ |     /* Skip Bitmap */ | ||||||
|     drs.seek(head.secSizes[curSec++], Athena::Current); |     drs.seek(head.secSizes[curSec++], athena::Current); | ||||||
| 
 | 
 | ||||||
|     /* Skip SCLY (for now) */ |     /* Skip SCLY (for now) */ | ||||||
|     for (atUint32 l=0 ; l<head.sclyLayerCount ; ++l) |     for (atUint32 l=0 ; l<head.sclyLayerCount ; ++l) | ||||||
|         drs.seek(head.secSizes[curSec++], Athena::Current); |         drs.seek(head.secSizes[curSec++], athena::Current); | ||||||
| 
 | 
 | ||||||
|     /* Skip SCGN (for now) */ |     /* Skip SCGN (for now) */ | ||||||
|     drs.seek(head.secSizes[curSec++], Athena::Current); |     drs.seek(head.secSizes[curSec++], athena::Current); | ||||||
| 
 | 
 | ||||||
|     /* Read collision meshes */ |     /* Read collision meshes */ | ||||||
|     DeafBabe collision; |     DeafBabe collision; | ||||||
| @ -292,15 +292,15 @@ bool MREA::Extract(const SpecBase& dataSpec, | |||||||
|     collision.read(drs); |     collision.read(drs); | ||||||
|     DeafBabe::BlenderInit(os); |     DeafBabe::BlenderInit(os); | ||||||
|     collision.sendToBlender(os); |     collision.sendToBlender(os); | ||||||
|     drs.seek(secStart + head.secSizes[curSec++], Athena::Begin); |     drs.seek(secStart + head.secSizes[curSec++], athena::Begin); | ||||||
| 
 | 
 | ||||||
|     /* Skip unknown section */ |     /* Skip unknown section */ | ||||||
|     drs.seek(head.secSizes[curSec++], Athena::Current); |     drs.seek(head.secSizes[curSec++], athena::Current); | ||||||
| 
 | 
 | ||||||
|     /* Read BABEDEAD Lights as Cycles emissives */ |     /* Read BABEDEAD Lights as Cycles emissives */ | ||||||
|     secStart = drs.position(); |     secStart = drs.position(); | ||||||
|     DNAMP1::MREA::ReadBabeDeadToBlender_1_2(os, drs); |     DNAMP1::MREA::ReadBabeDeadToBlender_1_2(os, drs); | ||||||
|     drs.seek(secStart + head.secSizes[curSec++], Athena::Begin); |     drs.seek(secStart + head.secSizes[curSec++], athena::Begin); | ||||||
| 
 | 
 | ||||||
|     /* Origins to center of mass */ |     /* Origins to center of mass */ | ||||||
|     os << "bpy.context.scene.layers[1] = True\n" |     os << "bpy.context.scene.layers[1] = True\n" | ||||||
|  | |||||||
| @ -12,7 +12,7 @@ namespace DNAMP2 | |||||||
| 
 | 
 | ||||||
| struct MREA | struct MREA | ||||||
| { | { | ||||||
|     class StreamReader : public Athena::io::IStreamReader |     class StreamReader : public athena::io::IStreamReader | ||||||
|     { |     { | ||||||
|     protected: |     protected: | ||||||
|         struct BlockInfo : BigDNA |         struct BlockInfo : BigDNA | ||||||
| @ -29,7 +29,7 @@ struct MREA | |||||||
|         std::unique_ptr<atUint8[]> m_compBuf; |         std::unique_ptr<atUint8[]> m_compBuf; | ||||||
|         size_t m_decompBufSz; |         size_t m_decompBufSz; | ||||||
|         std::unique_ptr<atUint8[]> m_decompBuf; |         std::unique_ptr<atUint8[]> m_decompBuf; | ||||||
|         Athena::io::IStreamReader& m_source; |         athena::io::IStreamReader& m_source; | ||||||
|         atUint64 m_blkBase; |         atUint64 m_blkBase; | ||||||
|         atUint32 m_blkCount; |         atUint32 m_blkCount; | ||||||
|         atUint32 m_totalDecompLen = 0; |         atUint32 m_totalDecompLen = 0; | ||||||
| @ -40,18 +40,18 @@ struct MREA | |||||||
|         atUint32 m_blkSz = 0; |         atUint32 m_blkSz = 0; | ||||||
|         void nextBlock(); |         void nextBlock(); | ||||||
| 
 | 
 | ||||||
|         StreamReader(Athena::io::IStreamReader& source) |         StreamReader(athena::io::IStreamReader& source) | ||||||
|         : m_compBufSz(0x4120), m_compBuf(new atUint8[0x4120]), |         : m_compBufSz(0x4120), m_compBuf(new atUint8[0x4120]), | ||||||
|           m_decompBufSz(0x4120), m_decompBuf(new atUint8[0x4120]), |           m_decompBufSz(0x4120), m_decompBuf(new atUint8[0x4120]), | ||||||
|           m_source(source) {} /* Empty constructor for inheriting */ |           m_source(source) {} /* Empty constructor for inheriting */ | ||||||
| 
 | 
 | ||||||
|     public: |     public: | ||||||
|         StreamReader(Athena::io::IStreamReader& source, atUint32 blkCount); |         StreamReader(athena::io::IStreamReader& source, atUint32 blkCount); | ||||||
|         void seek(atInt64 diff, Athena::SeekOrigin whence); |         void seek(atInt64 diff, athena::SeekOrigin whence); | ||||||
|         atUint64 position() const {return m_pos;} |         atUint64 position() const {return m_pos;} | ||||||
|         atUint64 length() const {return m_totalDecompLen;} |         atUint64 length() const {return m_totalDecompLen;} | ||||||
|         atUint64 readUBytesToBuf(void* buf, atUint64 len); |         atUint64 readUBytesToBuf(void* buf, atUint64 len); | ||||||
|         void writeDecompInfos(Athena::io::IStreamWriter& writer) const; |         void writeDecompInfos(athena::io::IStreamWriter& writer) const; | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     struct Header : BigDNA |     struct Header : BigDNA | ||||||
| @ -75,7 +75,7 @@ struct MREA | |||||||
|         Value<atUint32> unk3SecIdx; |         Value<atUint32> unk3SecIdx; | ||||||
|         Value<atUint32> egmcSecIdx; |         Value<atUint32> egmcSecIdx; | ||||||
|         Value<atUint32> compressedBlockCount; |         Value<atUint32> compressedBlockCount; | ||||||
|         Seek<12, Athena::Current> align1; |         Seek<12, athena::Current> align1; | ||||||
|         Vector<atUint32, DNA_COUNT(secCount)> secSizes; |         Vector<atUint32, DNA_COUNT(secCount)> secSizes; | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
| @ -119,11 +119,11 @@ struct MREA | |||||||
| 
 | 
 | ||||||
|     static bool Extract(const SpecBase& dataSpec, |     static bool Extract(const SpecBase& dataSpec, | ||||||
|                         PAKEntryReadStream& rs, |                         PAKEntryReadStream& rs, | ||||||
|                         const HECL::ProjectPath& outPath, |                         const hecl::ProjectPath& outPath, | ||||||
|                         PAKRouter<PAKBridge>& pakRouter, |                         PAKRouter<PAKBridge>& pakRouter, | ||||||
|                         const DNAMP1::PAK::Entry& entry, |                         const DNAMP1::PAK::Entry& entry, | ||||||
|                         bool, |                         bool, | ||||||
|                         std::function<void(const HECL::SystemChar*)>); |                         std::function<void(const hecl::SystemChar*)>); | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -3,7 +3,7 @@ | |||||||
| 
 | 
 | ||||||
| #include "../DNAMP1/PAK.hpp" | #include "../DNAMP1/PAK.hpp" | ||||||
| 
 | 
 | ||||||
| namespace Retro | namespace urde | ||||||
| { | { | ||||||
| namespace DNAMP2 | namespace DNAMP2 | ||||||
| { | { | ||||||
|  | |||||||
| @ -6,7 +6,7 @@ namespace DataSpec | |||||||
| namespace DNAMP2 | namespace DNAMP2 | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| void STRG::_read(Athena::io::IStreamReader& reader) | void STRG::_read(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     atUint32 langCount = reader.readUint32Big(); |     atUint32 langCount = reader.readUint32Big(); | ||||||
|     atUint32 strCount = reader.readUint32Big(); |     atUint32 strCount = reader.readUint32Big(); | ||||||
| @ -32,8 +32,8 @@ void STRG::_read(Athena::io::IStreamReader& reader) | |||||||
|     }* nameIndex = (NameIdxEntry*)nameTableBuf.get(); |     }* nameIndex = (NameIdxEntry*)nameTableBuf.get(); | ||||||
|     for (atUint32 n=0 ; n<nameCount ; ++n) |     for (atUint32 n=0 ; n<nameCount ; ++n) | ||||||
|     { |     { | ||||||
|         const char* name = (char*)(nameTableBuf.get() + HECL::SBig(nameIndex[n].nameOff)); |         const char* name = (char*)(nameTableBuf.get() + hecl::SBig(nameIndex[n].nameOff)); | ||||||
|         names[name] = HECL::SBig(nameIndex[n].strIdx); |         names[name] = hecl::SBig(nameIndex[n].strIdx); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     langs.clear(); |     langs.clear(); | ||||||
| @ -53,20 +53,20 @@ void STRG::_read(Athena::io::IStreamReader& reader) | |||||||
|         langMap.emplace(item.first, &item.second); |         langMap.emplace(item.first, &item.second); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void STRG::read(Athena::io::IStreamReader& reader) | void STRG::read(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     atUint32 magic = reader.readUint32Big(); |     atUint32 magic = reader.readUint32Big(); | ||||||
|     if (magic != 0x87654321) |     if (magic != 0x87654321) | ||||||
|         Log.report(LogVisor::Error, "invalid STRG magic"); |         Log.report(logvisor::Error, "invalid STRG magic"); | ||||||
| 
 | 
 | ||||||
|     atUint32 version = reader.readUint32Big(); |     atUint32 version = reader.readUint32Big(); | ||||||
|     if (version != 1) |     if (version != 1) | ||||||
|         Log.report(LogVisor::Error, "invalid STRG version"); |         Log.report(logvisor::Error, "invalid STRG version"); | ||||||
| 
 | 
 | ||||||
|     _read(reader); |     _read(reader); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void STRG::write(Athena::io::IStreamWriter& writer) const | void STRG::write(athena::io::IStreamWriter& writer) const | ||||||
| { | { | ||||||
|     writer.writeUint32Big(0x87654321); |     writer.writeUint32Big(0x87654321); | ||||||
|     writer.writeUint32Big(1); |     writer.writeUint32Big(1); | ||||||
| @ -166,9 +166,9 @@ size_t STRG::binarySize(size_t __isz) const | |||||||
|     return __isz; |     return __isz; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void STRG::read(Athena::io::YAMLDocReader& reader) | void STRG::read(athena::io::YAMLDocReader& reader) | ||||||
| { | { | ||||||
|     const Athena::io::YAMLNode* root = reader.getRootNode(); |     const athena::io::YAMLNode* root = reader.getRootNode(); | ||||||
| 
 | 
 | ||||||
|     /* Validate Pass */ |     /* Validate Pass */ | ||||||
|     if (root->m_type == YAML_MAPPING_NODE) |     if (root->m_type == YAML_MAPPING_NODE) | ||||||
| @ -179,19 +179,19 @@ void STRG::read(Athena::io::YAMLDocReader& reader) | |||||||
|                 continue; |                 continue; | ||||||
|             if (lang.first.size() != 4) |             if (lang.first.size() != 4) | ||||||
|             { |             { | ||||||
|                 Log.report(LogVisor::Warning, "STRG language string '%s' must be exactly 4 characters; skipping", lang.first.c_str()); |                 Log.report(logvisor::Warning, "STRG language string '%s' must be exactly 4 characters; skipping", lang.first.c_str()); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (lang.second->m_type != YAML_SEQUENCE_NODE) |             if (lang.second->m_type != YAML_SEQUENCE_NODE) | ||||||
|             { |             { | ||||||
|                 Log.report(LogVisor::Warning, "STRG language string '%s' must contain a sequence; skipping", lang.first.c_str()); |                 Log.report(logvisor::Warning, "STRG language string '%s' must contain a sequence; skipping", lang.first.c_str()); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             for (const auto& str : lang.second->m_seqChildren) |             for (const auto& str : lang.second->m_seqChildren) | ||||||
|             { |             { | ||||||
|                 if (str->m_type != YAML_SCALAR_NODE) |                 if (str->m_type != YAML_SCALAR_NODE) | ||||||
|                 { |                 { | ||||||
|                     Log.report(LogVisor::Warning, "STRG language '%s' must contain all scalars; skipping", lang.first.c_str()); |                     Log.report(logvisor::Warning, "STRG language '%s' must contain all scalars; skipping", lang.first.c_str()); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @ -199,7 +199,7 @@ void STRG::read(Athena::io::YAMLDocReader& reader) | |||||||
|     } |     } | ||||||
|     else |     else | ||||||
|     { |     { | ||||||
|         Log.report(LogVisor::Warning, "STRG must have a mapping root node; skipping"); |         Log.report(logvisor::Warning, "STRG must have a mapping root node; skipping"); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -209,15 +209,15 @@ void STRG::read(Athena::io::YAMLDocReader& reader) | |||||||
|     { |     { | ||||||
|         std::vector<std::wstring> strs; |         std::vector<std::wstring> strs; | ||||||
|         for (const auto& str : lang.second->m_seqChildren) |         for (const auto& str : lang.second->m_seqChildren) | ||||||
|             strs.emplace_back(HECL::UTF8ToWide(str->m_scalarString)); |             strs.emplace_back(hecl::UTF8ToWide(str->m_scalarString)); | ||||||
|         langs.emplace_back(FourCC(lang.first.c_str()), strs); |         langs.emplace_back(FourCC(lang.first.c_str()), strs); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     names.clear(); |     names.clear(); | ||||||
|     const Athena::io::YAMLNode* namesNode = root->findMapChild("names"); |     const athena::io::YAMLNode* namesNode = root->findMapChild("names"); | ||||||
|     if (namesNode) |     if (namesNode) | ||||||
|         for (const auto& item : namesNode->m_mapChildren) |         for (const auto& item : namesNode->m_mapChildren) | ||||||
|             names[item.first] = Athena::io::NodeToVal<atInt32>(item.second.get()); |             names[item.first] = athena::io::NodeToVal<atInt32>(item.second.get()); | ||||||
| 
 | 
 | ||||||
|     langMap.clear(); |     langMap.clear(); | ||||||
|     langMap.reserve(langs.size()); |     langMap.reserve(langs.size()); | ||||||
| @ -225,7 +225,7 @@ void STRG::read(Athena::io::YAMLDocReader& reader) | |||||||
|         langMap.emplace(item.first, &item.second); |         langMap.emplace(item.first, &item.second); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void STRG::write(Athena::io::YAMLDocWriter& writer) const | void STRG::write(athena::io::YAMLDocWriter& writer) const | ||||||
| { | { | ||||||
|     for (const auto& lang : langs) |     for (const auto& lang : langs) | ||||||
|     { |     { | ||||||
| @ -249,7 +249,7 @@ void STRG::write(Athena::io::YAMLDocWriter& writer) const | |||||||
| 
 | 
 | ||||||
| const char* STRG::DNAType() | const char* STRG::DNAType() | ||||||
| { | { | ||||||
|     return "Retro::DNAMP2::STRG"; |     return "urde::DNAMP2::STRG"; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -14,7 +14,7 @@ struct STRG : ISTRG | |||||||
| { | { | ||||||
|     DECL_YAML |     DECL_YAML | ||||||
|     Delete expl; |     Delete expl; | ||||||
|     void _read(Athena::io::IStreamReader& reader); |     void _read(athena::io::IStreamReader& reader); | ||||||
|     std::vector<std::pair<FourCC, std::vector<std::wstring>>> langs; |     std::vector<std::pair<FourCC, std::vector<std::wstring>>> langs; | ||||||
|     std::unordered_map<FourCC, std::vector<std::wstring>*> langMap; |     std::unordered_map<FourCC, std::vector<std::wstring>*> langMap; | ||||||
|     std::map<std::string, int32_t> names; |     std::map<std::string, int32_t> names; | ||||||
| @ -42,7 +42,7 @@ struct STRG : ISTRG | |||||||
|     { |     { | ||||||
|         auto search = langMap.find(lang); |         auto search = langMap.find(lang); | ||||||
|         if (search != langMap.end()) |         if (search != langMap.end()) | ||||||
|             return HECL::WideToUTF8(search->second->at(idx)); |             return hecl::WideToUTF8(search->second->at(idx)); | ||||||
|         return std::string(); |         return std::string(); | ||||||
|     } |     } | ||||||
|     inline std::wstring getUTF16(const FourCC& lang, size_t idx) const |     inline std::wstring getUTF16(const FourCC& lang, size_t idx) const | ||||||
| @ -52,35 +52,35 @@ struct STRG : ISTRG | |||||||
|             return search->second->at(idx); |             return search->second->at(idx); | ||||||
|         return std::wstring(); |         return std::wstring(); | ||||||
|     } |     } | ||||||
|     inline HECL::SystemString getSystemString(const FourCC& lang, size_t idx) const |     inline hecl::SystemString getSystemString(const FourCC& lang, size_t idx) const | ||||||
|     { |     { | ||||||
|         auto search = langMap.find(lang); |         auto search = langMap.find(lang); | ||||||
|         if (search != langMap.end()) |         if (search != langMap.end()) | ||||||
| #if HECL_UCS2 | #if HECL_UCS2 | ||||||
|             return search->second->at(idx); |             return search->second->at(idx); | ||||||
| #else | #else | ||||||
|             return HECL::WideToUTF8(search->second->at(idx)); |             return hecl::WideToUTF8(search->second->at(idx)); | ||||||
| #endif | #endif | ||||||
|         return HECL::SystemString(); |         return hecl::SystemString(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     static bool Extract(PAKEntryReadStream& rs, const HECL::ProjectPath& outPath) |     static bool Extract(PAKEntryReadStream& rs, const hecl::ProjectPath& outPath) | ||||||
|     { |     { | ||||||
|         STRG strg; |         STRG strg; | ||||||
|         strg.read(rs); |         strg.read(rs); | ||||||
|         FILE* fp = HECL::Fopen(outPath.getAbsolutePath().c_str(), _S("wb")); |         FILE* fp = hecl::Fopen(outPath.getAbsolutePath().c_str(), _S("wb")); | ||||||
|         strg.toYAMLFile(fp); |         strg.toYAMLFile(fp); | ||||||
|         fclose(fp); |         fclose(fp); | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     static bool Cook(const HECL::ProjectPath& inPath, const HECL::ProjectPath& outPath) |     static bool Cook(const hecl::ProjectPath& inPath, const hecl::ProjectPath& outPath) | ||||||
|     { |     { | ||||||
|         STRG strg; |         STRG strg; | ||||||
|         FILE* fp = HECL::Fopen(inPath.getAbsolutePath().c_str(), _S("rb")); |         FILE* fp = hecl::Fopen(inPath.getAbsolutePath().c_str(), _S("rb")); | ||||||
|         strg.fromYAMLFile(fp); |         strg.fromYAMLFile(fp); | ||||||
|         fclose(fp); |         fclose(fp); | ||||||
|         Athena::io::FileWriter ws(outPath.getAbsolutePath()); |         athena::io::FileWriter ws(outPath.getAbsolutePath()); | ||||||
|         strg.write(ws); |         strg.write(ws); | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -1,15 +1,15 @@ | |||||||
| #include "ANIM.hpp" | #include "ANIM.hpp" | ||||||
| #include <float.h> | #include <cfloat> | ||||||
| #include <math.h> | #include "zeus/Math.hpp" | ||||||
| 
 | 
 | ||||||
| namespace DataSpec | namespace DataSpec | ||||||
| { | { | ||||||
| namespace DNAMP3 | namespace DNAMP3 | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| using ANIMOutStream = HECL::BlenderConnection::PyOutStream::ANIMOutStream; | using ANIMOutStream = hecl::BlenderConnection::PyOutStream::ANIMOutStream; | ||||||
| 
 | 
 | ||||||
| void ANIM::IANIM::sendANIMToBlender(HECL::BlenderConnection::PyOutStream& os, const CINF& cinf, bool additive) const | void ANIM::IANIM::sendANIMToBlender(hecl::BlenderConnection::PyOutStream& os, const CINF& cinf, bool additive) const | ||||||
| { | { | ||||||
|     os.format("act.hecl_fps = round(%f)\n" |     os.format("act.hecl_fps = round(%f)\n" | ||||||
|               "act.hecl_additive = %s\n", |               "act.hecl_additive = %s\n", | ||||||
| @ -109,7 +109,7 @@ void ANIM::IANIM::sendANIMToBlender(HECL::BlenderConnection::PyOutStream& os, co | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANIM::ANIM0::read(Athena::io::IStreamReader& reader) | void ANIM::ANIM0::read(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     Header head; |     Header head; | ||||||
|     head.read(reader); |     head.read(reader); | ||||||
| @ -235,7 +235,7 @@ void ANIM::ANIM0::read(Athena::io::IStreamReader& reader) | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANIM::ANIM0::write(Athena::io::IStreamWriter& writer) const | void ANIM::ANIM0::write(athena::io::IStreamWriter& writer) const | ||||||
| { | { | ||||||
|     Header head; |     Header head; | ||||||
|     head.unk0 = 0; |     head.unk0 = 0; | ||||||
| @ -425,7 +425,7 @@ static float ComputeFrames(const std::vector<float>& keyTimes, std::vector<atUin | |||||||
|     return mainInterval; |     return mainInterval; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANIM::ANIM1::read(Athena::io::IStreamReader& reader) | void ANIM::ANIM1::read(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     Header head; |     Header head; | ||||||
|     head.read(reader); |     head.read(reader); | ||||||
| @ -522,7 +522,7 @@ void ANIM::ANIM1::read(Athena::io::IStreamReader& reader) | |||||||
|     chanKeys = bsReader.read(bsData.get(), head.keyCount-1, channels, 32767, head.translationMult); |     chanKeys = bsReader.read(bsData.get(), head.keyCount-1, channels, 32767, head.translationMult); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void ANIM::ANIM1::write(Athena::io::IStreamWriter& writer) const | void ANIM::ANIM1::write(athena::io::IStreamWriter& writer) const | ||||||
| { | { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -27,7 +27,7 @@ struct ANIM : BigDNA | |||||||
|         std::vector<std::vector<DNAANIM::Value>> chanKeys; |         std::vector<std::vector<DNAANIM::Value>> chanKeys; | ||||||
|         float mainInterval = 0.0; |         float mainInterval = 0.0; | ||||||
| 
 | 
 | ||||||
|         void sendANIMToBlender(HECL::BlenderConnection::PyOutStream&, const CINF&, bool additive) const; |         void sendANIMToBlender(hecl::BlenderConnection::PyOutStream&, const CINF&, bool additive) const; | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     struct ANIM0 : IANIM |     struct ANIM0 : IANIM | ||||||
| @ -80,7 +80,7 @@ struct ANIM : BigDNA | |||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     std::unique_ptr<IANIM> m_anim; |     std::unique_ptr<IANIM> m_anim; | ||||||
|     void read(Athena::io::IStreamReader& reader) |     void read(athena::io::IStreamReader& reader) | ||||||
|     { |     { | ||||||
|         atUint32 version = reader.readUint32Big(); |         atUint32 version = reader.readUint32Big(); | ||||||
|         switch (version) |         switch (version) | ||||||
| @ -94,12 +94,12 @@ struct ANIM : BigDNA | |||||||
|             m_anim->read(reader); |             m_anim->read(reader); | ||||||
|             break; |             break; | ||||||
|         default: |         default: | ||||||
|             Log.report(LogVisor::FatalError, "unrecognized ANIM version"); |             Log.report(logvisor::Fatal, "unrecognized ANIM version"); | ||||||
|             break; |             break; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void write(Athena::io::IStreamWriter& writer) const |     void write(athena::io::IStreamWriter& writer) const | ||||||
|     { |     { | ||||||
|         writer.writeUint32Big(m_anim->m_version); |         writer.writeUint32Big(m_anim->m_version); | ||||||
|         m_anim->write(writer); |         m_anim->write(writer); | ||||||
| @ -110,7 +110,7 @@ struct ANIM : BigDNA | |||||||
|         return m_anim->binarySize(__isz + 4); |         return m_anim->binarySize(__isz + 4); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void sendANIMToBlender(HECL::BlenderConnection::PyOutStream& os, const CINF& cinf, bool additive) const |     void sendANIMToBlender(hecl::BlenderConnection::PyOutStream& os, const CINF& cinf, bool additive) const | ||||||
|     { |     { | ||||||
|         m_anim->sendANIMToBlender(os, cinf, additive); |         m_anim->sendANIMToBlender(os, cinf, additive); | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -5,7 +5,7 @@ namespace DataSpec | |||||||
| namespace DNAMP3 | namespace DNAMP3 | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| void CHAR::AnimationInfo::EVNT::SFXEvent::read(Athena::io::IStreamReader& reader) | void CHAR::AnimationInfo::EVNT::SFXEvent::read(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     EventBase::read(reader); |     EventBase::read(reader); | ||||||
|     caudId.read(reader); |     caudId.read(reader); | ||||||
| @ -17,10 +17,10 @@ void CHAR::AnimationInfo::EVNT::SFXEvent::read(Athena::io::IStreamReader& reader | |||||||
|     if (extraType == 1) |     if (extraType == 1) | ||||||
|         extraFloat = reader.readFloatBig(); |         extraFloat = reader.readFloatBig(); | ||||||
|     else if (extraType == 2) |     else if (extraType == 2) | ||||||
|         reader.seek(35, Athena::Current); |         reader.seek(35, athena::Current); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CHAR::AnimationInfo::EVNT::SFXEvent::write(Athena::io::IStreamWriter& writer) const | void CHAR::AnimationInfo::EVNT::SFXEvent::write(athena::io::IStreamWriter& writer) const | ||||||
| { | { | ||||||
|     EventBase::write(writer); |     EventBase::write(writer); | ||||||
|     caudId.write(writer); |     caudId.write(writer); | ||||||
| @ -32,7 +32,7 @@ void CHAR::AnimationInfo::EVNT::SFXEvent::write(Athena::io::IStreamWriter& write | |||||||
|     if (extraType == 1) |     if (extraType == 1) | ||||||
|         writer.writeFloatBig(extraFloat); |         writer.writeFloatBig(extraFloat); | ||||||
|     else if (extraType == 2) |     else if (extraType == 2) | ||||||
|         writer.seek(35, Athena::Current); |         writer.seek(35, athena::Current); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| size_t CHAR::AnimationInfo::EVNT::SFXEvent::binarySize(size_t __isz) const | size_t CHAR::AnimationInfo::EVNT::SFXEvent::binarySize(size_t __isz) const | ||||||
| @ -48,26 +48,24 @@ size_t CHAR::AnimationInfo::EVNT::SFXEvent::binarySize(size_t __isz) const | |||||||
|     return __isz; |     return __isz; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CHAR::AnimationInfo::EVNT::SFXEvent::read(Athena::io::YAMLDocReader& reader) | void CHAR::AnimationInfo::EVNT::SFXEvent::read(athena::io::YAMLDocReader& reader) | ||||||
| { | { | ||||||
|     EventBase::read(reader); |     EventBase::read(reader); | ||||||
|     reader.enumerate("caudId", caudId); |     reader.enumerate("caudId", caudId); | ||||||
|     unk1 = reader.readUint32("unk1"); |     unk1 = reader.readUint32("unk1"); | ||||||
|     unk2 = reader.readUint32("unk2"); |     unk2 = reader.readUint32("unk2"); | ||||||
|     unk3 = reader.readUint32("unk3"); |     unk3 = reader.enumerate("unk3Vals", unk3Vals); | ||||||
|     reader.enumerate("unk3Vals", unk3Vals, unk3); |  | ||||||
|     extraType = reader.readUint32("extraType"); |     extraType = reader.readUint32("extraType"); | ||||||
|     if (extraType == 1) |     if (extraType == 1) | ||||||
|         extraFloat = reader.readFloat("extraFloat"); |         extraFloat = reader.readFloat("extraFloat"); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CHAR::AnimationInfo::EVNT::SFXEvent::write(Athena::io::YAMLDocWriter& writer) const | void CHAR::AnimationInfo::EVNT::SFXEvent::write(athena::io::YAMLDocWriter& writer) const | ||||||
| { | { | ||||||
|     EventBase::write(writer); |     EventBase::write(writer); | ||||||
|     writer.enumerate("caudId", caudId); |     writer.enumerate("caudId", caudId); | ||||||
|     writer.writeUint32("unk1", unk1); |     writer.writeUint32("unk1", unk1); | ||||||
|     writer.writeUint32("unk2", unk2); |     writer.writeUint32("unk2", unk2); | ||||||
|     writer.writeUint32("unk3", unk3); |  | ||||||
|     writer.enumerate("unk3Vals", unk3Vals); |     writer.enumerate("unk3Vals", unk3Vals); | ||||||
|     writer.writeUint32("extraType", extraType); |     writer.writeUint32("extraType", extraType); | ||||||
|     if (extraType == 1) |     if (extraType == 1) | ||||||
| @ -76,10 +74,10 @@ void CHAR::AnimationInfo::EVNT::SFXEvent::write(Athena::io::YAMLDocWriter& write | |||||||
| 
 | 
 | ||||||
| const char* CHAR::AnimationInfo::EVNT::SFXEvent::DNAType() | const char* CHAR::AnimationInfo::EVNT::SFXEvent::DNAType() | ||||||
| { | { | ||||||
|     return "Retro::DNAMP3::CHAR::AnimationInfo::EVNT::SFXEvent"; |     return "urde::DNAMP3::CHAR::AnimationInfo::EVNT::SFXEvent"; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CHAR::AnimationInfo::MetaAnimFactory::read(Athena::io::IStreamReader& reader) | void CHAR::AnimationInfo::MetaAnimFactory::read(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     IMetaAnim::Type type(IMetaAnim::Type(reader.readUint32Big())); |     IMetaAnim::Type type(IMetaAnim::Type(reader.readUint32Big())); | ||||||
|     switch (type) |     switch (type) | ||||||
| @ -110,7 +108,7 @@ void CHAR::AnimationInfo::MetaAnimFactory::read(Athena::io::IStreamReader& reade | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CHAR::AnimationInfo::MetaAnimFactory::write(Athena::io::IStreamWriter& writer) const | void CHAR::AnimationInfo::MetaAnimFactory::write(athena::io::IStreamWriter& writer) const | ||||||
| { | { | ||||||
|     if (!m_anim) |     if (!m_anim) | ||||||
|         return; |         return; | ||||||
| @ -125,7 +123,7 @@ size_t CHAR::AnimationInfo::MetaAnimFactory::binarySize(size_t __isz) const | |||||||
|     return m_anim->binarySize(__isz + 4); |     return m_anim->binarySize(__isz + 4); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CHAR::AnimationInfo::MetaAnimFactory::read(Athena::io::YAMLDocReader& reader) | void CHAR::AnimationInfo::MetaAnimFactory::read(athena::io::YAMLDocReader& reader) | ||||||
| { | { | ||||||
|     std::string type = reader.readString("type"); |     std::string type = reader.readString("type"); | ||||||
|     std::transform(type.begin(), type.end(), type.begin(), tolower); |     std::transform(type.begin(), type.end(), type.begin(), tolower); | ||||||
| @ -161,7 +159,7 @@ void CHAR::AnimationInfo::MetaAnimFactory::read(Athena::io::YAMLDocReader& reade | |||||||
| 
 | 
 | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void CHAR::AnimationInfo::MetaAnimFactory::write(Athena::io::YAMLDocWriter& writer) const | void CHAR::AnimationInfo::MetaAnimFactory::write(athena::io::YAMLDocWriter& writer) const | ||||||
| { | { | ||||||
|     if (!m_anim) |     if (!m_anim) | ||||||
|         return; |         return; | ||||||
| @ -171,7 +169,7 @@ void CHAR::AnimationInfo::MetaAnimFactory::write(Athena::io::YAMLDocWriter& writ | |||||||
| 
 | 
 | ||||||
| const char* CHAR::AnimationInfo::MetaAnimFactory::DNAType() | const char* CHAR::AnimationInfo::MetaAnimFactory::DNAType() | ||||||
| { | { | ||||||
|     return "Retro::DNAMP3::CHAR::AnimationInfo::MetaAnimFactory"; |     return "urde::DNAMP3::CHAR::AnimationInfo::MetaAnimFactory"; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -308,34 +308,34 @@ struct CHAR : BigYAML | |||||||
| 
 | 
 | ||||||
|     static bool Extract(const SpecBase& dataSpec, |     static bool Extract(const SpecBase& dataSpec, | ||||||
|                         PAKEntryReadStream& rs, |                         PAKEntryReadStream& rs, | ||||||
|                         const HECL::ProjectPath& outPath, |                         const hecl::ProjectPath& outPath, | ||||||
|                         PAKRouter<PAKBridge>& pakRouter, |                         PAKRouter<PAKBridge>& pakRouter, | ||||||
|                         const PAK::Entry& entry, |                         const PAK::Entry& entry, | ||||||
|                         bool force, |                         bool force, | ||||||
|                         std::function<void(const HECL::SystemChar*)> fileChanged) |                         std::function<void(const hecl::SystemChar*)> fileChanged) | ||||||
|     { |     { | ||||||
|         HECL::ProjectPath yamlPath = outPath.getWithExtension(_S(".yaml")); |         hecl::ProjectPath yamlPath = outPath.getWithExtension(_S(".yaml")); | ||||||
|         HECL::ProjectPath::Type yamlType = yamlPath.getPathType(); |         hecl::ProjectPath::Type yamlType = yamlPath.getPathType(); | ||||||
|         HECL::ProjectPath blendPath = outPath.getWithExtension(_S(".blend")); |         hecl::ProjectPath blendPath = outPath.getWithExtension(_S(".blend")); | ||||||
|         HECL::ProjectPath::Type blendType = blendPath.getPathType(); |         hecl::ProjectPath::Type blendType = blendPath.getPathType(); | ||||||
| 
 | 
 | ||||||
|         if (force || |         if (force || | ||||||
|             yamlType == HECL::ProjectPath::Type::None || |             yamlType == hecl::ProjectPath::Type::None || | ||||||
|             blendType == HECL::ProjectPath::Type::None) |             blendType == hecl::ProjectPath::Type::None) | ||||||
|         { |         { | ||||||
|             CHAR aChar; |             CHAR aChar; | ||||||
|             aChar.read(rs); |             aChar.read(rs); | ||||||
| 
 | 
 | ||||||
|             if (force || yamlType == HECL::ProjectPath::Type::None) |             if (force || yamlType == hecl::ProjectPath::Type::None) | ||||||
|             { |             { | ||||||
|                 FILE* fp = HECL::Fopen(yamlPath.getAbsolutePath().c_str(), _S("wb")); |                 FILE* fp = hecl::Fopen(yamlPath.getAbsolutePath().c_str(), _S("wb")); | ||||||
|                 aChar.toYAMLFile(fp); |                 aChar.toYAMLFile(fp); | ||||||
|                 fclose(fp); |                 fclose(fp); | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|             if (force || blendType == HECL::ProjectPath::Type::None) |             if (force || blendType == hecl::ProjectPath::Type::None) | ||||||
|             { |             { | ||||||
|                 HECL::BlenderConnection& conn = HECL::BlenderConnection::SharedConnection(); |                 hecl::BlenderConnection& conn = hecl::BlenderConnection::SharedConnection(); | ||||||
|                 DNAANCS::ReadANCSToBlender<PAKRouter<PAKBridge>, CHAR, MaterialSet, DNACMDL::SurfaceHeader_3, 4> |                 DNAANCS::ReadANCSToBlender<PAKRouter<PAKBridge>, CHAR, MaterialSet, DNACMDL::SurfaceHeader_3, 4> | ||||||
|                         (conn, aChar, blendPath, pakRouter, entry, dataSpec, fileChanged, force); |                         (conn, aChar, blendPath, pakRouter, entry, dataSpec, fileChanged, force); | ||||||
|             } |             } | ||||||
|  | |||||||
| @ -13,7 +13,7 @@ namespace DNAMP3 | |||||||
| struct CINF : DNAMP2::CINF | struct CINF : DNAMP2::CINF | ||||||
| { | { | ||||||
|     Delete expl; |     Delete expl; | ||||||
|     void sendCINFToBlender(HECL::BlenderConnection::PyOutStream& os, const UniqueID64& cinfId) const |     void sendCINFToBlender(hecl::BlenderConnection::PyOutStream& os, const UniqueID64& cinfId) const | ||||||
|     { |     { | ||||||
|         os.format("arm = bpy.data.armatures.new('CINF_%016" PRIX64 "')\n" |         os.format("arm = bpy.data.armatures.new('CINF_%016" PRIX64 "')\n" | ||||||
|                   "arm_obj = bpy.data.objects.new(arm.name, arm)\n" |                   "arm_obj = bpy.data.objects.new(arm.name, arm)\n" | ||||||
|  | |||||||
| @ -17,11 +17,11 @@ struct CMDL | |||||||
| { | { | ||||||
|     static bool Extract(const SpecBase& dataSpec, |     static bool Extract(const SpecBase& dataSpec, | ||||||
|                         PAKEntryReadStream& rs, |                         PAKEntryReadStream& rs, | ||||||
|                         const HECL::ProjectPath& outPath, |                         const hecl::ProjectPath& outPath, | ||||||
|                         PAKRouter<PAKBridge>& pakRouter, |                         PAKRouter<PAKBridge>& pakRouter, | ||||||
|                         const PAK::Entry& entry, |                         const PAK::Entry& entry, | ||||||
|                         bool, |                         bool, | ||||||
|                         std::function<void(const HECL::SystemChar*)>) |                         std::function<void(const hecl::SystemChar*)>) | ||||||
|     { |     { | ||||||
|         /* Check for RigPair */ |         /* Check for RigPair */ | ||||||
|         const PAKRouter<PAKBridge>::RigPair* rp = pakRouter.lookupCMDLRigPair(entry.id); |         const PAKRouter<PAKBridge>::RigPair* rp = pakRouter.lookupCMDLRigPair(entry.id); | ||||||
| @ -37,8 +37,8 @@ struct CMDL | |||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         /* Do extract */ |         /* Do extract */ | ||||||
|         HECL::BlenderConnection& conn = HECL::BlenderConnection::SharedConnection(); |         hecl::BlenderConnection& conn = hecl::BlenderConnection::SharedConnection(); | ||||||
|         if (!conn.createBlend(outPath, HECL::BlenderConnection::BlendType::Mesh)) |         if (!conn.createBlend(outPath, hecl::BlenderConnection::BlendType::Mesh)) | ||||||
|             return false; |             return false; | ||||||
|         DNACMDL::ReadCMDLToBlender<PAKRouter<PAKBridge>, MaterialSet, std::pair<CSKR*,CINF*>, DNACMDL::SurfaceHeader_3, 5> |         DNACMDL::ReadCMDLToBlender<PAKRouter<PAKBridge>, MaterialSet, std::pair<CSKR*,CINF*>, DNACMDL::SurfaceHeader_3, 5> | ||||||
|                 (conn, rs, pakRouter, entry, dataSpec, loadRp); |                 (conn, rs, pakRouter, entry, dataSpec, loadRp); | ||||||
|  | |||||||
| @ -1,6 +1,6 @@ | |||||||
| #include "CMDLMaterials.hpp" | #include "CMDLMaterials.hpp" | ||||||
| 
 | 
 | ||||||
| using Stream = HECL::BlenderConnection::PyOutStream; | using Stream = hecl::BlenderConnection::PyOutStream; | ||||||
| 
 | 
 | ||||||
| namespace DataSpec | namespace DataSpec | ||||||
| { | { | ||||||
| @ -108,7 +108,7 @@ void MaterialSet::ConstructMaterial(Stream& out, | |||||||
|            "    new_nodetree.links.new(kcolor_nodes[-1][1].outputs[0], final_node.inputs['Alpha'])\n"; |            "    new_nodetree.links.new(kcolor_nodes[-1][1].outputs[0], final_node.inputs['Alpha'])\n"; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void Material::SectionPASS::constructNode(HECL::BlenderConnection::PyOutStream& out, | void Material::SectionPASS::constructNode(hecl::BlenderConnection::PyOutStream& out, | ||||||
|                                           const PAKRouter<PAKBridge>& pakRouter, |                                           const PAKRouter<PAKBridge>& pakRouter, | ||||||
|                                           const PAK::Entry& entry, |                                           const PAK::Entry& entry, | ||||||
|                                           const Material::ISection* prevSection, |                                           const Material::ISection* prevSection, | ||||||
| @ -121,16 +121,16 @@ void Material::SectionPASS::constructNode(HECL::BlenderConnection::PyOutStream& | |||||||
|     if (txtrId) |     if (txtrId) | ||||||
|     { |     { | ||||||
|         std::string texName = pakRouter.getBestEntryName(txtrId); |         std::string texName = pakRouter.getBestEntryName(txtrId); | ||||||
|         const NOD::Node* node; |         const nod::Node* node; | ||||||
|         const PAK::Entry* texEntry = pakRouter.lookupEntry(txtrId, &node); |         const PAK::Entry* texEntry = pakRouter.lookupEntry(txtrId, &node); | ||||||
|         HECL::ProjectPath txtrPath = pakRouter.getWorking(texEntry); |         hecl::ProjectPath txtrPath = pakRouter.getWorking(texEntry); | ||||||
|         if (txtrPath.getPathType() == HECL::ProjectPath::Type::None) |         if (txtrPath.getPathType() == hecl::ProjectPath::Type::None) | ||||||
|         { |         { | ||||||
|             PAKEntryReadStream rs = texEntry->beginReadStream(*node); |             PAKEntryReadStream rs = texEntry->beginReadStream(*node); | ||||||
|             TXTR::Extract(rs, txtrPath); |             TXTR::Extract(rs, txtrPath); | ||||||
|         } |         } | ||||||
|         HECL::SystemString resPath = pakRouter.getResourceRelativePath(entry, txtrId); |         hecl::SystemString resPath = pakRouter.getResourceRelativePath(entry, txtrId); | ||||||
|         HECL::SystemUTF8View resPathView(resPath); |         hecl::SystemUTF8View resPathView(resPath); | ||||||
|         out.format("if '%s' in bpy.data.textures:\n" |         out.format("if '%s' in bpy.data.textures:\n" | ||||||
|                    "    image = bpy.data.images['%s']\n" |                    "    image = bpy.data.images['%s']\n" | ||||||
|                    "    texture = bpy.data.textures[image.name]\n" |                    "    texture = bpy.data.textures[image.name]\n" | ||||||
| @ -258,7 +258,7 @@ void Material::SectionPASS::constructNode(HECL::BlenderConnection::PyOutStream& | |||||||
|     out << "gridder.row_break(2)\n"; |     out << "gridder.row_break(2)\n"; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void Material::SectionCLR::constructNode(HECL::BlenderConnection::PyOutStream& out, | void Material::SectionCLR::constructNode(hecl::BlenderConnection::PyOutStream& out, | ||||||
|                                          const PAKRouter<PAKBridge>& pakRouter, |                                          const PAKRouter<PAKBridge>& pakRouter, | ||||||
|                                          const PAK::Entry& entry, |                                          const PAK::Entry& entry, | ||||||
|                                          const Material::ISection* prevSection, |                                          const Material::ISection* prevSection, | ||||||
| @ -278,7 +278,7 @@ void Material::SectionCLR::constructNode(HECL::BlenderConnection::PyOutStream& o | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void Material::SectionINT::constructNode(HECL::BlenderConnection::PyOutStream& out, | void Material::SectionINT::constructNode(hecl::BlenderConnection::PyOutStream& out, | ||||||
|                                          const PAKRouter<PAKBridge>& pakRouter, |                                          const PAKRouter<PAKBridge>& pakRouter, | ||||||
|                                          const PAK::Entry& entry, |                                          const PAK::Entry& entry, | ||||||
|                                          const Material::ISection* prevSection, |                                          const Material::ISection* prevSection, | ||||||
|  | |||||||
| @ -64,7 +64,7 @@ struct MaterialSet : BigDNA | |||||||
|                 INT = SBIG('INT ') |                 INT = SBIG('INT ') | ||||||
|             } m_type; |             } m_type; | ||||||
|             ISection(Type type) : m_type(type) {} |             ISection(Type type) : m_type(type) {} | ||||||
|             virtual void constructNode(HECL::BlenderConnection::PyOutStream& out, |             virtual void constructNode(hecl::BlenderConnection::PyOutStream& out, | ||||||
|                                        const PAKRouter<PAKBridge>& pakRouter, |                                        const PAKRouter<PAKBridge>& pakRouter, | ||||||
|                                        const PAK::Entry& entry, |                                        const PAK::Entry& entry, | ||||||
|                                        const Material::ISection* prevSection, |                                        const Material::ISection* prevSection, | ||||||
| @ -115,7 +115,7 @@ struct MaterialSet : BigDNA | |||||||
|             }; |             }; | ||||||
|             Vector<UVAnimation, DNA_COUNT(uvAnimSize != 0)> uvAnim; |             Vector<UVAnimation, DNA_COUNT(uvAnimSize != 0)> uvAnim; | ||||||
| 
 | 
 | ||||||
|             void constructNode(HECL::BlenderConnection::PyOutStream& out, |             void constructNode(hecl::BlenderConnection::PyOutStream& out, | ||||||
|                                const PAKRouter<PAKBridge>& pakRouter, |                                const PAKRouter<PAKBridge>& pakRouter, | ||||||
|                                const PAK::Entry& entry, |                                const PAK::Entry& entry, | ||||||
|                                const Material::ISection* prevSection, |                                const Material::ISection* prevSection, | ||||||
| @ -136,7 +136,7 @@ struct MaterialSet : BigDNA | |||||||
|             DNAFourCC subtype; |             DNAFourCC subtype; | ||||||
|             GX::Color color; |             GX::Color color; | ||||||
| 
 | 
 | ||||||
|             void constructNode(HECL::BlenderConnection::PyOutStream& out, |             void constructNode(hecl::BlenderConnection::PyOutStream& out, | ||||||
|                                const PAKRouter<PAKBridge>& pakRouter, |                                const PAKRouter<PAKBridge>& pakRouter, | ||||||
|                                const PAK::Entry& entry, |                                const PAK::Entry& entry, | ||||||
|                                const Material::ISection* prevSection, |                                const Material::ISection* prevSection, | ||||||
| @ -160,7 +160,7 @@ struct MaterialSet : BigDNA | |||||||
|             DNAFourCC subtype; |             DNAFourCC subtype; | ||||||
|             Value<atUint32> value; |             Value<atUint32> value; | ||||||
| 
 | 
 | ||||||
|             void constructNode(HECL::BlenderConnection::PyOutStream& out, |             void constructNode(hecl::BlenderConnection::PyOutStream& out, | ||||||
|                                const PAKRouter<PAKBridge>& pakRouter, |                                const PAKRouter<PAKBridge>& pakRouter, | ||||||
|                                const PAK::Entry& entry, |                                const PAK::Entry& entry, | ||||||
|                                const Material::ISection* prevSection, |                                const Material::ISection* prevSection, | ||||||
| @ -173,7 +173,7 @@ struct MaterialSet : BigDNA | |||||||
|         { |         { | ||||||
|             Delete expl; |             Delete expl; | ||||||
|             std::unique_ptr<ISection> section; |             std::unique_ptr<ISection> section; | ||||||
|             void read(Athena::io::IStreamReader& reader) |             void read(athena::io::IStreamReader& reader) | ||||||
|             { |             { | ||||||
|                 DNAFourCC type; |                 DNAFourCC type; | ||||||
|                 type.read(reader); |                 type.read(reader); | ||||||
| @ -196,7 +196,7 @@ struct MaterialSet : BigDNA | |||||||
|                     break; |                     break; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|             void write(Athena::io::IStreamWriter& writer) const |             void write(athena::io::IStreamWriter& writer) const | ||||||
|             { |             { | ||||||
|                 if (!section) |                 if (!section) | ||||||
|                     return; |                     return; | ||||||
| @ -209,7 +209,7 @@ struct MaterialSet : BigDNA | |||||||
|             } |             } | ||||||
|         }; |         }; | ||||||
|         std::vector<SectionFactory> sections; |         std::vector<SectionFactory> sections; | ||||||
|         void read(Athena::io::IStreamReader& reader) |         void read(athena::io::IStreamReader& reader) | ||||||
|         { |         { | ||||||
|             header.read(reader); |             header.read(reader); | ||||||
|             sections.clear(); |             sections.clear(); | ||||||
| @ -219,7 +219,7 @@ struct MaterialSet : BigDNA | |||||||
|             } while (sections.back().section); |             } while (sections.back().section); | ||||||
|             sections.pop_back(); |             sections.pop_back(); | ||||||
|         } |         } | ||||||
|         void write(Athena::io::IStreamWriter& writer) const |         void write(athena::io::IStreamWriter& writer) const | ||||||
|         { |         { | ||||||
|             header.write(writer); |             header.write(writer); | ||||||
|             for (const SectionFactory& section : sections) |             for (const SectionFactory& section : sections) | ||||||
| @ -236,14 +236,14 @@ struct MaterialSet : BigDNA | |||||||
|     }; |     }; | ||||||
|     Vector<Material, DNA_COUNT(materialCount)> materials; |     Vector<Material, DNA_COUNT(materialCount)> materials; | ||||||
| 
 | 
 | ||||||
|     static void RegisterMaterialProps(HECL::BlenderConnection::PyOutStream& out); |     static void RegisterMaterialProps(hecl::BlenderConnection::PyOutStream& out); | ||||||
|     static void ConstructMaterial(HECL::BlenderConnection::PyOutStream& out, |     static void ConstructMaterial(hecl::BlenderConnection::PyOutStream& out, | ||||||
|                                   const PAKRouter<PAKBridge>& pakRouter, |                                   const PAKRouter<PAKBridge>& pakRouter, | ||||||
|                                   const PAK::Entry& entry, |                                   const PAK::Entry& entry, | ||||||
|                                   const MaterialSet::Material& material, |                                   const MaterialSet::Material& material, | ||||||
|                                   unsigned groupIdx, unsigned matIdx); |                                   unsigned groupIdx, unsigned matIdx); | ||||||
| 
 | 
 | ||||||
|     void readToBlender(HECL::BlenderConnection::PyOutStream& os, |     void readToBlender(hecl::BlenderConnection::PyOutStream& os, | ||||||
|                        const PAKRouter<PAKBridge>& pakRouter, |                        const PAKRouter<PAKBridge>& pakRouter, | ||||||
|                        const PAKRouter<PAKBridge>::EntryType& entry, |                        const PAKRouter<PAKBridge>::EntryType& entry, | ||||||
|                        unsigned setIdx) |                        unsigned setIdx) | ||||||
|  | |||||||
| @ -41,7 +41,7 @@ struct CSKR : BigDNA | |||||||
|         return mtxBindings.at(idx).mtxs; |         return mtxBindings.at(idx).mtxs; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void weightVertex(HECL::BlenderConnection::PyOutStream& os, const CINF& cinf, atInt16 skinIdx) const |     void weightVertex(hecl::BlenderConnection::PyOutStream& os, const CINF& cinf, atInt16 skinIdx) const | ||||||
|     { |     { | ||||||
|         if (skinIdx < 0) |         if (skinIdx < 0) | ||||||
|             return; |             return; | ||||||
|  | |||||||
| @ -14,7 +14,7 @@ namespace DataSpec | |||||||
| { | { | ||||||
| namespace DNAMP3 | namespace DNAMP3 | ||||||
| { | { | ||||||
| LogVisor::LogModule Log("Retro::DNAMP3"); | logvisor::Module Log("urde::DNAMP3"); | ||||||
| 
 | 
 | ||||||
| static bool GetNoShare(const std::string& name) | static bool GetNoShare(const std::string& name) | ||||||
| { | { | ||||||
| @ -25,16 +25,16 @@ static bool GetNoShare(const std::string& name) | |||||||
|     return true; |     return true; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| PAKBridge::PAKBridge(HECL::Database::Project& project, | PAKBridge::PAKBridge(hecl::Database::Project& project, | ||||||
|                      const NOD::Node& node, |                      const nod::Node& node, | ||||||
|                      bool doExtract) |                      bool doExtract) | ||||||
| : m_project(project), m_node(node), m_pak(GetNoShare(node.getName())), m_doExtract(doExtract) | : m_project(project), m_node(node), m_pak(GetNoShare(node.getName())), m_doExtract(doExtract) | ||||||
| { | { | ||||||
|     NOD::AthenaPartReadStream rs(node.beginReadStream()); |     nod::AthenaPartReadStream rs(node.beginReadStream()); | ||||||
|     m_pak.read(rs); |     m_pak.read(rs); | ||||||
| 
 | 
 | ||||||
|     /* Append Level String */ |     /* Append Level String */ | ||||||
|     std::set<HECL::SystemString, HECL::CaseInsensitiveCompare> uniq; |     std::set<hecl::SystemString, hecl::CaseInsensitiveCompare> uniq; | ||||||
|     for (PAK::Entry& entry : m_pak.m_entries) |     for (PAK::Entry& entry : m_pak.m_entries) | ||||||
|     { |     { | ||||||
|         if (entry.type == FOURCC('MLVL')) |         if (entry.type == FOURCC('MLVL')) | ||||||
| @ -53,7 +53,7 @@ PAKBridge::PAKBridge(HECL::Database::Project& project, | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     bool comma = false; |     bool comma = false; | ||||||
|     for (const HECL::SystemString& str : uniq) |     for (const hecl::SystemString& str : uniq) | ||||||
|     { |     { | ||||||
|         if (comma) |         if (comma) | ||||||
|             m_levelString += _S(", "); |             m_levelString += _S(", "); | ||||||
| @ -62,12 +62,12 @@ PAKBridge::PAKBridge(HECL::Database::Project& project, | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| static HECL::SystemString LayerName(const std::string& name) | static hecl::SystemString LayerName(const std::string& name) | ||||||
| { | { | ||||||
| #if HECL_UCS2 | #if HECL_UCS2 | ||||||
|     HECL::SystemString ret = HECL::UTF8ToWide(name); |     hecl::SystemString ret = hecl::UTF8ToWide(name); | ||||||
| #else | #else | ||||||
|     HECL::SystemString ret = name; |     hecl::SystemString ret = name; | ||||||
| #endif | #endif | ||||||
|     for (auto& ch : ret) |     for (auto& ch : ret) | ||||||
|         if (ch == _S('/') || ch == _S('\\')) |         if (ch == _S('/') || ch == _S('\\')) | ||||||
| @ -90,7 +90,7 @@ void PAKBridge::build() | |||||||
|                 mlvl.read(rs); |                 mlvl.read(rs); | ||||||
|             } |             } | ||||||
| #if HECL_UCS2 | #if HECL_UCS2 | ||||||
|             level.name = HECL::UTF8ToWide(m_pak.bestEntryName(entry)); |             level.name = hecl::UTF8ToWide(m_pak.bestEntryName(entry)); | ||||||
| #else | #else | ||||||
|             level.name = m_pak.bestEntryName(entry); |             level.name = m_pak.bestEntryName(entry); | ||||||
| #endif | #endif | ||||||
| @ -103,7 +103,7 @@ void PAKBridge::build() | |||||||
|             if (worldMapEnt) |             if (worldMapEnt) | ||||||
|             { |             { | ||||||
|                 PAKEntryReadStream rs = worldMapEnt->beginReadStream(m_node); |                 PAKEntryReadStream rs = worldMapEnt->beginReadStream(m_node); | ||||||
|                 rs.seek(8, Athena::Current); |                 rs.seek(8, athena::Current); | ||||||
|                 atUint32 areaCount = rs.readUint32Big(); |                 atUint32 areaCount = rs.readUint32Big(); | ||||||
|                 mapw.reserve(areaCount); |                 mapw.reserve(areaCount); | ||||||
|                 for (atUint32 i=0 ; i<areaCount ; ++i) |                 for (atUint32 i=0 ; i<areaCount ; ++i) | ||||||
| @ -138,21 +138,21 @@ void PAKBridge::build() | |||||||
|                 if (areaDeps.name.empty()) |                 if (areaDeps.name.empty()) | ||||||
|                 { |                 { | ||||||
| #if HECL_UCS2 | #if HECL_UCS2 | ||||||
|                     areaDeps.name = HECL::UTF8ToWide(area.internalAreaName); |                     areaDeps.name = hecl::UTF8ToWide(area.internalAreaName); | ||||||
| #else | #else | ||||||
|                     areaDeps.name = area.internalAreaName; |                     areaDeps.name = area.internalAreaName; | ||||||
| #endif | #endif | ||||||
|                     if (areaDeps.name.empty()) |                     if (areaDeps.name.empty()) | ||||||
|                     { |                     { | ||||||
| #if HECL_UCS2 | #if HECL_UCS2 | ||||||
|                         areaDeps.name = _S("MREA_") + HECL::UTF8ToWide(area.areaMREAId.toString()); |                         areaDeps.name = _S("MREA_") + hecl::UTF8ToWide(area.areaMREAId.toString()); | ||||||
| #else | #else | ||||||
|                         areaDeps.name = "MREA_" + area.areaMREAId.toString(); |                         areaDeps.name = "MREA_" + area.areaMREAId.toString(); | ||||||
| #endif | #endif | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|                 HECL::SystemChar num[16]; |                 hecl::SystemChar num[16]; | ||||||
|                 HECL::SNPrintf(num, 16, _S("%02u "), ai); |                 hecl::SNPrintf(num, 16, _S("%02u "), ai); | ||||||
|                 areaDeps.name = num + areaDeps.name; |                 areaDeps.name = num + areaDeps.name; | ||||||
| 
 | 
 | ||||||
|                 const MLVL::LayerFlags& layerFlags = *layerFlagsIt++; |                 const MLVL::LayerFlags& layerFlags = *layerFlagsIt++; | ||||||
| @ -173,7 +173,7 @@ void PAKBridge::build() | |||||||
|                         while (layer.name.size() && isspace(layer.name.back())) |                         while (layer.name.size() && isspace(layer.name.back())) | ||||||
|                             layer.name.pop_back(); |                             layer.name.pop_back(); | ||||||
|     #endif |     #endif | ||||||
|                         HECL::SNPrintf(num, 16, layer.active ? _S("%02ua ") : _S("%02u "), l-1); |                         hecl::SNPrintf(num, 16, layer.active ? _S("%02ua ") : _S("%02u "), l-1); | ||||||
|                         layer.name = num + layer.name; |                         layer.name = num + layer.name; | ||||||
|                     } |                     } | ||||||
|                 } |                 } | ||||||
|  | |||||||
| @ -9,31 +9,31 @@ namespace DataSpec | |||||||
| namespace DNAMP3 | namespace DNAMP3 | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| extern LogVisor::LogModule Log; | extern logvisor::Module Log; | ||||||
| 
 | 
 | ||||||
| /* MP3-specific, one-shot PAK traversal/extraction class */ | /* MP3-specific, one-shot PAK traversal/extraction class */ | ||||||
| class PAKBridge | class PAKBridge | ||||||
| { | { | ||||||
|     HECL::Database::Project& m_project; |     hecl::Database::Project& m_project; | ||||||
|     const NOD::Node& m_node; |     const nod::Node& m_node; | ||||||
|     PAK m_pak; |     PAK m_pak; | ||||||
| public: | public: | ||||||
|     bool m_doExtract; |     bool m_doExtract; | ||||||
|     using Level = Level<UniqueID64>; |     using Level = Level<UniqueID64>; | ||||||
|     std::unordered_map<UniqueID64, Level> m_levelDeps; |     std::unordered_map<UniqueID64, Level> m_levelDeps; | ||||||
|     HECL::SystemString m_levelString; |     hecl::SystemString m_levelString; | ||||||
| 
 | 
 | ||||||
|     PAKBridge(HECL::Database::Project& project, |     PAKBridge(hecl::Database::Project& project, | ||||||
|               const NOD::Node& node, |               const nod::Node& node, | ||||||
|               bool doExtract=true); |               bool doExtract=true); | ||||||
|     void build(); |     void build(); | ||||||
|     static ResExtractor<PAKBridge> LookupExtractor(const PAK::Entry& entry); |     static ResExtractor<PAKBridge> LookupExtractor(const PAK::Entry& entry); | ||||||
|     inline const std::string& getName() const {return m_node.getName();} |     inline const std::string& getName() const {return m_node.getName();} | ||||||
|     inline HECL::SystemString getLevelString() const {return m_levelString;} |     inline hecl::SystemString getLevelString() const {return m_levelString;} | ||||||
| 
 | 
 | ||||||
|     using PAKType = PAK; |     using PAKType = PAK; | ||||||
|     inline const PAKType& getPAK() const {return m_pak;} |     inline const PAKType& getPAK() const {return m_pak;} | ||||||
|     inline const NOD::Node& getNode() const {return m_node;} |     inline const nod::Node& getNode() const {return m_node;} | ||||||
| 
 | 
 | ||||||
|     void addCMDLRigPairs(PAKRouter<PAKBridge>& pakRouter, |     void addCMDLRigPairs(PAKRouter<PAKBridge>& pakRouter, | ||||||
|             std::unordered_map<UniqueID64, std::pair<UniqueID64, UniqueID64>>& addTo) const; |             std::unordered_map<UniqueID64, std::pair<UniqueID64, UniqueID64>>& addTo) const; | ||||||
|  | |||||||
| @ -13,15 +13,15 @@ struct MAPA : DNAMAPA::MAPA | |||||||
| { | { | ||||||
|     static bool Extract(const SpecBase& dataSpec, |     static bool Extract(const SpecBase& dataSpec, | ||||||
|                         PAKEntryReadStream& rs, |                         PAKEntryReadStream& rs, | ||||||
|                         const HECL::ProjectPath& outPath, |                         const hecl::ProjectPath& outPath, | ||||||
|                         PAKRouter<PAKBridge>& pakRouter, |                         PAKRouter<PAKBridge>& pakRouter, | ||||||
|                         const PAK::Entry& entry, |                         const PAK::Entry& entry, | ||||||
|                         bool force, |                         bool force, | ||||||
|                         std::function<void(const HECL::SystemChar*)> fileChanged) |                         std::function<void(const hecl::SystemChar*)> fileChanged) | ||||||
|     { |     { | ||||||
|         MAPA mapa; |         MAPA mapa; | ||||||
|         mapa.read(rs); |         mapa.read(rs); | ||||||
|         HECL::BlenderConnection& conn = HECL::BlenderConnection::SharedConnection(); |         hecl::BlenderConnection& conn = hecl::BlenderConnection::SharedConnection(); | ||||||
|         return DNAMAPA::ReadMAPAToBlender(conn, mapa, outPath, pakRouter, entry, force); |         return DNAMAPA::ReadMAPAToBlender(conn, mapa, outPath, pakRouter, entry, force); | ||||||
|     } |     } | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -80,18 +80,18 @@ struct MLVL : BigYAML | |||||||
| 
 | 
 | ||||||
|     static bool Extract(const SpecBase& dataSpec, |     static bool Extract(const SpecBase& dataSpec, | ||||||
|                         PAKEntryReadStream& rs, |                         PAKEntryReadStream& rs, | ||||||
|                         const HECL::ProjectPath& outPath, |                         const hecl::ProjectPath& outPath, | ||||||
|                         PAKRouter<PAKBridge>& pakRouter, |                         PAKRouter<PAKBridge>& pakRouter, | ||||||
|                         const PAK::Entry& entry, |                         const PAK::Entry& entry, | ||||||
|                         bool force, |                         bool force, | ||||||
|                         std::function<void(const HECL::SystemChar*)> fileChanged) |                         std::function<void(const hecl::SystemChar*)> fileChanged) | ||||||
|     { |     { | ||||||
|         MLVL mlvl; |         MLVL mlvl; | ||||||
|         mlvl.read(rs); |         mlvl.read(rs); | ||||||
|         FILE* fp = HECL::Fopen(outPath.getWithExtension(_S(".yaml"), true).getAbsolutePath().c_str(), _S("wb")); |         FILE* fp = hecl::Fopen(outPath.getWithExtension(_S(".yaml"), true).getAbsolutePath().c_str(), _S("wb")); | ||||||
|         mlvl.toYAMLFile(fp); |         mlvl.toYAMLFile(fp); | ||||||
|         fclose(fp); |         fclose(fp); | ||||||
|         HECL::BlenderConnection& conn = HECL::BlenderConnection::SharedConnection(); |         hecl::BlenderConnection& conn = hecl::BlenderConnection::SharedConnection(); | ||||||
|         return DNAMLVL::ReadMLVLToBlender(conn, mlvl, outPath, pakRouter, |         return DNAMLVL::ReadMLVLToBlender(conn, mlvl, outPath, pakRouter, | ||||||
|                                           entry, force, fileChanged); |                                           entry, force, fileChanged); | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -1,4 +1,4 @@ | |||||||
| #include <Athena/FileWriter.hpp> | #include <athena/FileWriter.hpp> | ||||||
| #include "MREA.hpp" | #include "MREA.hpp" | ||||||
| #include "../DNAMP2/DeafBabe.hpp" | #include "../DNAMP2/DeafBabe.hpp" | ||||||
| #include "../DNACommon/BabeDead.hpp" | #include "../DNACommon/BabeDead.hpp" | ||||||
| @ -8,7 +8,7 @@ namespace DataSpec | |||||||
| namespace DNAMP3 | namespace DNAMP3 | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| MREA::StreamReader::StreamReader(Athena::io::IStreamReader& source, | MREA::StreamReader::StreamReader(athena::io::IStreamReader& source, | ||||||
|                                  atUint32 blkCount, atUint32 secIdxCount) |                                  atUint32 blkCount, atUint32 secIdxCount) | ||||||
| : DNAMP2::MREA::StreamReader(source) | : DNAMP2::MREA::StreamReader(source) | ||||||
| { | { | ||||||
| @ -35,7 +35,7 @@ MREA::StreamReader::StreamReader(Athena::io::IStreamReader& source, | |||||||
|     nextBlock(); |     nextBlock(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void MREA::StreamReader::writeSecIdxs(Athena::io::IStreamWriter& writer) const | void MREA::StreamReader::writeSecIdxs(athena::io::IStreamWriter& writer) const | ||||||
| { | { | ||||||
|     for (const std::pair<DNAFourCC, atUint32>& idx : m_secIdxs) |     for (const std::pair<DNAFourCC, atUint32>& idx : m_secIdxs) | ||||||
|     { |     { | ||||||
| @ -44,12 +44,12 @@ void MREA::StreamReader::writeSecIdxs(Athena::io::IStreamWriter& writer) const | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void MREA::ReadBabeDeadToBlender_3(HECL::BlenderConnection::PyOutStream& os, | void MREA::ReadBabeDeadToBlender_3(hecl::BlenderConnection::PyOutStream& os, | ||||||
|                                    Athena::io::IStreamReader& rs) |                                    athena::io::IStreamReader& rs) | ||||||
| { | { | ||||||
|     atUint32 bdMagic = rs.readUint32Big(); |     atUint32 bdMagic = rs.readUint32Big(); | ||||||
|     if (bdMagic != 0xBABEDEAD) |     if (bdMagic != 0xBABEDEAD) | ||||||
|         Log.report(LogVisor::FatalError, "invalid BABEDEAD magic"); |         Log.report(logvisor::Fatal, "invalid BABEDEAD magic"); | ||||||
|     os << "bpy.context.scene.render.engine = 'CYCLES'\n" |     os << "bpy.context.scene.render.engine = 'CYCLES'\n" | ||||||
|           "bpy.context.scene.world.use_nodes = True\n" |           "bpy.context.scene.world.use_nodes = True\n" | ||||||
|           "bpy.context.scene.render.engine = 'BLENDER_GAME'\n" |           "bpy.context.scene.render.engine = 'BLENDER_GAME'\n" | ||||||
| @ -68,18 +68,18 @@ void MREA::ReadBabeDeadToBlender_3(HECL::BlenderConnection::PyOutStream& os, | |||||||
| 
 | 
 | ||||||
| bool MREA::Extract(const SpecBase& dataSpec, | bool MREA::Extract(const SpecBase& dataSpec, | ||||||
|                    PAKEntryReadStream& rs, |                    PAKEntryReadStream& rs, | ||||||
|                    const HECL::ProjectPath& outPath, |                    const hecl::ProjectPath& outPath, | ||||||
|                    PAKRouter<PAKBridge>& pakRouter, |                    PAKRouter<PAKBridge>& pakRouter, | ||||||
|                    const PAK::Entry& entry, |                    const PAK::Entry& entry, | ||||||
|                    bool force, |                    bool force, | ||||||
|                    std::function<void(const HECL::SystemChar*)>) |                    std::function<void(const hecl::SystemChar*)>) | ||||||
| { | { | ||||||
|     using RigPair = std::pair<CSKR*, CINF*>; |     using RigPair = std::pair<CSKR*, CINF*>; | ||||||
|     RigPair dummy(nullptr, nullptr); |     RigPair dummy(nullptr, nullptr); | ||||||
| 
 | 
 | ||||||
|     /* Rename MREA for consistency */ |     /* Rename MREA for consistency */ | ||||||
|     HECL::ProjectPath mreaPath(outPath.getParentPath(), _S("!area.blend")); |     hecl::ProjectPath mreaPath(outPath.getParentPath(), _S("!area.blend")); | ||||||
|     if (!force && mreaPath.getPathType() == HECL::ProjectPath::Type::File) |     if (!force && mreaPath.getPathType() == hecl::ProjectPath::Type::File) | ||||||
|         return true; |         return true; | ||||||
| 
 | 
 | ||||||
|     /* Do extract */ |     /* Do extract */ | ||||||
| @ -89,7 +89,7 @@ bool MREA::Extract(const SpecBase& dataSpec, | |||||||
| 
 | 
 | ||||||
|     /* MREA decompression stream */ |     /* MREA decompression stream */ | ||||||
|     StreamReader drs(rs, head.compressedBlockCount, head.secIndexCount); |     StreamReader drs(rs, head.compressedBlockCount, head.secIndexCount); | ||||||
|     Athena::io::FileWriter mreaDecompOut(pakRouter.getCooked(&entry).getWithExtension(_S(".decomp")).getAbsolutePath()); |     athena::io::FileWriter mreaDecompOut(pakRouter.getCooked(&entry).getWithExtension(_S(".decomp")).getAbsolutePath()); | ||||||
|     head.write(mreaDecompOut); |     head.write(mreaDecompOut); | ||||||
|     mreaDecompOut.seekAlign32(); |     mreaDecompOut.seekAlign32(); | ||||||
|     drs.writeDecompInfos(mreaDecompOut); |     drs.writeDecompInfos(mreaDecompOut); | ||||||
| @ -99,16 +99,16 @@ bool MREA::Extract(const SpecBase& dataSpec, | |||||||
|     atUint64 decompLen = drs.length(); |     atUint64 decompLen = drs.length(); | ||||||
|     mreaDecompOut.writeBytes(drs.readBytes(decompLen).get(), decompLen); |     mreaDecompOut.writeBytes(drs.readBytes(decompLen).get(), decompLen); | ||||||
|     mreaDecompOut.close(); |     mreaDecompOut.close(); | ||||||
|     drs.seek(0, Athena::Begin); |     drs.seek(0, athena::Begin); | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|     /* Start up blender connection */ |     /* Start up blender connection */ | ||||||
|     HECL::BlenderConnection& conn = HECL::BlenderConnection::SharedConnection(); |     hecl::BlenderConnection& conn = hecl::BlenderConnection::SharedConnection(); | ||||||
|     if (!conn.createBlend(mreaPath, HECL::BlenderConnection::BlendType::Area)) |     if (!conn.createBlend(mreaPath, hecl::BlenderConnection::BlendType::Area)) | ||||||
|         return false; |         return false; | ||||||
| 
 | 
 | ||||||
|     /* Open Py Stream and read sections */ |     /* Open Py Stream and read sections */ | ||||||
|     HECL::BlenderConnection::PyOutStream os = conn.beginPythonOut(true); |     hecl::BlenderConnection::PyOutStream os = conn.beginPythonOut(true); | ||||||
|     os.format("import bpy\n" |     os.format("import bpy\n" | ||||||
|               "import bmesh\n" |               "import bmesh\n" | ||||||
|               "from mathutils import Vector\n" |               "from mathutils import Vector\n" | ||||||
| @ -133,7 +133,7 @@ bool MREA::Extract(const SpecBase& dataSpec, | |||||||
|     atUint64 secStart = drs.position(); |     atUint64 secStart = drs.position(); | ||||||
|     matSet.read(drs); |     matSet.read(drs); | ||||||
|     matSet.readToBlender(os, pakRouter, entry, 0); |     matSet.readToBlender(os, pakRouter, entry, 0); | ||||||
|     drs.seek(secStart + head.secSizes[0], Athena::Begin); |     drs.seek(secStart + head.secSizes[0], athena::Begin); | ||||||
|     std::vector<DNACMDL::VertexAttributes> vertAttribs; |     std::vector<DNACMDL::VertexAttributes> vertAttribs; | ||||||
|     DNACMDL::GetVertexAttributes(matSet, vertAttribs); |     DNACMDL::GetVertexAttributes(matSet, vertAttribs); | ||||||
| 
 | 
 | ||||||
| @ -147,16 +147,16 @@ bool MREA::Extract(const SpecBase& dataSpec, | |||||||
|         MeshHeader mHeader; |         MeshHeader mHeader; | ||||||
|         secStart = drs.position(); |         secStart = drs.position(); | ||||||
|         mHeader.read(drs); |         mHeader.read(drs); | ||||||
|         drs.seek(secStart + head.secSizes[curSec++], Athena::Begin); |         drs.seek(secStart + head.secSizes[curSec++], athena::Begin); | ||||||
| 
 | 
 | ||||||
|         /* Surface count from here */ |         /* Surface count from here */ | ||||||
|         secStart = drs.position(); |         secStart = drs.position(); | ||||||
|         surfaceCounts.push_back(drs.readUint32Big()); |         surfaceCounts.push_back(drs.readUint32Big()); | ||||||
|         drs.seek(secStart + head.secSizes[curSec++], Athena::Begin); |         drs.seek(secStart + head.secSizes[curSec++], athena::Begin); | ||||||
| 
 | 
 | ||||||
|         /* Seek through AROT-relation sections */ |         /* Seek through AROT-relation sections */ | ||||||
|         drs.seek(head.secSizes[curSec++], Athena::Current); |         drs.seek(head.secSizes[curSec++], athena::Current); | ||||||
|         drs.seek(head.secSizes[curSec++], Athena::Current); |         drs.seek(head.secSizes[curSec++], athena::Current); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /* Skip though WOBJs */ |     /* Skip though WOBJs */ | ||||||
| @ -167,14 +167,14 @@ bool MREA::Extract(const SpecBase& dataSpec, | |||||||
|     /* Skip AROT */ |     /* Skip AROT */ | ||||||
|     if (secIdxIt->first == FOURCC('ROCT')) |     if (secIdxIt->first == FOURCC('ROCT')) | ||||||
|     { |     { | ||||||
|         drs.seek(head.secSizes[curSec++], Athena::Current); |         drs.seek(head.secSizes[curSec++], athena::Current); | ||||||
|         ++secIdxIt; |         ++secIdxIt; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /* Skip AABB */ |     /* Skip AABB */ | ||||||
|     if (secIdxIt->first == FOURCC('AABB')) |     if (secIdxIt->first == FOURCC('AABB')) | ||||||
|     { |     { | ||||||
|         drs.seek(head.secSizes[curSec++], Athena::Current); |         drs.seek(head.secSizes[curSec++], athena::Current); | ||||||
|         ++secIdxIt; |         ++secIdxIt; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -193,7 +193,7 @@ bool MREA::Extract(const SpecBase& dataSpec, | |||||||
|     /* Skip DEPS */ |     /* Skip DEPS */ | ||||||
|     if (secIdxIt->first == FOURCC('DEPS')) |     if (secIdxIt->first == FOURCC('DEPS')) | ||||||
|     { |     { | ||||||
|         drs.seek(head.secSizes[curSec++], Athena::Current); |         drs.seek(head.secSizes[curSec++], athena::Current); | ||||||
|         ++secIdxIt; |         ++secIdxIt; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -201,14 +201,14 @@ bool MREA::Extract(const SpecBase& dataSpec, | |||||||
|     if (secIdxIt->first == FOURCC('SOBJ')) |     if (secIdxIt->first == FOURCC('SOBJ')) | ||||||
|     { |     { | ||||||
|         for (atUint32 l=0 ; l<head.sclyLayerCount ; ++l) |         for (atUint32 l=0 ; l<head.sclyLayerCount ; ++l) | ||||||
|             drs.seek(head.secSizes[curSec++], Athena::Current); |             drs.seek(head.secSizes[curSec++], athena::Current); | ||||||
|         ++secIdxIt; |         ++secIdxIt; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     /* Skip SGEN */ |     /* Skip SGEN */ | ||||||
|     if (secIdxIt->first == FOURCC('SGEN')) |     if (secIdxIt->first == FOURCC('SGEN')) | ||||||
|     { |     { | ||||||
|         drs.seek(head.secSizes[curSec++], Athena::Current); |         drs.seek(head.secSizes[curSec++], athena::Current); | ||||||
|         ++secIdxIt; |         ++secIdxIt; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -220,7 +220,7 @@ bool MREA::Extract(const SpecBase& dataSpec, | |||||||
|         collision.read(drs); |         collision.read(drs); | ||||||
|         DNAMP2::DeafBabe::BlenderInit(os); |         DNAMP2::DeafBabe::BlenderInit(os); | ||||||
|         collision.sendToBlender(os); |         collision.sendToBlender(os); | ||||||
|         drs.seek(secStart + head.secSizes[curSec++], Athena::Begin); |         drs.seek(secStart + head.secSizes[curSec++], athena::Begin); | ||||||
|         ++secIdxIt; |         ++secIdxIt; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -229,7 +229,7 @@ bool MREA::Extract(const SpecBase& dataSpec, | |||||||
|     { |     { | ||||||
|         secStart = drs.position(); |         secStart = drs.position(); | ||||||
|         ReadBabeDeadToBlender_3(os, drs); |         ReadBabeDeadToBlender_3(os, drs); | ||||||
|         drs.seek(secStart + head.secSizes[curSec++], Athena::Begin); |         drs.seek(secStart + head.secSizes[curSec++], athena::Begin); | ||||||
|         ++secIdxIt; |         ++secIdxIt; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -258,7 +258,7 @@ bool MREA::ExtractLayerDeps(PAKEntryReadStream& rs, PAKBridge::Level::Area& area | |||||||
|     { |     { | ||||||
|         if (idx.first == FOURCC('DEPS')) |         if (idx.first == FOURCC('DEPS')) | ||||||
|         { |         { | ||||||
|             drs.seek(head.getSecOffset(idx.second), Athena::Begin); |             drs.seek(head.getSecOffset(idx.second), athena::Begin); | ||||||
|             DEPS deps; |             DEPS deps; | ||||||
|             deps.read(drs); |             deps.read(drs); | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -16,13 +16,13 @@ struct MREA | |||||||
|     struct StreamReader : DNAMP2::MREA::StreamReader |     struct StreamReader : DNAMP2::MREA::StreamReader | ||||||
|     { |     { | ||||||
|         std::vector<std::pair<DNAFourCC, atUint32>> m_secIdxs; |         std::vector<std::pair<DNAFourCC, atUint32>> m_secIdxs; | ||||||
|         StreamReader(Athena::io::IStreamReader& source, |         StreamReader(athena::io::IStreamReader& source, | ||||||
|                      atUint32 blkCount, atUint32 secIdxCount); |                      atUint32 blkCount, atUint32 secIdxCount); | ||||||
|         std::vector<std::pair<DNAFourCC, atUint32>>::const_iterator beginSecIdxs() |         std::vector<std::pair<DNAFourCC, atUint32>>::const_iterator beginSecIdxs() | ||||||
|         { |         { | ||||||
|             return m_secIdxs.begin(); |             return m_secIdxs.begin(); | ||||||
|         } |         } | ||||||
|         void writeSecIdxs(Athena::io::IStreamWriter& writer) const; |         void writeSecIdxs(athena::io::IStreamWriter& writer) const; | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     struct Header : BigDNA |     struct Header : BigDNA | ||||||
| @ -36,7 +36,7 @@ struct MREA | |||||||
|         Value<atUint32> secCount; |         Value<atUint32> secCount; | ||||||
|         Value<atUint32> compressedBlockCount; |         Value<atUint32> compressedBlockCount; | ||||||
|         Value<atUint32> secIndexCount; |         Value<atUint32> secIndexCount; | ||||||
|         Seek<20, Athena::Current> align1; |         Seek<20, athena::Current> align1; | ||||||
|         Vector<atUint32, DNA_COUNT(secCount)> secSizes; |         Vector<atUint32, DNA_COUNT(secCount)> secSizes; | ||||||
| 
 | 
 | ||||||
|         atUint32 getSecOffset(atUint32 idx) const |         atUint32 getSecOffset(atUint32 idx) const | ||||||
| @ -111,16 +111,16 @@ struct MREA | |||||||
|         Value<atUint32> unk13; |         Value<atUint32> unk13; | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     static void ReadBabeDeadToBlender_3(HECL::BlenderConnection::PyOutStream& os, |     static void ReadBabeDeadToBlender_3(hecl::BlenderConnection::PyOutStream& os, | ||||||
|                                         Athena::io::IStreamReader& rs); |                                         athena::io::IStreamReader& rs); | ||||||
| 
 | 
 | ||||||
|     static bool Extract(const SpecBase& dataSpec, |     static bool Extract(const SpecBase& dataSpec, | ||||||
|                         PAKEntryReadStream& rs, |                         PAKEntryReadStream& rs, | ||||||
|                         const HECL::ProjectPath& outPath, |                         const hecl::ProjectPath& outPath, | ||||||
|                         PAKRouter<PAKBridge>& pakRouter, |                         PAKRouter<PAKBridge>& pakRouter, | ||||||
|                         const PAK::Entry& entry, |                         const PAK::Entry& entry, | ||||||
|                         bool, |                         bool, | ||||||
|                         std::function<void(const HECL::SystemChar*)>); |                         std::function<void(const hecl::SystemChar*)>); | ||||||
| 
 | 
 | ||||||
|     static bool ExtractLayerDeps(PAKEntryReadStream& rs, PAKBridge::Level::Area& areaOut); |     static bool ExtractLayerDeps(PAKEntryReadStream& rs, PAKBridge::Level::Area& areaOut); | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -6,19 +6,19 @@ namespace DataSpec | |||||||
| namespace DNAMP3 | namespace DNAMP3 | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| const HECL::FourCC CMPD("CMPD"); | const hecl::FourCC CMPD("CMPD"); | ||||||
| 
 | 
 | ||||||
| void PAK::read(Athena::io::IStreamReader& reader) | void PAK::read(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     m_header.read(reader); |     m_header.read(reader); | ||||||
|     if (m_header.version != 2) |     if (m_header.version != 2) | ||||||
|         Log.report(LogVisor::FatalError, "unexpected PAK magic"); |         Log.report(logvisor::Fatal, "unexpected PAK magic"); | ||||||
| 
 | 
 | ||||||
|     reader.seek(8, Athena::Current); |     reader.seek(8, athena::Current); | ||||||
|     atUint32 strgSz = reader.readUint32Big(); |     atUint32 strgSz = reader.readUint32Big(); | ||||||
|     reader.seek(4, Athena::Current); |     reader.seek(4, athena::Current); | ||||||
|     atUint32 rshdSz = reader.readUint32Big(); |     atUint32 rshdSz = reader.readUint32Big(); | ||||||
|     reader.seek(44, Athena::Current); |     reader.seek(44, athena::Current); | ||||||
|     atUint32 dataOffset = 128 + strgSz + rshdSz; |     atUint32 dataOffset = 128 + strgSz + rshdSz; | ||||||
| 
 | 
 | ||||||
|     atUint64 strgBase = reader.position(); |     atUint64 strgBase = reader.position(); | ||||||
| @ -30,7 +30,7 @@ void PAK::read(Athena::io::IStreamReader& reader) | |||||||
|         m_nameEntries.emplace_back(); |         m_nameEntries.emplace_back(); | ||||||
|         m_nameEntries.back().read(reader); |         m_nameEntries.back().read(reader); | ||||||
|     } |     } | ||||||
|     reader.seek(strgBase + strgSz, Athena::Begin); |     reader.seek(strgBase + strgSz, athena::Begin); | ||||||
| 
 | 
 | ||||||
|     atUint32 count = reader.readUint32Big(); |     atUint32 count = reader.readUint32Big(); | ||||||
|     m_entries.clear(); |     m_entries.clear(); | ||||||
| @ -67,7 +67,7 @@ void PAK::read(Athena::io::IStreamReader& reader) | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
| void PAK::write(Athena::io::IStreamWriter& writer) const | void PAK::write(athena::io::IStreamWriter& writer) const | ||||||
| { | { | ||||||
|     m_header.write(writer); |     m_header.write(writer); | ||||||
| 
 | 
 | ||||||
| @ -93,12 +93,12 @@ void PAK::write(Athena::io::IStreamWriter& writer) const | |||||||
|     atUint32 dataPad = ((dataSz + 63) & ~63) - dataSz; |     atUint32 dataPad = ((dataSz + 63) & ~63) - dataSz; | ||||||
|     dataSz += dataPad; |     dataSz += dataPad; | ||||||
|     writer.writeUint32Big(dataSz); |     writer.writeUint32Big(dataSz); | ||||||
|     writer.seek(36, Athena::Current); |     writer.seek(36, athena::Current); | ||||||
| 
 | 
 | ||||||
|     writer.writeUint32Big((atUint32)m_nameEntries.size()); |     writer.writeUint32Big((atUint32)m_nameEntries.size()); | ||||||
|     for (const NameEntry& entry : m_nameEntries) |     for (const NameEntry& entry : m_nameEntries) | ||||||
|         entry.write(writer); |         entry.write(writer); | ||||||
|     writer.seek(strgPad, Athena::Current); |     writer.seek(strgPad, athena::Current); | ||||||
| 
 | 
 | ||||||
|     writer.writeUint32Big((atUint32)m_entries.size()); |     writer.writeUint32Big((atUint32)m_entries.size()); | ||||||
|     for (const Entry& entry : m_entries) |     for (const Entry& entry : m_entries) | ||||||
| @ -107,7 +107,7 @@ void PAK::write(Athena::io::IStreamWriter& writer) const | |||||||
|         copy.offset -= dataOffset; |         copy.offset -= dataOffset; | ||||||
|         copy.write(writer); |         copy.write(writer); | ||||||
|     } |     } | ||||||
|     writer.seek(rshdPad, Athena::Current); |     writer.seek(rshdPad, athena::Current); | ||||||
| } | } | ||||||
| size_t PAK::binarySize(size_t __isz) const | size_t PAK::binarySize(size_t __isz) const | ||||||
| { | { | ||||||
| @ -136,23 +136,23 @@ size_t PAK::binarySize(size_t __isz) const | |||||||
|     return __isz; |     return __isz; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| std::unique_ptr<atUint8[]> PAK::Entry::getBuffer(const NOD::Node& pak, atUint64& szOut) const | std::unique_ptr<atUint8[]> PAK::Entry::getBuffer(const nod::Node& pak, atUint64& szOut) const | ||||||
| { | { | ||||||
|     if (compressed) |     if (compressed) | ||||||
|     { |     { | ||||||
|         std::unique_ptr<NOD::IPartReadStream> strm = pak.beginReadStream(offset); |         std::unique_ptr<nod::IPartReadStream> strm = pak.beginReadStream(offset); | ||||||
|         struct |         struct | ||||||
|         { |         { | ||||||
|             HECL::FourCC magic; |             hecl::FourCC magic; | ||||||
|             atUint32 blockCount; |             atUint32 blockCount; | ||||||
|         } head; |         } head; | ||||||
|         strm->read(&head, 8); |         strm->read(&head, 8); | ||||||
|         if (head.magic != CMPD) |         if (head.magic != CMPD) | ||||||
|         { |         { | ||||||
|             Log.report(LogVisor::Error, "invalid CMPD block"); |             Log.report(logvisor::Error, "invalid CMPD block"); | ||||||
|             return std::unique_ptr<atUint8[]>(); |             return std::unique_ptr<atUint8[]>(); | ||||||
|         } |         } | ||||||
|         head.blockCount = HECL::SBig(head.blockCount); |         head.blockCount = hecl::SBig(head.blockCount); | ||||||
| 
 | 
 | ||||||
|         struct Block |         struct Block | ||||||
|         { |         { | ||||||
| @ -167,8 +167,8 @@ std::unique_ptr<atUint8[]> PAK::Entry::getBuffer(const NOD::Node& pak, atUint64& | |||||||
|         for (atUint32 b=0 ; b<head.blockCount ; ++b) |         for (atUint32 b=0 ; b<head.blockCount ; ++b) | ||||||
|         { |         { | ||||||
|             Block& block = blocks[b]; |             Block& block = blocks[b]; | ||||||
|             block.compSz = HECL::SBig(block.compSz) & 0xffffff; |             block.compSz = hecl::SBig(block.compSz) & 0xffffff; | ||||||
|             block.decompSz = HECL::SBig(block.decompSz); |             block.decompSz = hecl::SBig(block.decompSz); | ||||||
|             if (block.compSz > maxBlockSz) |             if (block.compSz > maxBlockSz) | ||||||
|                 maxBlockSz = block.compSz; |                 maxBlockSz = block.compSz; | ||||||
|             totalDecompSz += block.decompSz; |             totalDecompSz += block.decompSz; | ||||||
| @ -192,7 +192,7 @@ std::unique_ptr<atUint8[]> PAK::Entry::getBuffer(const NOD::Node& pak, atUint64& | |||||||
|                 atUint32 rem = block.decompSz; |                 atUint32 rem = block.decompSz; | ||||||
|                 while (rem) |                 while (rem) | ||||||
|                 { |                 { | ||||||
|                     atUint16 chunkSz = HECL::SBig(*(atUint16*)compBufCur); |                     atUint16 chunkSz = hecl::SBig(*(atUint16*)compBufCur); | ||||||
|                     compBufCur += 2; |                     compBufCur += 2; | ||||||
|                     lzo_uint dsz = rem; |                     lzo_uint dsz = rem; | ||||||
|                     lzo1x_decompress(compBufCur, chunkSz, bufCur, &dsz, nullptr); |                     lzo1x_decompress(compBufCur, chunkSz, bufCur, &dsz, nullptr); | ||||||
|  | |||||||
| @ -4,7 +4,7 @@ | |||||||
| #include <unordered_map> | #include <unordered_map> | ||||||
| 
 | 
 | ||||||
| #include <lzo/lzo1x.h> | #include <lzo/lzo1x.h> | ||||||
| #include <NOD/DiscBase.hpp> | #include <nod/DiscBase.hpp> | ||||||
| #include "../DNACommon/PAK.hpp" | #include "../DNACommon/PAK.hpp" | ||||||
| 
 | 
 | ||||||
| namespace DataSpec | namespace DataSpec | ||||||
| @ -12,7 +12,7 @@ namespace DataSpec | |||||||
| namespace DNAMP3 | namespace DNAMP3 | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| extern const HECL::FourCC CMPD; | extern const hecl::FourCC CMPD; | ||||||
| 
 | 
 | ||||||
| struct PAK : BigDNA | struct PAK : BigDNA | ||||||
| { | { | ||||||
| @ -25,7 +25,7 @@ struct PAK : BigDNA | |||||||
|         Value<atUint32> version; |         Value<atUint32> version; | ||||||
|         Value<atUint32> headSz; |         Value<atUint32> headSz; | ||||||
|         Value<atUint8> md5sum[16]; |         Value<atUint8> md5sum[16]; | ||||||
|         Seek<40, Athena::Current> seek; |         Seek<40, athena::Current> seek; | ||||||
|     } m_header; |     } m_header; | ||||||
| 
 | 
 | ||||||
|     struct NameEntry : BigDNA |     struct NameEntry : BigDNA | ||||||
| @ -47,8 +47,8 @@ struct PAK : BigDNA | |||||||
|         UniqueResult unique; |         UniqueResult unique; | ||||||
|         std::string name; |         std::string name; | ||||||
| 
 | 
 | ||||||
|         std::unique_ptr<atUint8[]> getBuffer(const NOD::Node& pak, atUint64& szOut) const; |         std::unique_ptr<atUint8[]> getBuffer(const nod::Node& pak, atUint64& szOut) const; | ||||||
|         inline PAKEntryReadStream beginReadStream(const NOD::Node& pak, atUint64 off=0) const |         inline PAKEntryReadStream beginReadStream(const nod::Node& pak, atUint64 off=0) const | ||||||
|         { |         { | ||||||
|             atUint64 sz; |             atUint64 sz; | ||||||
|             std::unique_ptr<atUint8[]> buf = getBuffer(pak, sz); |             std::unique_ptr<atUint8[]> buf = getBuffer(pak, sz); | ||||||
|  | |||||||
| @ -6,7 +6,7 @@ namespace DataSpec | |||||||
| namespace DNAMP3 | namespace DNAMP3 | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| void STRG::_read(Athena::io::IStreamReader& reader) | void STRG::_read(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     atUint32 langCount = reader.readUint32Big(); |     atUint32 langCount = reader.readUint32Big(); | ||||||
|     atUint32 strCount = reader.readUint32Big(); |     atUint32 strCount = reader.readUint32Big(); | ||||||
| @ -24,8 +24,8 @@ void STRG::_read(Athena::io::IStreamReader& reader) | |||||||
|         }* nameIndex = (NameIdxEntry*)nameTableBuf.get(); |         }* nameIndex = (NameIdxEntry*)nameTableBuf.get(); | ||||||
|         for (atUint32 n=0 ; n<nameCount ; ++n) |         for (atUint32 n=0 ; n<nameCount ; ++n) | ||||||
|         { |         { | ||||||
|             const char* name = (char*)(nameTableBuf.get() + HECL::SBig(nameIndex[n].nameOff)); |             const char* name = (char*)(nameTableBuf.get() + hecl::SBig(nameIndex[n].nameOff)); | ||||||
|             names[name] = HECL::SBig(nameIndex[n].strIdx); |             names[name] = hecl::SBig(nameIndex[n].strIdx); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -53,7 +53,7 @@ void STRG::_read(Athena::io::IStreamReader& reader) | |||||||
|         std::vector<std::string> strs; |         std::vector<std::string> strs; | ||||||
|         for (atUint32 s=0 ; s<strCount ; ++s) |         for (atUint32 s=0 ; s<strCount ; ++s) | ||||||
|         { |         { | ||||||
|             reader.seek(strBase + strOffs[l*strCount+s], Athena::Begin); |             reader.seek(strBase + strOffs[l*strCount+s], athena::Begin); | ||||||
|             atUint32 len = reader.readUint32Big(); |             atUint32 len = reader.readUint32Big(); | ||||||
|             strs.emplace_back(reader.readString(len)); |             strs.emplace_back(reader.readString(len)); | ||||||
|         } |         } | ||||||
| @ -66,28 +66,28 @@ void STRG::_read(Athena::io::IStreamReader& reader) | |||||||
|         langMap.emplace(item.first, &item.second); |         langMap.emplace(item.first, &item.second); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void STRG::read(Athena::io::IStreamReader& reader) | void STRG::read(athena::io::IStreamReader& reader) | ||||||
| { | { | ||||||
|     atUint32 magic = reader.readUint32Big(); |     atUint32 magic = reader.readUint32Big(); | ||||||
|     if (magic != 0x87654321) |     if (magic != 0x87654321) | ||||||
|     { |     { | ||||||
|         Log.report(LogVisor::Error, "invalid STRG magic"); |         Log.report(logvisor::Error, "invalid STRG magic"); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     atUint32 version = reader.readUint32Big(); |     atUint32 version = reader.readUint32Big(); | ||||||
|     if (version != 3) |     if (version != 3) | ||||||
|     { |     { | ||||||
|         Log.report(LogVisor::Error, "invalid STRG version"); |         Log.report(logvisor::Error, "invalid STRG version"); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     _read(reader); |     _read(reader); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void STRG::read(Athena::io::YAMLDocReader& reader) | void STRG::read(athena::io::YAMLDocReader& reader) | ||||||
| { | { | ||||||
|     const Athena::io::YAMLNode* root = reader.getRootNode(); |     const athena::io::YAMLNode* root = reader.getRootNode(); | ||||||
| 
 | 
 | ||||||
|     /* Validate Pass */ |     /* Validate Pass */ | ||||||
|     if (root->m_type == YAML_MAPPING_NODE) |     if (root->m_type == YAML_MAPPING_NODE) | ||||||
| @ -98,12 +98,12 @@ void STRG::read(Athena::io::YAMLDocReader& reader) | |||||||
|                 continue; |                 continue; | ||||||
|             if (lang.first.size() != 4) |             if (lang.first.size() != 4) | ||||||
|             { |             { | ||||||
|                 Log.report(LogVisor::Warning, "STRG language string '%s' must be exactly 4 characters; skipping", lang.first.c_str()); |                 Log.report(logvisor::Warning, "STRG language string '%s' must be exactly 4 characters; skipping", lang.first.c_str()); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
|             if (lang.second->m_type != YAML_SEQUENCE_NODE) |             if (lang.second->m_type != YAML_SEQUENCE_NODE) | ||||||
|             { |             { | ||||||
|                 Log.report(LogVisor::Warning, |                 Log.report(logvisor::Warning, | ||||||
|                            "STRG language string '%s' must contain a sequence; skipping", lang.first.c_str()); |                            "STRG language string '%s' must contain a sequence; skipping", lang.first.c_str()); | ||||||
|                 return; |                 return; | ||||||
|             } |             } | ||||||
| @ -111,7 +111,7 @@ void STRG::read(Athena::io::YAMLDocReader& reader) | |||||||
|             { |             { | ||||||
|                 if (str->m_type != YAML_SCALAR_NODE) |                 if (str->m_type != YAML_SCALAR_NODE) | ||||||
|                 { |                 { | ||||||
|                     Log.report(LogVisor::Warning, "STRG language '%s' must contain all scalars; skipping", lang.first.c_str()); |                     Log.report(logvisor::Warning, "STRG language '%s' must contain all scalars; skipping", lang.first.c_str()); | ||||||
|                     return; |                     return; | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| @ -119,16 +119,16 @@ void STRG::read(Athena::io::YAMLDocReader& reader) | |||||||
|     } |     } | ||||||
|     else |     else | ||||||
|     { |     { | ||||||
|         Log.report(LogVisor::Warning, "STRG must have a mapping root node; skipping"); |         Log.report(logvisor::Warning, "STRG must have a mapping root node; skipping"); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     const Athena::io::YAMLNode* nameYAML = root->findMapChild("names"); |     const athena::io::YAMLNode* nameYAML = root->findMapChild("names"); | ||||||
|     names.clear(); |     names.clear(); | ||||||
|     if (nameYAML && nameYAML->m_type == YAML_MAPPING_NODE) |     if (nameYAML && nameYAML->m_type == YAML_MAPPING_NODE) | ||||||
|         for (const auto& item : nameYAML->m_mapChildren) |         for (const auto& item : nameYAML->m_mapChildren) | ||||||
|             if (item.second->m_type == YAML_SCALAR_NODE) |             if (item.second->m_type == YAML_SCALAR_NODE) | ||||||
|                 names[item.first] = Athena::io::NodeToVal<atInt32>(item.second.get()); |                 names[item.first] = athena::io::NodeToVal<atInt32>(item.second.get()); | ||||||
| 
 | 
 | ||||||
|     langs.clear(); |     langs.clear(); | ||||||
|     langs.reserve(root->m_mapChildren.size()); |     langs.reserve(root->m_mapChildren.size()); | ||||||
| @ -151,7 +151,7 @@ void STRG::read(Athena::io::YAMLDocReader& reader) | |||||||
|         langMap.emplace(item.first, &item.second); |         langMap.emplace(item.first, &item.second); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void STRG::write(Athena::io::IStreamWriter& writer) const | void STRG::write(athena::io::IStreamWriter& writer) const | ||||||
| { | { | ||||||
|     writer.writeUint32Big(0x87654321); |     writer.writeUint32Big(0x87654321); | ||||||
|     writer.writeUint32Big(3); |     writer.writeUint32Big(3); | ||||||
| @ -243,7 +243,7 @@ size_t STRG::binarySize(size_t __isz) const | |||||||
|     return __isz; |     return __isz; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void STRG::write(Athena::io::YAMLDocWriter& writer) const | void STRG::write(athena::io::YAMLDocWriter& writer) const | ||||||
| { | { | ||||||
|     for (const auto& item : langs) |     for (const auto& item : langs) | ||||||
|     { |     { | ||||||
| @ -268,7 +268,7 @@ void STRG::write(Athena::io::YAMLDocWriter& writer) const | |||||||
| 
 | 
 | ||||||
| const char* STRG::DNAType() | const char* STRG::DNAType() | ||||||
| { | { | ||||||
|     return "Retro::DNAMP3::STRG"; |     return "urde::DNAMP3::STRG"; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  | |||||||
| @ -14,7 +14,7 @@ struct STRG : ISTRG | |||||||
| { | { | ||||||
|     DECL_YAML |     DECL_YAML | ||||||
|     Delete expl; |     Delete expl; | ||||||
|     void _read(Athena::io::IStreamReader& reader); |     void _read(athena::io::IStreamReader& reader); | ||||||
|     std::vector<std::pair<DNAFourCC, std::vector<std::string>>> langs; |     std::vector<std::pair<DNAFourCC, std::vector<std::string>>> langs; | ||||||
|     std::unordered_map<DNAFourCC, std::vector<std::string>*> langMap; |     std::unordered_map<DNAFourCC, std::vector<std::string>*> langMap; | ||||||
|     std::map<std::string, int32_t> names; |     std::map<std::string, int32_t> names; | ||||||
| @ -49,37 +49,37 @@ struct STRG : ISTRG | |||||||
|     { |     { | ||||||
|         auto search = langMap.find(lang); |         auto search = langMap.find(lang); | ||||||
|         if (search != langMap.end()) |         if (search != langMap.end()) | ||||||
|             return HECL::UTF8ToWide(search->second->at(idx)); |             return hecl::UTF8ToWide(search->second->at(idx)); | ||||||
|         return std::wstring(); |         return std::wstring(); | ||||||
|     } |     } | ||||||
|     inline HECL::SystemString getSystemString(const FourCC& lang, size_t idx) const |     inline hecl::SystemString getSystemString(const FourCC& lang, size_t idx) const | ||||||
|     { |     { | ||||||
|         auto search = langMap.find(lang); |         auto search = langMap.find(lang); | ||||||
|         if (search != langMap.end()) |         if (search != langMap.end()) | ||||||
| #if HECL_UCS2 | #if HECL_UCS2 | ||||||
|             return HECL::UTF8ToWide(search->second->at(idx)); |             return hecl::UTF8ToWide(search->second->at(idx)); | ||||||
| #else | #else | ||||||
|             return search->second->at(idx); |             return search->second->at(idx); | ||||||
| #endif | #endif | ||||||
|         return HECL::SystemString(); |         return hecl::SystemString(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     static bool Extract(PAKEntryReadStream& rs, const HECL::ProjectPath& outPath) |     static bool Extract(PAKEntryReadStream& rs, const hecl::ProjectPath& outPath) | ||||||
|     { |     { | ||||||
|         std::unique_ptr<ISTRG> strg = LoadSTRG(rs); |         std::unique_ptr<ISTRG> strg = LoadSTRG(rs); | ||||||
|         FILE* fp = HECL::Fopen(outPath.getAbsolutePath().c_str(), _S("wb")); |         FILE* fp = hecl::Fopen(outPath.getAbsolutePath().c_str(), _S("wb")); | ||||||
|         strg->toYAMLFile(fp); |         strg->toYAMLFile(fp); | ||||||
|         fclose(fp); |         fclose(fp); | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     static bool Cook(const HECL::ProjectPath& inPath, const HECL::ProjectPath& outPath) |     static bool Cook(const hecl::ProjectPath& inPath, const hecl::ProjectPath& outPath) | ||||||
|     { |     { | ||||||
|         STRG strg; |         STRG strg; | ||||||
|         FILE* fp = HECL::Fopen(inPath.getAbsolutePath().c_str(), _S("rb")); |         FILE* fp = hecl::Fopen(inPath.getAbsolutePath().c_str(), _S("rb")); | ||||||
|         strg.fromYAMLFile(fp); |         strg.fromYAMLFile(fp); | ||||||
|         fclose(fp); |         fclose(fp); | ||||||
|         Athena::io::FileWriter ws(outPath.getAbsolutePath()); |         athena::io::FileWriter ws(outPath.getAbsolutePath()); | ||||||
|         strg.write(ws); |         strg.write(ws); | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -13,9 +13,9 @@ | |||||||
| namespace DataSpec | namespace DataSpec | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| static LogVisor::LogModule Log("Retro::SpecBase"); | static logvisor::Module Log("urde::SpecBase"); | ||||||
| 
 | 
 | ||||||
| static const HECL::SystemChar* MomErr[] = | static const hecl::SystemChar* MomErr[] = | ||||||
| { | { | ||||||
|     _S("Your metroid is in another castle"), |     _S("Your metroid is in another castle"), | ||||||
|     _S("HECL is experiencing a PTSD attack"), |     _S("HECL is experiencing a PTSD attack"), | ||||||
| @ -31,13 +31,13 @@ static const HECL::SystemChar* MomErr[] = | |||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| constexpr uint32_t MomErrCount = 11; | constexpr uint32_t MomErrCount = 11; | ||||||
| SpecBase::SpecBase(HECL::Database::Project& project) | SpecBase::SpecBase(hecl::Database::Project& project) | ||||||
| : m_project(project), | : m_project(project), | ||||||
|   m_masterShader(project.getProjectWorkingPath(), ".hecl/RetroMasterShader.blend") {} |   m_masterShader(project.getProjectWorkingPath(), ".hecl/RetroMasterShader.blend") {} | ||||||
| 
 | 
 | ||||||
| bool SpecBase::canExtract(const ExtractPassInfo& info, std::vector<ExtractReport>& reps) | bool SpecBase::canExtract(const ExtractPassInfo& info, std::vector<ExtractReport>& reps) | ||||||
| { | { | ||||||
|     m_disc = NOD::OpenDiscFromImage(info.srcpath.c_str(), m_isWii); |     m_disc = nod::OpenDiscFromImage(info.srcpath.c_str(), m_isWii); | ||||||
|     if (!m_disc) |     if (!m_disc) | ||||||
|         return false; |         return false; | ||||||
|     const char* gameID = m_disc->getHeader().m_gameID; |     const char* gameID = m_disc->getHeader().m_gameID; | ||||||
| @ -51,7 +51,7 @@ bool SpecBase::canExtract(const ExtractPassInfo& info, std::vector<ExtractReport | |||||||
| #else | #else | ||||||
|         int r = rand_r(&t) % MomErrCount; |         int r = rand_r(&t) % MomErrCount; | ||||||
| #endif | #endif | ||||||
|         Log.report(LogVisor::FatalError, MomErr[r]); |         Log.report(logvisor::Fatal, MomErr[r]); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     m_standalone = true; |     m_standalone = true; | ||||||
| @ -62,11 +62,11 @@ bool SpecBase::canExtract(const ExtractPassInfo& info, std::vector<ExtractReport | |||||||
|         return false; |         return false; | ||||||
| 
 | 
 | ||||||
|     char region = m_disc->getHeader().m_gameID[3]; |     char region = m_disc->getHeader().m_gameID[3]; | ||||||
|     static const HECL::SystemString regNONE = _S(""); |     static const hecl::SystemString regNONE = _S(""); | ||||||
|     static const HECL::SystemString regE = _S("NTSC"); |     static const hecl::SystemString regE = _S("NTSC"); | ||||||
|     static const HECL::SystemString regJ = _S("NTSC-J"); |     static const hecl::SystemString regJ = _S("NTSC-J"); | ||||||
|     static const HECL::SystemString regP = _S("PAL"); |     static const hecl::SystemString regP = _S("PAL"); | ||||||
|     const HECL::SystemString* regstr = ®NONE; |     const hecl::SystemString* regstr = ®NONE; | ||||||
|     switch (region) |     switch (region) | ||||||
|     { |     { | ||||||
|     case 'E': |     case 'E': | ||||||
| @ -90,13 +90,13 @@ void SpecBase::doExtract(const ExtractPassInfo& info, FProgress progress) | |||||||
| { | { | ||||||
|     DataSpec::g_curSpec = this; |     DataSpec::g_curSpec = this; | ||||||
|     if (!Blender::BuildMasterShader(m_masterShader)) |     if (!Blender::BuildMasterShader(m_masterShader)) | ||||||
|         Log.report(LogVisor::FatalError, "Unable to build master shader blend"); |         Log.report(logvisor::Fatal, "Unable to build master shader blend"); | ||||||
|     if (m_isWii) |     if (m_isWii) | ||||||
|     { |     { | ||||||
|         /* Extract update partition for repacking later */ |         /* Extract update partition for repacking later */ | ||||||
|         const HECL::SystemString& target = m_project.getProjectWorkingPath().getAbsolutePath(); |         const hecl::SystemString& target = m_project.getProjectWorkingPath().getAbsolutePath(); | ||||||
|         NOD::Partition* update = m_disc->getUpdatePartition(); |         nod::Partition* update = m_disc->getUpdatePartition(); | ||||||
|         NOD::ExtractionContext ctx = {true, info.force, nullptr}; |         nod::ExtractionContext ctx = {true, info.force, nullptr}; | ||||||
| 
 | 
 | ||||||
|         if (update) |         if (update) | ||||||
|         { |         { | ||||||
| @ -104,7 +104,7 @@ void SpecBase::doExtract(const ExtractPassInfo& info, FProgress progress) | |||||||
|             progress(_S("Update Partition"), _S(""), 0, 0.0); |             progress(_S("Update Partition"), _S(""), 0, 0.0); | ||||||
|             const atUint64 nodeCount = update->getFSTRoot().rawEnd() - update->getFSTRoot().rawBegin(); |             const atUint64 nodeCount = update->getFSTRoot().rawEnd() - update->getFSTRoot().rawBegin(); | ||||||
|             ctx.progressCB = [&](const std::string& name) { |             ctx.progressCB = [&](const std::string& name) { | ||||||
|                 HECL::SystemStringView nameView(name); |                 hecl::SystemStringView nameView(name); | ||||||
|                 progress(_S("Update Partition"), nameView.sys_str().c_str(), 0, idx / (float)nodeCount); |                 progress(_S("Update Partition"), nameView.sys_str().c_str(), 0, idx / (float)nodeCount); | ||||||
|                 idx++; |                 idx++; | ||||||
|             }; |             }; | ||||||
| @ -116,10 +116,10 @@ void SpecBase::doExtract(const ExtractPassInfo& info, FProgress progress) | |||||||
|         if (!m_standalone) |         if (!m_standalone) | ||||||
|         { |         { | ||||||
|             progress(_S("Trilogy Files"), _S(""), 1, 0.0); |             progress(_S("Trilogy Files"), _S(""), 1, 0.0); | ||||||
|             NOD::Partition* data = m_disc->getDataPartition(); |             nod::Partition* data = m_disc->getDataPartition(); | ||||||
|             const NOD::Node& root = data->getFSTRoot(); |             const nod::Node& root = data->getFSTRoot(); | ||||||
|             for (const NOD::Node& child : root) |             for (const nod::Node& child : root) | ||||||
|                 if (child.getKind() == NOD::Node::Kind::File) |                 if (child.getKind() == nod::Node::Kind::File) | ||||||
|                     child.extractToDirectory(target, ctx); |                     child.extractToDirectory(target, ctx); | ||||||
|             progress(_S("Trilogy Files"), _S(""), 1, 1.0); |             progress(_S("Trilogy Files"), _S(""), 1, 1.0); | ||||||
|         } |         } | ||||||
| @ -127,25 +127,25 @@ void SpecBase::doExtract(const ExtractPassInfo& info, FProgress progress) | |||||||
|     extractFromDisc(*m_disc, info.force, progress); |     extractFromDisc(*m_disc, info.force, progress); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| bool SpecBase::canCook(const HECL::ProjectPath& path) | bool SpecBase::canCook(const hecl::ProjectPath& path) | ||||||
| { | { | ||||||
|     if (!checkPathPrefix(path)) |     if (!checkPathPrefix(path)) | ||||||
|         return false; |         return false; | ||||||
|     if (HECL::IsPathBlend(path)) |     if (hecl::IsPathBlend(path)) | ||||||
|     { |     { | ||||||
|         HECL::BlenderConnection& conn = HECL::BlenderConnection::SharedConnection(); |         hecl::BlenderConnection& conn = hecl::BlenderConnection::SharedConnection(); | ||||||
|         if (!conn.openBlend(path)) |         if (!conn.openBlend(path)) | ||||||
|             return false; |             return false; | ||||||
|         if (conn.getBlendType() != HECL::BlenderConnection::BlendType::None) |         if (conn.getBlendType() != hecl::BlenderConnection::BlendType::None) | ||||||
|             return true; |             return true; | ||||||
|     } |     } | ||||||
|     else if (HECL::IsPathPNG(path)) |     else if (hecl::IsPathPNG(path)) | ||||||
|     { |     { | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
|     else if (HECL::IsPathYAML(path)) |     else if (hecl::IsPathYAML(path)) | ||||||
|     { |     { | ||||||
|         FILE* fp = HECL::Fopen(path.getAbsolutePath().c_str(), _S("r")); |         FILE* fp = hecl::Fopen(path.getAbsolutePath().c_str(), _S("r")); | ||||||
|         bool retval = validateYAMLDNAType(fp); |         bool retval = validateYAMLDNAType(fp); | ||||||
|         fclose(fp); |         fclose(fp); | ||||||
|         return retval; |         return retval; | ||||||
| @ -153,41 +153,41 @@ bool SpecBase::canCook(const HECL::ProjectPath& path) | |||||||
|     return false; |     return false; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void SpecBase::doCook(const HECL::ProjectPath& path, const HECL::ProjectPath& cookedPath, | void SpecBase::doCook(const hecl::ProjectPath& path, const hecl::ProjectPath& cookedPath, | ||||||
|                       bool fast, FCookProgress progress) |                       bool fast, FCookProgress progress) | ||||||
| { | { | ||||||
|     DataSpec::g_curSpec = this; |     DataSpec::g_curSpec = this; | ||||||
|     if (HECL::IsPathBlend(path)) |     if (hecl::IsPathBlend(path)) | ||||||
|     { |     { | ||||||
|         HECL::BlenderConnection& conn = HECL::BlenderConnection::SharedConnection(); |         hecl::BlenderConnection& conn = hecl::BlenderConnection::SharedConnection(); | ||||||
|         if (!conn.openBlend(path)) |         if (!conn.openBlend(path)) | ||||||
|             return; |             return; | ||||||
|         switch (conn.getBlendType()) |         switch (conn.getBlendType()) | ||||||
|         { |         { | ||||||
|         case HECL::BlenderConnection::BlendType::Mesh: |         case hecl::BlenderConnection::BlendType::Mesh: | ||||||
|         { |         { | ||||||
|             HECL::BlenderConnection::DataStream ds = conn.beginData(); |             hecl::BlenderConnection::DataStream ds = conn.beginData(); | ||||||
|             cookMesh(cookedPath, path, ds, fast, progress); |             cookMesh(cookedPath, path, ds, fast, progress); | ||||||
|             break; |             break; | ||||||
|         } |         } | ||||||
|         case HECL::BlenderConnection::BlendType::Actor: |         case hecl::BlenderConnection::BlendType::Actor: | ||||||
|         { |         { | ||||||
|             HECL::BlenderConnection::DataStream ds = conn.beginData(); |             hecl::BlenderConnection::DataStream ds = conn.beginData(); | ||||||
|             cookActor(cookedPath, path, ds, fast, progress); |             cookActor(cookedPath, path, ds, fast, progress); | ||||||
|             break; |             break; | ||||||
|         } |         } | ||||||
|         case HECL::BlenderConnection::BlendType::Area: |         case hecl::BlenderConnection::BlendType::Area: | ||||||
|         { |         { | ||||||
|             HECL::BlenderConnection::DataStream ds = conn.beginData(); |             hecl::BlenderConnection::DataStream ds = conn.beginData(); | ||||||
|             cookArea(cookedPath, path, ds, fast, progress); |             cookArea(cookedPath, path, ds, fast, progress); | ||||||
|             break; |             break; | ||||||
|         } |         } | ||||||
|         default: break; |         default: break; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|     else if (HECL::IsPathYAML(path)) |     else if (hecl::IsPathYAML(path)) | ||||||
|     { |     { | ||||||
|         FILE* fp = HECL::Fopen(path.getAbsolutePath().c_str(), _S("r")); |         FILE* fp = hecl::Fopen(path.getAbsolutePath().c_str(), _S("r")); | ||||||
|         cookYAML(cookedPath, path, fp, progress); |         cookYAML(cookedPath, path, fp, progress); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @ -198,7 +198,7 @@ bool SpecBase::canPackage(const PackagePassInfo& info) | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void SpecBase::gatherDependencies(const PackagePassInfo& info, | void SpecBase::gatherDependencies(const PackagePassInfo& info, | ||||||
|                                   std::unordered_set<HECL::ProjectPath>& implicitsOut) |                                   std::unordered_set<hecl::ProjectPath>& implicitsOut) | ||||||
| { | { | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -3,71 +3,71 @@ | |||||||
| 
 | 
 | ||||||
| #include <functional> | #include <functional> | ||||||
| 
 | 
 | ||||||
| #include <HECL/Database.hpp> | #include <hecl/Database.hpp> | ||||||
| #include <NOD/NOD.hpp> | #include <nod/nod.hpp> | ||||||
| #include "BlenderConnection.hpp" | #include "BlenderConnection.hpp" | ||||||
| 
 | 
 | ||||||
| namespace DataSpec | namespace DataSpec | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| struct SpecBase : HECL::Database::IDataSpec | struct SpecBase : hecl::Database::IDataSpec | ||||||
| { | { | ||||||
|     /* HECL Adaptors */ |     /* HECL Adaptors */ | ||||||
|     bool canExtract(const ExtractPassInfo& info, std::vector<ExtractReport>& reps); |     bool canExtract(const ExtractPassInfo& info, std::vector<ExtractReport>& reps); | ||||||
|     void doExtract(const ExtractPassInfo& info, FProgress progress); |     void doExtract(const ExtractPassInfo& info, FProgress progress); | ||||||
| 
 | 
 | ||||||
|     bool canCook(const HECL::ProjectPath& path); |     bool canCook(const hecl::ProjectPath& path); | ||||||
|     void doCook(const HECL::ProjectPath& path, const HECL::ProjectPath& cookedPath, bool fast, FCookProgress progress); |     void doCook(const hecl::ProjectPath& path, const hecl::ProjectPath& cookedPath, bool fast, FCookProgress progress); | ||||||
| 
 | 
 | ||||||
|     bool canPackage(const PackagePassInfo& info); |     bool canPackage(const PackagePassInfo& info); | ||||||
|     void gatherDependencies(const PackagePassInfo& info, |     void gatherDependencies(const PackagePassInfo& info, | ||||||
|                             std::unordered_set<HECL::ProjectPath>& implicitsOut); |                             std::unordered_set<hecl::ProjectPath>& implicitsOut); | ||||||
|     void doPackage(const PackagePassInfo& info); |     void doPackage(const PackagePassInfo& info); | ||||||
| 
 | 
 | ||||||
|     /* Extract handlers */ |     /* Extract handlers */ | ||||||
|     virtual bool checkStandaloneID(const char* id) const=0; |     virtual bool checkStandaloneID(const char* id) const=0; | ||||||
|     virtual bool checkFromStandaloneDisc(NOD::DiscBase& disc, |     virtual bool checkFromStandaloneDisc(nod::DiscBase& disc, | ||||||
|                                          const HECL::SystemString& regstr, |                                          const hecl::SystemString& regstr, | ||||||
|                                          const std::vector<HECL::SystemString>& args, |                                          const std::vector<hecl::SystemString>& args, | ||||||
|                                          std::vector<ExtractReport>& reps)=0; |                                          std::vector<ExtractReport>& reps)=0; | ||||||
|     virtual bool checkFromTrilogyDisc(NOD::DiscBase& disc, |     virtual bool checkFromTrilogyDisc(nod::DiscBase& disc, | ||||||
|                                       const HECL::SystemString& regstr, |                                       const hecl::SystemString& regstr, | ||||||
|                                       const std::vector<HECL::SystemString>& args, |                                       const std::vector<hecl::SystemString>& args, | ||||||
|                                       std::vector<ExtractReport>& reps)=0; |                                       std::vector<ExtractReport>& reps)=0; | ||||||
|     virtual bool extractFromDisc(NOD::DiscBase& disc, bool force, |     virtual bool extractFromDisc(nod::DiscBase& disc, bool force, | ||||||
|                                  FProgress progress)=0; |                                  FProgress progress)=0; | ||||||
| 
 | 
 | ||||||
|     /* Basic path check (game directory matching) */ |     /* Basic path check (game directory matching) */ | ||||||
|     virtual bool checkPathPrefix(const HECL::ProjectPath& path)=0; |     virtual bool checkPathPrefix(const hecl::ProjectPath& path)=0; | ||||||
| 
 | 
 | ||||||
|     /* Pre-cook handlers */ |     /* Pre-cook handlers */ | ||||||
|     virtual bool validateYAMLDNAType(FILE* fp) const=0; |     virtual bool validateYAMLDNAType(FILE* fp) const=0; | ||||||
| 
 | 
 | ||||||
|     /* Cook handlers */ |     /* Cook handlers */ | ||||||
|     using BlendStream = HECL::BlenderConnection::DataStream; |     using BlendStream = hecl::BlenderConnection::DataStream; | ||||||
|     using Mesh = BlendStream::Mesh; |     using Mesh = BlendStream::Mesh; | ||||||
|     using Actor = BlendStream::Actor; |     using Actor = BlendStream::Actor; | ||||||
| 
 | 
 | ||||||
|     virtual void cookMesh(const HECL::ProjectPath& out, const HECL::ProjectPath& in, BlendStream& ds, bool fast, FCookProgress progress) const=0; |     virtual void cookMesh(const hecl::ProjectPath& out, const hecl::ProjectPath& in, BlendStream& ds, bool fast, FCookProgress progress) const=0; | ||||||
|     virtual void cookActor(const HECL::ProjectPath& out, const HECL::ProjectPath& in, BlendStream& ds, bool fast, FCookProgress progress) const=0; |     virtual void cookActor(const hecl::ProjectPath& out, const hecl::ProjectPath& in, BlendStream& ds, bool fast, FCookProgress progress) const=0; | ||||||
|     virtual void cookArea(const HECL::ProjectPath& out, const HECL::ProjectPath& in, BlendStream& ds, bool fast, FCookProgress progress) const=0; |     virtual void cookArea(const hecl::ProjectPath& out, const hecl::ProjectPath& in, BlendStream& ds, bool fast, FCookProgress progress) const=0; | ||||||
|     virtual void cookYAML(const HECL::ProjectPath& out, const HECL::ProjectPath& in, FILE* fin, FCookProgress progress) const=0; |     virtual void cookYAML(const hecl::ProjectPath& out, const hecl::ProjectPath& in, FILE* fin, FCookProgress progress) const=0; | ||||||
| 
 | 
 | ||||||
|     const HECL::ProjectPath& getMasterShaderPath() const {return m_masterShader;} |     const hecl::ProjectPath& getMasterShaderPath() const {return m_masterShader;} | ||||||
| 
 | 
 | ||||||
|     /* Support functions for resolving paths from IDs */ |     /* Support functions for resolving paths from IDs */ | ||||||
|     virtual HECL::ProjectPath getWorking(class UniqueID32&) {return HECL::ProjectPath();} |     virtual hecl::ProjectPath getWorking(class UniqueID32&) {return hecl::ProjectPath();} | ||||||
|     virtual HECL::ProjectPath getWorking(class UniqueID64&) {return HECL::ProjectPath();} |     virtual hecl::ProjectPath getWorking(class UniqueID64&) {return hecl::ProjectPath();} | ||||||
| 
 | 
 | ||||||
|     /* Project accessor */ |     /* Project accessor */ | ||||||
|     HECL::Database::Project& getProject() {return m_project;} |     hecl::Database::Project& getProject() {return m_project;} | ||||||
| 
 | 
 | ||||||
|     SpecBase(HECL::Database::Project& project); |     SpecBase(hecl::Database::Project& project); | ||||||
| protected: | protected: | ||||||
|     HECL::Database::Project& m_project; |     hecl::Database::Project& m_project; | ||||||
|     HECL::ProjectPath m_masterShader; |     hecl::ProjectPath m_masterShader; | ||||||
| private: | private: | ||||||
|     std::unique_ptr<NOD::DiscBase> m_disc; |     std::unique_ptr<nod::DiscBase> m_disc; | ||||||
|     bool m_isWii; |     bool m_isWii; | ||||||
|     bool m_standalone; |     bool m_standalone; | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -13,8 +13,8 @@ | |||||||
| namespace DataSpec | namespace DataSpec | ||||||
| { | { | ||||||
| 
 | 
 | ||||||
| static LogVisor::LogModule Log("Retro::SpecMP1"); | static logvisor::Module Log("urde::SpecMP1"); | ||||||
| extern HECL::Database::DataSpecEntry SpecEntMP1; | extern hecl::Database::DataSpecEntry SpecEntMP1; | ||||||
| 
 | 
 | ||||||
| struct SpecMP1 : SpecBase | struct SpecMP1 : SpecBase | ||||||
| { | { | ||||||
| @ -25,27 +25,27 @@ struct SpecMP1 : SpecBase | |||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     std::vector<const NOD::Node*> m_nonPaks; |     std::vector<const nod::Node*> m_nonPaks; | ||||||
|     std::vector<DNAMP1::PAKBridge> m_paks; |     std::vector<DNAMP1::PAKBridge> m_paks; | ||||||
|     std::map<std::string, DNAMP1::PAKBridge*, HECL::CaseInsensitiveCompare> m_orderedPaks; |     std::map<std::string, DNAMP1::PAKBridge*, hecl::CaseInsensitiveCompare> m_orderedPaks; | ||||||
| 
 | 
 | ||||||
|     HECL::ProjectPath m_workPath; |     hecl::ProjectPath m_workPath; | ||||||
|     HECL::ProjectPath m_cookPath; |     hecl::ProjectPath m_cookPath; | ||||||
|     PAKRouter<DNAMP1::PAKBridge> m_pakRouter; |     PAKRouter<DNAMP1::PAKBridge> m_pakRouter; | ||||||
| 
 | 
 | ||||||
|     SpecMP1(HECL::Database::Project& project) |     SpecMP1(hecl::Database::Project& project) | ||||||
|     : SpecBase(project), |     : SpecBase(project), | ||||||
|       m_workPath(project.getProjectWorkingPath(), _S("MP1")), |       m_workPath(project.getProjectWorkingPath(), _S("MP1")), | ||||||
|       m_cookPath(project.getProjectCookedPath(SpecEntMP1), _S("MP1")), |       m_cookPath(project.getProjectCookedPath(SpecEntMP1), _S("MP1")), | ||||||
|       m_pakRouter(*this, m_workPath, m_cookPath) {} |       m_pakRouter(*this, m_workPath, m_cookPath) {} | ||||||
| 
 | 
 | ||||||
|     void buildPaks(NOD::Node& root, |     void buildPaks(nod::Node& root, | ||||||
|                    const std::vector<HECL::SystemString>& args, |                    const std::vector<hecl::SystemString>& args, | ||||||
|                    ExtractReport& rep) |                    ExtractReport& rep) | ||||||
|     { |     { | ||||||
|         m_nonPaks.clear(); |         m_nonPaks.clear(); | ||||||
|         m_paks.clear(); |         m_paks.clear(); | ||||||
|         for (const NOD::Node& child : root) |         for (const nod::Node& child : root) | ||||||
|         { |         { | ||||||
|             bool isPak = false; |             bool isPak = false; | ||||||
|             const std::string& name = child.getName(); |             const std::string& name = child.getName(); | ||||||
| @ -67,8 +67,8 @@ struct SpecMP1 : SpecBase | |||||||
|                         good = false; |                         good = false; | ||||||
|                         if (!lowerName.compare(0, 7, "metroid")) |                         if (!lowerName.compare(0, 7, "metroid")) | ||||||
|                         { |                         { | ||||||
|                             HECL::SystemChar idxChar = lowerName[7]; |                             hecl::SystemChar idxChar = lowerName[7]; | ||||||
|                             for (const HECL::SystemString& arg : args) |                             for (const hecl::SystemString& arg : args) | ||||||
|                             { |                             { | ||||||
|                                 if (arg.size() == 1 && iswdigit(arg[0])) |                                 if (arg.size() == 1 && iswdigit(arg[0])) | ||||||
|                                     if (arg[0] == idxChar) |                                     if (arg[0] == idxChar) | ||||||
| @ -80,10 +80,10 @@ struct SpecMP1 : SpecBase | |||||||
| 
 | 
 | ||||||
|                         if (!good) |                         if (!good) | ||||||
|                         { |                         { | ||||||
|                             for (const HECL::SystemString& arg : args) |                             for (const hecl::SystemString& arg : args) | ||||||
|                             { |                             { | ||||||
| #if HECL_UCS2 | #if HECL_UCS2 | ||||||
|                                 std::string lowerArg = HECL::WideToUTF8(arg); |                                 std::string lowerArg = hecl::WideToUTF8(arg); | ||||||
| #else | #else | ||||||
|                                 std::string lowerArg = arg; |                                 std::string lowerArg = arg; | ||||||
| #endif | #endif | ||||||
| @ -116,18 +116,18 @@ struct SpecMP1 : SpecBase | |||||||
|                 continue; |                 continue; | ||||||
|             rep.childOpts.emplace_back(); |             rep.childOpts.emplace_back(); | ||||||
|             ExtractReport& childRep = rep.childOpts.back(); |             ExtractReport& childRep = rep.childOpts.back(); | ||||||
|             HECL::SystemStringView nameView(item.first); |             hecl::SystemStringView nameView(item.first); | ||||||
|             childRep.name = nameView; |             childRep.name = nameView; | ||||||
|             childRep.desc = item.second->getLevelString(); |             childRep.desc = item.second->getLevelString(); | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     bool checkFromStandaloneDisc(NOD::DiscBase& disc, |     bool checkFromStandaloneDisc(nod::DiscBase& disc, | ||||||
|                                  const HECL::SystemString& regstr, |                                  const hecl::SystemString& regstr, | ||||||
|                                  const std::vector<HECL::SystemString>& args, |                                  const std::vector<hecl::SystemString>& args, | ||||||
|                                  std::vector<ExtractReport>& reps) |                                  std::vector<ExtractReport>& reps) | ||||||
|     { |     { | ||||||
|         NOD::Partition* partition = disc.getDataPartition(); |         nod::Partition* partition = disc.getDataPartition(); | ||||||
|         std::unique_ptr<uint8_t[]> dolBuf = partition->getDOLBuf(); |         std::unique_ptr<uint8_t[]> dolBuf = partition->getDOLBuf(); | ||||||
|         const char* buildInfo = (char*)memmem(dolBuf.get(), partition->getDOLSize(), "MetroidBuildInfo", 16) + 19; |         const char* buildInfo = (char*)memmem(dolBuf.get(), partition->getDOLSize(), "MetroidBuildInfo", 16) + 19; | ||||||
| 
 | 
 | ||||||
| @ -142,40 +142,40 @@ struct SpecMP1 : SpecBase | |||||||
|         if (buildInfo) |         if (buildInfo) | ||||||
|         { |         { | ||||||
|             std::string buildStr(buildInfo); |             std::string buildStr(buildInfo); | ||||||
|             HECL::SystemStringView buildView(buildStr); |             hecl::SystemStringView buildView(buildStr); | ||||||
|             rep.desc += _S(" (") + buildView + _S(")"); |             rep.desc += _S(" (") + buildView + _S(")"); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         /* Iterate PAKs and build level options */ |         /* Iterate PAKs and build level options */ | ||||||
|         NOD::Node& root = partition->getFSTRoot(); |         nod::Node& root = partition->getFSTRoot(); | ||||||
|         buildPaks(root, args, rep); |         buildPaks(root, args, rep); | ||||||
| 
 | 
 | ||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     bool checkFromTrilogyDisc(NOD::DiscBase& disc, |     bool checkFromTrilogyDisc(nod::DiscBase& disc, | ||||||
|                               const HECL::SystemString& regstr, |                               const hecl::SystemString& regstr, | ||||||
|                               const std::vector<HECL::SystemString>& args, |                               const std::vector<hecl::SystemString>& args, | ||||||
|                               std::vector<ExtractReport>& reps) |                               std::vector<ExtractReport>& reps) | ||||||
|     { |     { | ||||||
|         std::vector<HECL::SystemString> mp1args; |         std::vector<hecl::SystemString> mp1args; | ||||||
|         bool doExtract = false; |         bool doExtract = false; | ||||||
|         if (args.size()) |         if (args.size()) | ||||||
|         { |         { | ||||||
|             /* Needs filter */ |             /* Needs filter */ | ||||||
|             for (const HECL::SystemString& arg : args) |             for (const hecl::SystemString& arg : args) | ||||||
|             { |             { | ||||||
|                 HECL::SystemString lowerArg = arg; |                 hecl::SystemString lowerArg = arg; | ||||||
|                 HECL::ToLower(lowerArg); |                 hecl::ToLower(lowerArg); | ||||||
|                 if (!lowerArg.compare(0, 3, _S("mp1"))) |                 if (!lowerArg.compare(0, 3, _S("mp1"))) | ||||||
|                 { |                 { | ||||||
|                     doExtract = true; |                     doExtract = true; | ||||||
|                     mp1args.reserve(args.size()); |                     mp1args.reserve(args.size()); | ||||||
|                     size_t slashPos = arg.find(_S('/')); |                     size_t slashPos = arg.find(_S('/')); | ||||||
|                     if (slashPos == HECL::SystemString::npos) |                     if (slashPos == hecl::SystemString::npos) | ||||||
|                         slashPos = arg.find(_S('\\')); |                         slashPos = arg.find(_S('\\')); | ||||||
|                     if (slashPos != HECL::SystemString::npos) |                     if (slashPos != hecl::SystemString::npos) | ||||||
|                         mp1args.emplace_back(HECL::SystemString(arg.begin() + slashPos + 1, arg.end())); |                         mp1args.emplace_back(hecl::SystemString(arg.begin() + slashPos + 1, arg.end())); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| @ -185,9 +185,9 @@ struct SpecMP1 : SpecBase | |||||||
|         if (!doExtract) |         if (!doExtract) | ||||||
|             return false; |             return false; | ||||||
| 
 | 
 | ||||||
|         NOD::Partition* partition = disc.getDataPartition(); |         nod::Partition* partition = disc.getDataPartition(); | ||||||
|         NOD::Node& root = partition->getFSTRoot(); |         nod::Node& root = partition->getFSTRoot(); | ||||||
|         NOD::Node::DirectoryIterator dolIt = root.find("rs5mp1_p.dol"); |         nod::Node::DirectoryIterator dolIt = root.find("rs5mp1_p.dol"); | ||||||
|         if (dolIt == root.end()) |         if (dolIt == root.end()) | ||||||
|             return false; |             return false; | ||||||
| 
 | 
 | ||||||
| @ -202,12 +202,12 @@ struct SpecMP1 : SpecBase | |||||||
|         if (buildInfo) |         if (buildInfo) | ||||||
|         { |         { | ||||||
|             std::string buildStr(buildInfo); |             std::string buildStr(buildInfo); | ||||||
|             HECL::SystemStringView buildView(buildStr); |             hecl::SystemStringView buildView(buildStr); | ||||||
|             rep.desc += _S(" (") + buildView + _S(")"); |             rep.desc += _S(" (") + buildView + _S(")"); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         /* Iterate PAKs and build level options */ |         /* Iterate PAKs and build level options */ | ||||||
|         NOD::Node::DirectoryIterator mp1It = root.find("MP1"); |         nod::Node::DirectoryIterator mp1It = root.find("MP1"); | ||||||
|         if (mp1It == root.end()) |         if (mp1It == root.end()) | ||||||
|             return false; |             return false; | ||||||
|         buildPaks(*mp1It, mp1args, rep); |         buildPaks(*mp1It, mp1args, rep); | ||||||
| @ -215,9 +215,9 @@ struct SpecMP1 : SpecBase | |||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     bool extractFromDisc(NOD::DiscBase&, bool force, FProgress progress) |     bool extractFromDisc(nod::DiscBase&, bool force, FProgress progress) | ||||||
|     { |     { | ||||||
|         NOD::ExtractionContext ctx = {true, force, nullptr}; |         nod::ExtractionContext ctx = {true, force, nullptr}; | ||||||
| 
 | 
 | ||||||
|         progress(_S("Indexing PAKs"), _S(""), 2, 0.0); |         progress(_S("Indexing PAKs"), _S(""), 2, 0.0); | ||||||
|         m_pakRouter.build(m_paks, [&progress](float factor) |         m_pakRouter.build(m_paks, [&progress](float factor) | ||||||
| @ -230,17 +230,17 @@ struct SpecMP1 : SpecBase | |||||||
|         progress(_S("MP1 Root"), _S(""), 3, 0.0); |         progress(_S("MP1 Root"), _S(""), 3, 0.0); | ||||||
|         int prog = 0; |         int prog = 0; | ||||||
|         ctx.progressCB = [&](const std::string& name) { |         ctx.progressCB = [&](const std::string& name) { | ||||||
|             HECL::SystemStringView nameView(name); |             hecl::SystemStringView nameView(name); | ||||||
|             progress(_S("MP1 Root"), nameView.sys_str().c_str(), 3, prog / (float)m_nonPaks.size()); |             progress(_S("MP1 Root"), nameView.sys_str().c_str(), 3, prog / (float)m_nonPaks.size()); | ||||||
|         }; |         }; | ||||||
|         for (const NOD::Node* node : m_nonPaks) |         for (const nod::Node* node : m_nonPaks) | ||||||
|         { |         { | ||||||
|             node->extractToDirectory(m_workPath.getAbsolutePath(), ctx); |             node->extractToDirectory(m_workPath.getAbsolutePath(), ctx); | ||||||
|             prog++; |             prog++; | ||||||
|         } |         } | ||||||
|         progress(_S("MP1 Root"), _S(""), 3, 1.0); |         progress(_S("MP1 Root"), _S(""), 3, 1.0); | ||||||
| 
 | 
 | ||||||
|         const HECL::ProjectPath& cookPath = m_project.getProjectCookedPath(SpecEntMP1); |         const hecl::ProjectPath& cookPath = m_project.getProjectCookedPath(SpecEntMP1); | ||||||
|         cookPath.makeDir(); |         cookPath.makeDir(); | ||||||
|         m_cookPath.makeDir(); |         m_cookPath.makeDir(); | ||||||
| 
 | 
 | ||||||
| @ -253,11 +253,11 @@ struct SpecMP1 : SpecBase | |||||||
|                 continue; |                 continue; | ||||||
| 
 | 
 | ||||||
|             const std::string& name = pak.getName(); |             const std::string& name = pak.getName(); | ||||||
|             HECL::SystemStringView sysName(name); |             hecl::SystemStringView sysName(name); | ||||||
| 
 | 
 | ||||||
|             progress(sysName.sys_str().c_str(), _S(""), compIdx, 0.0); |             progress(sysName.sys_str().c_str(), _S(""), compIdx, 0.0); | ||||||
|             m_pakRouter.extractResources(pak, force, |             m_pakRouter.extractResources(pak, force, | ||||||
|             [&progress, &sysName, &compIdx](const HECL::SystemChar* substr, float factor) |             [&progress, &sysName, &compIdx](const hecl::SystemChar* substr, float factor) | ||||||
|             { |             { | ||||||
|                 progress(sysName.sys_str().c_str(), substr, compIdx, factor); |                 progress(sysName.sys_str().c_str(), substr, compIdx, factor); | ||||||
|             }); |             }); | ||||||
| @ -267,12 +267,12 @@ struct SpecMP1 : SpecBase | |||||||
|         return true; |         return true; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     virtual HECL::ProjectPath getWorking(class UniqueID32& id) |     virtual hecl::ProjectPath getWorking(class UniqueID32& id) | ||||||
|     { |     { | ||||||
|         return m_pakRouter.getWorking(id); |         return m_pakRouter.getWorking(id); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     bool checkPathPrefix(const HECL::ProjectPath& path) |     bool checkPathPrefix(const hecl::ProjectPath& path) | ||||||
|     { |     { | ||||||
|         return path.getRelativePath().compare(0, 4, _S("MP1/")) == 0; |         return path.getRelativePath().compare(0, 4, _S("MP1/")) == 0; | ||||||
|     } |     } | ||||||
| @ -286,41 +286,41 @@ struct SpecMP1 : SpecBase | |||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void cookMesh(const HECL::ProjectPath& out, const HECL::ProjectPath& in, |     void cookMesh(const hecl::ProjectPath& out, const hecl::ProjectPath& in, | ||||||
|                   BlendStream& ds, bool fast, FCookProgress progress) const |                   BlendStream& ds, bool fast, FCookProgress progress) const | ||||||
|     { |     { | ||||||
|         Mesh mesh = ds.compileMesh(fast ? HECL::HMDLTopology::Triangles : HECL::HMDLTopology::TriStrips, -1, |         Mesh mesh = ds.compileMesh(fast ? hecl::HMDLTopology::Triangles : hecl::HMDLTopology::TriStrips, -1, | ||||||
|         [&progress](int surfCount) |         [&progress](int surfCount) | ||||||
|         { |         { | ||||||
|             progress(HECL::SysFormat(_S("%d"), surfCount).c_str()); |             progress(hecl::SysFormat(_S("%d"), surfCount).c_str()); | ||||||
|         }); |         }); | ||||||
|         DNAMP1::CMDL::Cook(out, in, mesh); |         DNAMP1::CMDL::Cook(out, in, mesh); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void cookActor(const HECL::ProjectPath& out, const HECL::ProjectPath& in, |     void cookActor(const hecl::ProjectPath& out, const hecl::ProjectPath& in, | ||||||
|                    BlendStream& ds, bool fast, FCookProgress progress) const |                    BlendStream& ds, bool fast, FCookProgress progress) const | ||||||
|     { |     { | ||||||
|         Actor actor = ds.compileActor(); |         Actor actor = ds.compileActor(); | ||||||
|         DNAMP1::ANCS::Cook(out, in, actor); |         DNAMP1::ANCS::Cook(out, in, actor); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void cookArea(const HECL::ProjectPath& out, const HECL::ProjectPath& in, |     void cookArea(const hecl::ProjectPath& out, const hecl::ProjectPath& in, | ||||||
|                   BlendStream& ds, bool fast, FCookProgress progress) const |                   BlendStream& ds, bool fast, FCookProgress progress) const | ||||||
|     { |     { | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void cookYAML(const HECL::ProjectPath& out, const HECL::ProjectPath& in, |     void cookYAML(const hecl::ProjectPath& out, const hecl::ProjectPath& in, | ||||||
|                   FILE* fin, FCookProgress progress) const |                   FILE* fin, FCookProgress progress) const | ||||||
|     { |     { | ||||||
|     } |     } | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| HECL::Database::DataSpecEntry SpecEntMP1 = | hecl::Database::DataSpecEntry SpecEntMP1 = | ||||||
| { | { | ||||||
|     _S("MP1"), |     _S("MP1"), | ||||||
|     _S("Data specification for original Metroid Prime engine"), |     _S("Data specification for original Metroid Prime engine"), | ||||||
|     [](HECL::Database::Project& project, HECL::Database::DataSpecTool) |     [](hecl::Database::Project& project, hecl::Database::DataSpecTool) | ||||||
|     -> HECL::Database::IDataSpec* {return new struct SpecMP1(project);} |     -> hecl::Database::IDataSpec* {return new struct SpecMP1(project);} | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user