lsnes/include/core/moviefile.hpp

173 lines
3.8 KiB
C++
Raw Normal View History

#ifndef _moviefile__hpp__included__
#define _moviefile__hpp__included__
#include <string>
#include <vector>
#include <stdexcept>
#include <map>
#include "controllerdata.hpp"
#include "rom.hpp"
/**
* This structure gives parsed representationg of movie file, as result of decoding or for encoding.
*/
struct moviefile
{
/**
* This constructor construct movie structure with default settings.
*
2011-09-16 21:09:22 +03:00
* throws std::bad_alloc: Not enough memory.
*/
moviefile() throw(std::bad_alloc);
/**
* This constructor loads a movie/savestate file and fills structure accordingly.
*
2011-09-16 21:09:22 +03:00
* parameter filename: The file to load.
* throws std::bad_alloc: Not enough memory.
* throws std::runtime_error: Can't load the movie file
*/
moviefile(const std::string& filename) throw(std::bad_alloc, std::runtime_error);
/**
* Reads this movie structure and saves it into file.
*
2011-09-16 21:09:22 +03:00
* parameter filename: The file to save to.
* parameter compression: The compression level 0-9. 0 is uncompressed.
* throws std::bad_alloc: Not enough memory.
* throws std::runtime_error: Can't save the movie file.
*/
void save(const std::string& filename, unsigned compression) throw(std::bad_alloc, std::runtime_error);
/**
* Force loading as corrupt.
*/
bool force_corrupt;
/**
2011-09-16 21:09:22 +03:00
* What is the ROM type and region?
*/
gametype_t gametype;
/**
2011-09-16 21:09:22 +03:00
* What's in port #1?
*/
porttype_t port1;
/**
2011-09-16 21:09:22 +03:00
* What's in port #2?
*/
porttype_t port2;
/**
2011-09-16 21:09:22 +03:00
* Emulator Core version string.
*/
std::string coreversion;
/**
2011-09-16 21:09:22 +03:00
* Name of the game
*/
std::string gamename;
/**
2011-09-16 21:09:22 +03:00
* Project ID (used to identify if two movies are from the same project).
*/
std::string projectid;
/**
2011-09-16 21:09:22 +03:00
* Rerecord count (only saved).
*/
std::string rerecords;
/**
2011-09-16 21:09:22 +03:00
* SHA-256 of main ROM (empty string if none).
*/
std::string rom_sha256; //SHA-256 of main ROM.
/**
2011-09-16 21:09:22 +03:00
* SHA-256 of main ROM XML (empty string if none).
*/
std::string romxml_sha256; //SHA-256 of main ROM XML.
/**
2011-09-16 21:09:22 +03:00
* SHA-256 of slot A ROM (empty string if none).
*/
std::string slota_sha256; //SHA-256 of SLOT A ROM.
/**
2011-09-16 21:09:22 +03:00
* SHA-256 of slot A XML (empty string if none).
*/
std::string slotaxml_sha256; //SHA-256 of SLOT A XML.
/**
2011-09-16 21:09:22 +03:00
* SHA-256 of slot B ROM (empty string if none).
*/
std::string slotb_sha256; //SHA-256 of SLOT B ROM.
/**
2011-09-16 21:09:22 +03:00
* SHA-256 of slot B XML (empty string if none).
*/
std::string slotbxml_sha256; //SHA-256 of SLOT B XML.
/**
2011-09-16 21:09:22 +03:00
* Authors of the run, first in each pair is full name, second is nickname.
*/
std::vector<std::pair<std::string, std::string>> authors;
/**
2011-09-16 21:09:22 +03:00
* Contents of SRAM on time of initial powerup.
*/
std::map<std::string, std::vector<char>> movie_sram;
/**
2011-09-16 21:09:22 +03:00
* True if savestate, false if movie.
*/
bool is_savestate;
/**
2011-09-16 21:09:22 +03:00
* Contents of SRAM on time of savestate (if is_savestate is true).
*/
std::map<std::string, std::vector<char>> sram;
/**
2011-09-16 21:09:22 +03:00
* Core savestate (if is_savestate is true).
*/
std::vector<char> savestate; //Savestate to load (if is_savestate is true).
/**
2011-09-16 21:09:22 +03:00
* Host memory (if is_savestate is true).
*/
std::vector<char> host_memory;
/**
2011-09-16 21:09:22 +03:00
* Screenshot (if is_savestate is true).
*/
std::vector<char> screenshot;
/**
2011-09-16 21:09:22 +03:00
* State of movie code (if is_savestate is true).
*/
std::vector<char> movie_state;
/**
* Compressed rrdata.
*/
std::vector<char> c_rrdata;
/**
2011-09-16 21:09:22 +03:00
* Input for each (sub)frame.
*/
std::vector<controls_t> input; //Input for each frame.
/**
* Current RTC second.
*/
int64_t rtc_second;
/**
* Current RTC subsecond.
*/
int64_t rtc_subsecond;
/**
* Movie starting RTC second.
*/
int64_t movie_rtc_second;
/**
* Movie starting RTC subsecond.
*/
int64_t movie_rtc_subsecond;
/**
2011-09-16 21:09:22 +03:00
* Get number of frames in movie.
*
2011-09-16 21:09:22 +03:00
* returns: Number of frames.
*/
uint64_t get_frame_count() throw();
/**
2011-09-16 21:09:22 +03:00
* Get length of the movie
*
* parameter framebias: Number of frames to subtract.
2011-09-16 21:09:22 +03:00
* returns: Length of the movie in nanoseconds.
*/
uint64_t get_movie_length(uint64_t framebias = 0) throw();
};
#endif