DiscIO: Make WiiEncryptionCache moveable

Fixes the following warning:

../../../../../../Core\DiscIO/DirectoryBlob.h:156:3: warning: explicitly defaulted move constructor is implicitly deleted [-Wdefaulted-function-deleted]
  DirectoryBlobReader(DirectoryBlobReader&&) = default;
  ^
../../../../../../Core\DiscIO/DirectoryBlob.h:205:22: note: move constructor of 'DirectoryBlobReader' is implicitly deleted because field 'm_encryption_cache' has a deleted move constructor
  WiiEncryptionCache m_encryption_cache;
                     ^
This commit is contained in:
JosJuice 2020-10-20 11:33:38 +02:00
parent 409230e088
commit 5b6f604d90
2 changed files with 12 additions and 1 deletions

View File

@ -29,7 +29,10 @@ WiiEncryptionCache::EncryptGroup(u64 offset, u64 partition_data_offset,
{ {
// Only allocate memory if this function actually ends up getting called // Only allocate memory if this function actually ends up getting called
if (!m_cache) if (!m_cache)
{
m_cache = std::make_unique<std::array<u8, VolumeWii::GROUP_TOTAL_SIZE>>(); m_cache = std::make_unique<std::array<u8, VolumeWii::GROUP_TOTAL_SIZE>>();
m_cached_offset = std::numeric_limits<u64>::max();
}
ASSERT(offset % VolumeWii::GROUP_TOTAL_SIZE == 0); ASSERT(offset % VolumeWii::GROUP_TOTAL_SIZE == 0);
const u64 group_offset_in_partition = const u64 group_offset_in_partition =

View File

@ -26,6 +26,14 @@ public:
explicit WiiEncryptionCache(BlobReader* blob); explicit WiiEncryptionCache(BlobReader* blob);
~WiiEncryptionCache(); ~WiiEncryptionCache();
WiiEncryptionCache(WiiEncryptionCache&&) = default;
WiiEncryptionCache& operator=(WiiEncryptionCache&&) = default;
// It would be possible to write a custom copy constructor and assignment operator
// for this class, but there has been no reason to do so.
WiiEncryptionCache(const WiiEncryptionCache&) = delete;
WiiEncryptionCache& operator=(const WiiEncryptionCache&) = delete;
// Encrypts exactly one group. // Encrypts exactly one group.
// If the returned pointer is nullptr, reading from the blob failed. // If the returned pointer is nullptr, reading from the blob failed.
// If the returned pointer is not nullptr, it is guaranteed to be valid until // If the returned pointer is not nullptr, it is guaranteed to be valid until
@ -43,7 +51,7 @@ public:
private: private:
BlobReader* m_blob; BlobReader* m_blob;
std::unique_ptr<std::array<u8, VolumeWii::GROUP_TOTAL_SIZE>> m_cache; std::unique_ptr<std::array<u8, VolumeWii::GROUP_TOTAL_SIZE>> m_cache;
u64 m_cached_offset = std::numeric_limits<u64>::max(); u64 m_cached_offset;
}; };
} // namespace DiscIO } // namespace DiscIO