mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-07-22 13:49:53 -06:00
NANDContentLoader/WiiWAD: Get rid of raw delete and new
This commit is contained in:
@ -20,76 +20,73 @@ namespace DiscIO
|
||||
|
||||
WiiWAD::WiiWAD(const std::string& name)
|
||||
{
|
||||
std::unique_ptr<IBlobReader> reader(DiscIO::CreateBlobReader(name));
|
||||
std::unique_ptr<IBlobReader> reader(CreateBlobReader(name));
|
||||
if (reader == nullptr || File::IsDirectory(name))
|
||||
{
|
||||
m_Valid = false;
|
||||
m_valid = false;
|
||||
return;
|
||||
}
|
||||
|
||||
m_Valid = ParseWAD(*reader);
|
||||
m_valid = ParseWAD(*reader);
|
||||
}
|
||||
|
||||
WiiWAD::~WiiWAD()
|
||||
{
|
||||
if (m_Valid)
|
||||
{
|
||||
delete[] m_pCertificateChain;
|
||||
delete[] m_pTicket;
|
||||
delete[] m_pTMD;
|
||||
delete[] m_pDataApp;
|
||||
delete[] m_pFooter;
|
||||
}
|
||||
}
|
||||
|
||||
u8* WiiWAD::CreateWADEntry(DiscIO::IBlobReader& _rReader, u32 _Size, u64 _Offset)
|
||||
std::vector<u8> WiiWAD::CreateWADEntry(IBlobReader& reader, u32 size, u64 offset)
|
||||
{
|
||||
if (_Size > 0)
|
||||
{
|
||||
u8* pTmpBuffer = new u8[_Size];
|
||||
_dbg_assert_msg_(BOOT, pTmpBuffer!=nullptr, "WiiWAD: Can't allocate memory for WAD entry");
|
||||
if (size == 0)
|
||||
return {};
|
||||
|
||||
if (!_rReader.Read(_Offset, _Size, pTmpBuffer))
|
||||
{
|
||||
ERROR_LOG(DISCIO, "WiiWAD: Could not read from file");
|
||||
PanicAlertT("WiiWAD: Could not read from file");
|
||||
}
|
||||
return pTmpBuffer;
|
||||
std::vector<u8> buffer(size);
|
||||
|
||||
if (!reader.Read(offset, size, buffer.data()))
|
||||
{
|
||||
ERROR_LOG(DISCIO, "WiiWAD: Could not read from file");
|
||||
PanicAlertT("WiiWAD: Could not read from file");
|
||||
}
|
||||
return nullptr;
|
||||
|
||||
return buffer;
|
||||
}
|
||||
|
||||
|
||||
bool WiiWAD::ParseWAD(DiscIO::IBlobReader& _rReader)
|
||||
bool WiiWAD::ParseWAD(IBlobReader& reader)
|
||||
{
|
||||
CBlobBigEndianReader ReaderBig(_rReader);
|
||||
CBlobBigEndianReader big_endian_reader(reader);
|
||||
|
||||
if (!IsWiiWAD(ReaderBig))
|
||||
if (!IsWiiWAD(big_endian_reader))
|
||||
return false;
|
||||
|
||||
u32 Reserved;
|
||||
if (!ReaderBig.ReadSwapped(0x8, &m_CertificateChainSize) ||
|
||||
!ReaderBig.ReadSwapped(0xC, &Reserved) ||
|
||||
!ReaderBig.ReadSwapped(0x10, &m_TicketSize) ||
|
||||
!ReaderBig.ReadSwapped(0x14, &m_TMDSize) ||
|
||||
!ReaderBig.ReadSwapped(0x18, &m_DataAppSize) ||
|
||||
!ReaderBig.ReadSwapped(0x1C, &m_FooterSize))
|
||||
u32 certificate_chain_size;
|
||||
u32 reserved;
|
||||
u32 ticket_size;
|
||||
u32 tmd_size;
|
||||
u32 data_app_size;
|
||||
u32 footer_size;
|
||||
|
||||
if (!big_endian_reader.ReadSwapped(0x08, &certificate_chain_size) ||
|
||||
!big_endian_reader.ReadSwapped(0x0C, &reserved) ||
|
||||
!big_endian_reader.ReadSwapped(0x10, &ticket_size) ||
|
||||
!big_endian_reader.ReadSwapped(0x14, &tmd_size) ||
|
||||
!big_endian_reader.ReadSwapped(0x18, &data_app_size) ||
|
||||
!big_endian_reader.ReadSwapped(0x1C, &footer_size))
|
||||
return false;
|
||||
|
||||
if (MAX_LOGLEVEL >= LogTypes::LOG_LEVELS::LDEBUG)
|
||||
_dbg_assert_msg_(BOOT, Reserved==0x00, "WiiWAD: Reserved must be 0x00");
|
||||
_dbg_assert_msg_(BOOT, reserved == 0x00, "WiiWAD: Reserved must be 0x00");
|
||||
|
||||
u32 Offset = 0x40;
|
||||
m_pCertificateChain = CreateWADEntry(_rReader, m_CertificateChainSize, Offset); Offset += ROUND_UP(m_CertificateChainSize, 0x40);
|
||||
m_pTicket = CreateWADEntry(_rReader, m_TicketSize, Offset); Offset += ROUND_UP(m_TicketSize, 0x40);
|
||||
m_pTMD = CreateWADEntry(_rReader, m_TMDSize, Offset); Offset += ROUND_UP(m_TMDSize, 0x40);
|
||||
m_pDataApp = CreateWADEntry(_rReader, m_DataAppSize, Offset); Offset += ROUND_UP(m_DataAppSize, 0x40);
|
||||
m_pFooter = CreateWADEntry(_rReader, m_FooterSize, Offset); Offset += ROUND_UP(m_FooterSize, 0x40);
|
||||
u32 offset = 0x40;
|
||||
m_certificate_chain = CreateWADEntry(reader, certificate_chain_size, offset); offset += ROUND_UP(certificate_chain_size, 0x40);
|
||||
m_ticket = CreateWADEntry(reader, ticket_size, offset); offset += ROUND_UP(ticket_size, 0x40);
|
||||
m_tmd = CreateWADEntry(reader, tmd_size, offset); offset += ROUND_UP(tmd_size, 0x40);
|
||||
m_data_app = CreateWADEntry(reader, data_app_size, offset); offset += ROUND_UP(data_app_size, 0x40);
|
||||
m_footer = CreateWADEntry(reader, footer_size, offset); offset += ROUND_UP(footer_size, 0x40);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
bool WiiWAD::IsWiiWAD(const DiscIO::CBlobBigEndianReader& reader)
|
||||
bool WiiWAD::IsWiiWAD(const CBlobBigEndianReader& reader)
|
||||
{
|
||||
u32 header_size = 0;
|
||||
u32 header_type = 0;
|
||||
|
Reference in New Issue
Block a user