diff --git a/Source/Core/Core/Movie.cpp b/Source/Core/Core/Movie.cpp index fa67c9d0bc..68dd2c60a4 100644 --- a/Source/Core/Core/Movie.cpp +++ b/Source/Core/Core/Movie.cpp @@ -227,7 +227,7 @@ void Init(const BootParameters& boot) ReadHeader(); std::thread md5thread(CheckMD5); md5thread.detach(); - if (tmpHeader.GetGameID() == SConfig::GetInstance().GetGameID()) + if (strncmp(tmpHeader.gameID.data(), SConfig::GetInstance().GetGameID().c_str(), 6)) { PanicAlertFmtT("The recorded game ({0}) is not the same as the selected game ({1})", tmpHeader.GetGameID(), SConfig::GetInstance().GetGameID()); diff --git a/Source/Core/Core/Movie.h b/Source/Core/Core/Movie.h index dd55bea55b..e76ea6a10e 100644 --- a/Source/Core/Core/Movie.h +++ b/Source/Core/Core/Movie.h @@ -5,6 +5,7 @@ #pragma once #include +#include #include #include #include @@ -64,7 +65,10 @@ static_assert(sizeof(ControllerState) == 8, "ControllerState should be 8 bytes") #pragma pack(push, 1) struct DTMHeader { - std::string_view GetGameID() const { return {gameID.data(), gameID.size()}; } + std::string_view GetGameID() const + { + return {gameID.data(), strnlen(gameID.data(), gameID.size())}; + } std::array filetype; // Unique Identifier (always "DTM"0x1A)