mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-07-23 06:09:50 -06:00
Display all compressed formats in blue in GUI
In the past, only GCZ was shown as compressed, not CISO and WBFS.
This commit is contained in:
@ -25,7 +25,8 @@ class IBlobReader
|
||||
public:
|
||||
virtual ~IBlobReader() {}
|
||||
|
||||
virtual u64 GetRawSize() const = 0;
|
||||
virtual bool IsCompressed() const = 0;
|
||||
virtual u64 GetRawSize() const = 0;
|
||||
virtual u64 GetDataSize() const = 0;
|
||||
// NOT thread-safe - can't call this from multiple threads.
|
||||
virtual bool Read(u64 offset, u64 size, u8* out_ptr) = 0;
|
||||
|
@ -36,6 +36,7 @@ class CISOFileReader : public IBlobReader
|
||||
public:
|
||||
static CISOFileReader* Create(const std::string& filename);
|
||||
|
||||
bool IsCompressed() const override { return true; }
|
||||
u64 GetDataSize() const override;
|
||||
u64 GetRawSize() const override;
|
||||
bool Read(u64 offset, u64 nbytes, u8* out_ptr) override;
|
||||
|
@ -49,6 +49,7 @@ public:
|
||||
static CompressedBlobReader* Create(const std::string& filename);
|
||||
~CompressedBlobReader();
|
||||
const CompressedBlobHeader &GetHeader() const { return m_header; }
|
||||
bool IsCompressed() const override { return true; }
|
||||
u64 GetDataSize() const override { return m_header.data_size; }
|
||||
u64 GetRawSize() const override { return m_file_size; }
|
||||
u64 GetBlockCompressedSize(u64 block_num) const;
|
||||
|
@ -23,6 +23,7 @@ class DriveReader : public SectorReader
|
||||
public:
|
||||
static DriveReader* Create(const std::string& drive);
|
||||
~DriveReader();
|
||||
bool IsCompressed() const override { return false; }
|
||||
u64 GetDataSize() const override { return m_size; }
|
||||
u64 GetRawSize() const override { return m_size; }
|
||||
|
||||
|
@ -19,6 +19,7 @@ class PlainFileReader : public IBlobReader
|
||||
public:
|
||||
static PlainFileReader* Create(const std::string& filename);
|
||||
|
||||
bool IsCompressed() const override { return false; }
|
||||
u64 GetDataSize() const override { return m_size; }
|
||||
u64 GetRawSize() const override { return m_size; }
|
||||
bool Read(u64 offset, u64 nbytes, u8* out_ptr) override;
|
||||
|
@ -101,8 +101,9 @@ public:
|
||||
virtual bool ChangePartition(u64 offset) { return false; }
|
||||
|
||||
virtual ECountry GetCountry() const = 0;
|
||||
virtual bool IsCompressed() const = 0;
|
||||
// Size of virtual disc (not always accurate)
|
||||
virtual u64 GetSize() const = 0;
|
||||
|
||||
// Size on disc (compressed size)
|
||||
virtual u64 GetRawSize() const = 0;
|
||||
|
||||
|
@ -225,6 +225,11 @@ IVolume::EPlatform CVolumeDirectory::GetVolumeType() const
|
||||
return m_is_wii ? WII_DISC : GAMECUBE_DISC;
|
||||
}
|
||||
|
||||
bool CVolumeDirectory::IsCompressed() const
|
||||
{
|
||||
return false;
|
||||
}
|
||||
|
||||
u64 CVolumeDirectory::GetSize() const
|
||||
{
|
||||
return 0;
|
||||
|
@ -51,6 +51,7 @@ public:
|
||||
|
||||
ECountry GetCountry() const override;
|
||||
|
||||
bool IsCompressed() const override;
|
||||
u64 GetSize() const override;
|
||||
u64 GetRawSize() const override;
|
||||
|
||||
|
@ -168,6 +168,11 @@ std::string CVolumeGC::GetApploaderDate() const
|
||||
return DecodeString(date);
|
||||
}
|
||||
|
||||
bool CVolumeGC::IsCompressed() const
|
||||
{
|
||||
return m_pReader ? m_pReader->IsCompressed() : false;
|
||||
}
|
||||
|
||||
u64 CVolumeGC::GetSize() const
|
||||
{
|
||||
if (m_pReader)
|
||||
|
@ -39,6 +39,7 @@ public:
|
||||
|
||||
EPlatform GetVolumeType() const override;
|
||||
ECountry GetCountry() const override;
|
||||
bool IsCompressed() const override;
|
||||
u64 GetSize() const override;
|
||||
u64 GetRawSize() const override;
|
||||
|
||||
|
@ -124,6 +124,11 @@ std::map<IVolume::ELanguage, std::string> CVolumeWAD::GetNames(bool prefer_long)
|
||||
return ReadWiiNames(name_data);
|
||||
}
|
||||
|
||||
bool CVolumeWAD::IsCompressed() const
|
||||
{
|
||||
return m_pReader ? m_pReader->IsCompressed() : false;
|
||||
}
|
||||
|
||||
u64 CVolumeWAD::GetSize() const
|
||||
{
|
||||
if (m_pReader)
|
||||
|
@ -37,8 +37,9 @@ public:
|
||||
std::string GetApploaderDate() const override { return ""; }
|
||||
|
||||
EPlatform GetVolumeType() const override;
|
||||
|
||||
ECountry GetCountry() const override;
|
||||
|
||||
bool IsCompressed() const override;
|
||||
u64 GetSize() const override;
|
||||
u64 GetRawSize() const override;
|
||||
|
||||
|
@ -250,6 +250,11 @@ u8 CVolumeWiiCrypted::GetDiscNumber() const
|
||||
return disc_number;
|
||||
}
|
||||
|
||||
bool CVolumeWiiCrypted::IsCompressed() const
|
||||
{
|
||||
return m_pReader ? m_pReader->IsCompressed() : false;
|
||||
}
|
||||
|
||||
u64 CVolumeWiiCrypted::GetSize() const
|
||||
{
|
||||
if (m_pReader)
|
||||
|
@ -43,6 +43,7 @@ public:
|
||||
bool ChangePartition(u64 offset) override;
|
||||
|
||||
ECountry GetCountry() const override;
|
||||
bool IsCompressed() const override;
|
||||
u64 GetSize() const override;
|
||||
u64 GetRawSize() const override;
|
||||
|
||||
|
@ -19,6 +19,7 @@ class WbfsFileReader : public IBlobReader
|
||||
public:
|
||||
static WbfsFileReader* Create(const std::string& filename);
|
||||
|
||||
bool IsCompressed() const override { return true; }
|
||||
u64 GetDataSize() const override { return m_size; }
|
||||
u64 GetRawSize() const override { return m_size; }
|
||||
bool Read(u64 offset, u64 nbytes, u8* out_ptr) override;
|
||||
|
Reference in New Issue
Block a user