diff --git a/Source/Core/DiscIO/VolumeDirectory.cpp b/Source/Core/DiscIO/VolumeDirectory.cpp index 35b29b7cdc..a42fd61919 100644 --- a/Source/Core/DiscIO/VolumeDirectory.cpp +++ b/Source/Core/DiscIO/VolumeDirectory.cpp @@ -24,6 +24,9 @@ namespace DiscIO { +const size_t CVolumeDirectory::MAX_NAME_LENGTH; +const size_t CVolumeDirectory::MAX_ID_LENGTH; + CVolumeDirectory::CVolumeDirectory(const std::string& _rDirectory, bool _bIsWii, const std::string& _rApploader, const std::string& _rDOL) : m_totalNameSize(0) @@ -40,15 +43,11 @@ CVolumeDirectory::CVolumeDirectory(const std::string& _rDirectory, bool _bIsWii, SetName("Default name"); if (_bIsWii) - { SetDiskTypeWii(); - } else - { SetDiskTypeGC(); - } - // Don't load the dol if we've no apploader... + // Don't load the DOL if we don't have an apploader if (SetApploader(_rApploader)) SetDOL(_rDOL); @@ -61,8 +60,7 @@ CVolumeDirectory::~CVolumeDirectory() bool CVolumeDirectory::IsValidDirectory(const std::string& _rDirectory) { - std::string directoryName = ExtractDirectoryName(_rDirectory); - return File::IsDirectory(directoryName); + return File::IsDirectory(ExtractDirectoryName(_rDirectory)); } bool CVolumeDirectory::Read(u64 _Offset, u64 _Length, u8* _pBuffer, bool decrypt) const @@ -133,9 +131,7 @@ bool CVolumeDirectory::Read(u64 _Offset, u64 _Length, u8* _pBuffer, bool decrypt if (fileOffset < fileSize) { - u64 fileBytes = fileSize - fileOffset; - if (_Length < fileBytes) - fileBytes = _Length; + u64 fileBytes = std::min(fileSize - fileOffset, _Length); if (!file.Seek(fileOffset, SEEK_SET)) return false; @@ -161,24 +157,17 @@ bool CVolumeDirectory::Read(u64 _Offset, u64 _Length, u8* _pBuffer, bool decrypt std::string CVolumeDirectory::GetUniqueID() const { - static const size_t ID_LENGTH = 6; - return std::string(m_diskHeader.begin(), m_diskHeader.begin() + ID_LENGTH); + return std::string(m_diskHeader.begin(), m_diskHeader.begin() + MAX_ID_LENGTH); } void CVolumeDirectory::SetUniqueID(const std::string& id) { - size_t length = id.length(); - if (length > 6) - length = 6; - - memcpy(m_diskHeader.data(), id.c_str(), length); + memcpy(m_diskHeader.data(), id.c_str(), std::min(id.length(), MAX_ID_LENGTH)); } IVolume::ECountry CVolumeDirectory::GetCountry() const { - u8 country_code = m_diskHeader[3]; - - return CountrySwitch(country_code); + return CountrySwitch(m_diskHeader[3]); } std::string CVolumeDirectory::GetMakerID() const @@ -197,19 +186,15 @@ std::string CVolumeDirectory::GetInternalName() const std::map CVolumeDirectory::GetNames(bool prefer_long) const { - std::map names; std::string name = GetInternalName(); - if (!name.empty()) - names[IVolume::ELanguage::LANGUAGE_UNKNOWN] = name; - return names; + if (name.empty()) + return { { } }; + return { { IVolume::LANGUAGE_UNKNOWN, name } }; } void CVolumeDirectory::SetName(const std::string& name) { - size_t length = name.length(); - if (length > MAX_NAME_LENGTH) - length = MAX_NAME_LENGTH; - + size_t length = std::min(name.length(), MAX_NAME_LENGTH); memcpy(&m_diskHeader[0x20], name.c_str(), length); m_diskHeader[length + 0x20] = 0; } @@ -274,10 +259,7 @@ std::string CVolumeDirectory::ExtractDirectoryName(const std::string& _rDirector void CVolumeDirectory::SetDiskTypeWii() { - m_diskHeader[0x18] = 0x5d; - m_diskHeader[0x19] = 0x1c; - m_diskHeader[0x1a] = 0x9e; - m_diskHeader[0x1b] = 0xa3; + Write32(0x5d1c9ea3, 0x18, &m_diskHeader); memset(&m_diskHeader[0x1c], 0, 4); m_is_wii = true; @@ -287,10 +269,7 @@ void CVolumeDirectory::SetDiskTypeWii() void CVolumeDirectory::SetDiskTypeGC() { memset(&m_diskHeader[0x18], 0, 4); - m_diskHeader[0x1c] = 0xc2; - m_diskHeader[0x1d] = 0x33; - m_diskHeader[0x1e] = 0x9f; - m_diskHeader[0x1f] = 0x3d; + Write32(0xc2339f3d, 0x1c, &m_diskHeader); m_is_wii = false; m_addressShift = 0; @@ -397,9 +376,7 @@ void CVolumeDirectory::WriteToBuffer(u64 _SrcStartAddress, u64 _SrcLength, const if (srcOffset < _SrcLength) { - u64 srcBytes = _SrcLength - srcOffset; - if (_Length < srcBytes) - srcBytes = _Length; + u64 srcBytes = std::min(_SrcLength - srcOffset, _Length); memcpy(_pBuffer, _Src + srcOffset, (size_t)srcBytes); @@ -411,15 +388,9 @@ void CVolumeDirectory::WriteToBuffer(u64 _SrcStartAddress, u64 _SrcLength, const void CVolumeDirectory::PadToAddress(u64 _StartAddress, u64& _Address, u64& _Length, u8*& _pBuffer) const { - if (_StartAddress <= _Address) - return; - - u64 padBytes = _StartAddress - _Address; - if (padBytes > _Length) - padBytes = _Length; - - if (_Length > 0) + if (_StartAddress > _Address && _Length > 0) { + u64 padBytes = std::min(_StartAddress - _Address, _Length); memset(_pBuffer, 0, (size_t)padBytes); _Length -= padBytes; _pBuffer += padBytes; diff --git a/Source/Core/DiscIO/VolumeDirectory.h b/Source/Core/DiscIO/VolumeDirectory.h index 8d8f664a07..be27e0763f 100644 --- a/Source/Core/DiscIO/VolumeDirectory.h +++ b/Source/Core/DiscIO/VolumeDirectory.h @@ -139,13 +139,14 @@ private: u64 m_fst_address; u64 m_dol_address; - static const u8 ENTRY_SIZE = 0x0c; - static const u8 FILE_ENTRY = 0; - static const u8 DIRECTORY_ENTRY = 1; - static const u64 DISKHEADER_ADDRESS = 0; - static const u64 DISKHEADERINFO_ADDRESS = 0x440; - static const u64 APPLOADER_ADDRESS = 0x2440; - static const u32 MAX_NAME_LENGTH = 0x3df; + static constexpr u8 ENTRY_SIZE = 0x0c; + static constexpr u8 FILE_ENTRY = 0; + static constexpr u8 DIRECTORY_ENTRY = 1; + static constexpr u64 DISKHEADER_ADDRESS = 0; + static constexpr u64 DISKHEADERINFO_ADDRESS = 0x440; + static constexpr u64 APPLOADER_ADDRESS = 0x2440; + static const size_t MAX_NAME_LENGTH = 0x3df; + static const size_t MAX_ID_LENGTH = 6; }; } // namespace