From adf9cb5d505c21806766080bf5c91ac3393448cc Mon Sep 17 00:00:00 2001 From: Luis Michaelis Date: Fri, 1 Nov 2024 20:50:31 +0100 Subject: [PATCH] !BREAKING feat(World): properly implement `CutscenePlayer` in save-games Removes `CutscenePlayer::play_list_count` and replaces it with `CutscenePlayer::playlists`. --- include/zenkit/World.hh | 3 ++- src/World.cc | 17 +++++++++++++---- 2 files changed, 15 insertions(+), 5 deletions(-) diff --git a/include/zenkit/World.hh b/include/zenkit/World.hh index d0621e50..8424a8a5 100644 --- a/include/zenkit/World.hh +++ b/include/zenkit/World.hh @@ -18,13 +18,14 @@ namespace phoenix { namespace zenkit { struct VNpc; + struct CutsceneContext; struct CutscenePlayer : Object { static constexpr ObjectType TYPE = ObjectType::oCCSPlayer; int32_t last_process_day; int32_t last_process_hour; - int32_t play_list_count; + std::vector> playlists; [[nodiscard]] ObjectType get_object_type() const override { return TYPE; diff --git a/src/World.cc b/src/World.cc index 38aa1ec7..808fcc5f 100644 --- a/src/World.cc +++ b/src/World.cc @@ -6,6 +6,7 @@ #include "zenkit/vobs/Misc.hh" #include "Internal.hh" +#include "zenkit/CutsceneLibrary.hh" namespace zenkit { [[maybe_unused]] static constexpr uint32_t BSP_VERSION_G1 = 0x2090000; @@ -273,16 +274,24 @@ namespace zenkit { return 64513; } - void CutscenePlayer::load(ReadArchive& r, GameVersion) { + void CutscenePlayer::load(ReadArchive& r, GameVersion version) { this->last_process_day = r.read_int(); // lastProcessDay this->last_process_hour = r.read_int(); // lastProcessHour - this->play_list_count = r.read_int(); // playListCount + + auto play_list_count = r.read_int(); // playListCount + for (auto i = 0; i < play_list_count; ++i) { + playlists.push_back(r.read_object(version)); + } } - void CutscenePlayer::save(WriteArchive& w, GameVersion) const { + void CutscenePlayer::save(WriteArchive& w, GameVersion version) const { w.write_int("lastProcessDay", this->last_process_day); w.write_int("lastProcessHour", this->last_process_hour); - w.write_int("playListCount", this->play_list_count); + w.write_int("playListCount", this->playlists.size()); + + for (auto i = 0; i < this->playlists.size(); ++i) { + w.write_object("playContext" + std::to_string(i), this->playlists[i].lock(), version); + } } void SkyController::load(ReadArchive& r, GameVersion version) {