athena/include/Athena/MCFileWriter.hpp

76 lines
2.0 KiB
C++
Raw Normal View History

#ifndef ATHENA_NO_SAVES
2014-04-20 09:14:15 +00:00
// This file is part of libAthena.
2013-07-21 03:57:20 +00:00
//
2014-04-20 09:14:15 +00:00
// libAthena is free software: you can redistribute it and/or modify
2013-07-21 03:57:20 +00:00
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
2014-04-20 09:14:15 +00:00
// libAthena is distributed in the hope that it will be useful,
2013-07-21 03:57:20 +00:00
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
2014-04-20 09:14:15 +00:00
// along with libAthena. If not, see <http://www.gnu.org/licenses/>
2013-07-21 03:57:20 +00:00
#ifndef __MCFILEWRITER_HPP__
#define __MCFILEWRITER_HPP__
#include "Types.hpp"
#include "BinaryWriter.hpp"
2014-04-20 09:14:15 +00:00
namespace Athena
2013-07-21 03:57:20 +00:00
{
class MCFile;
namespace io
{
2013-07-21 03:57:20 +00:00
/*! \class MCFileWriter
* \brief The Minish Cap Save save data writer class
*
* A Class for writing binary data to a The Minish Cap Save File,
* all work is done using a memory buffer, and not written directly from the disk.
* \sa BinaryWriter
*/
class MCFileWriter : protected BinaryWriter
2013-07-21 03:57:20 +00:00
{
BINARYWRITER_BASE
2013-07-21 03:57:20 +00:00
public:
/*!
* \brief This constructor takes an existing buffer to write to.
*
* \param data The existing buffer
* \param length The length of the existing buffer
*/
MCFileWriter(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
*/
MCFileWriter(const std::string&);
/*!
* \brief Writes the given save data to a file on disk
*
* \param file Save data to write
*/
void writeFile(MCFile* file);
private:
atUint16 calculateSlotChecksum(atUint32 game);
atUint16 calculateChecksum(atUint8* data, atUint32 length);
atUint8* reverse(atUint8* data, atUint32 length);
2013-07-21 03:57:20 +00:00
void unscramble();
};
} // io
2013-07-21 03:57:20 +00:00
} // zelda
#endif // __MCFILEWRITER_HPP__
#endif // ATHENA_NO_SAVES