athena/include/Athena/WiiSaveReader.hpp

57 lines
1.3 KiB
C++
Raw Permalink Normal View History

2015-03-01 20:42:39 +00:00
#ifndef WIISAVEREADER_HPP
#define WIISAVEREADER_HPP
2013-02-16 04:22:16 +00:00
2014-04-20 09:14:15 +00:00
#include "Athena/Global.hpp"
2015-03-01 20:42:39 +00:00
#include "Athena/MemoryReader.hpp"
2013-02-16 04:22:16 +00:00
2014-04-20 09:14:15 +00:00
namespace Athena
2013-07-21 03:57:20 +00:00
{
2013-02-16 04:22:16 +00:00
class WiiSave;
class WiiBanner;
class WiiFile;
class WiiImage;
namespace io
{
2013-07-21 03:57:20 +00:00
/*! \class WiiSaveReader
* \brief Wii data.bin reader class
*
* A Class for reading binary data from a wii data.bin file,
* all work is done using a memory buffer, and not read directly from the disk.
* \sa BinaryReader
*/
class WiiSaveReader : protected MemoryCopyReader
2013-02-16 04:22:16 +00:00
{
MEMORYCOPYREADER_BASE();
2013-02-16 04:22:16 +00:00
public:
2013-07-21 03:57:20 +00:00
/*! \brief This constructor takes an existing buffer to read from.
*
* \param data The existing buffer
* \param length The length of the existing buffer
*/
WiiSaveReader(const atUint8*, atUint64);
2013-07-21 03:57:20 +00:00
/*! \brief This constructor creates an instance from a file on disk.
*
* \param filename The file to create the stream from
*/
2013-02-16 04:22:16 +00:00
WiiSaveReader(const std::string&);
2013-07-21 03:57:20 +00:00
/*!
* \brief readSave
* \return
*/
2013-02-16 04:22:16 +00:00
WiiSave* readSave();
private:
WiiBanner* readBanner();
WiiFile* readFile();
WiiImage* readImage(atUint32 width, atUint32 height);
void readCerts(atUint32 totalSize);
WiiFile* buildTree(std::vector<WiiFile*> files);
2013-02-16 04:22:16 +00:00
};
2013-07-21 03:57:20 +00:00
} // io
2013-07-21 03:57:20 +00:00
} // zelda
2015-03-01 20:42:39 +00:00
#endif // WIISAVEREADER_HPP