2012-04-21 21:13:50 +00:00
|
|
|
/* RetroArch - A frontend for libretro.
|
2014-01-01 00:50:59 +00:00
|
|
|
* Copyright (C) 2010-2014 - Hans-Kristian Arntzen
|
2016-01-10 03:06:50 +00:00
|
|
|
* Copyright (C) 2011-2016 - Daniel De Matteis
|
2015-01-07 16:46:50 +00:00
|
|
|
* Copyright (C) 2014-2015 - Alfred Agrell
|
2011-01-31 15:06:46 +00:00
|
|
|
*
|
2012-04-21 21:13:50 +00:00
|
|
|
* RetroArch is free software: you can redistribute it and/or modify it under the terms
|
2011-01-31 15:06:46 +00:00
|
|
|
* of the GNU General Public License as published by the Free Software Found-
|
|
|
|
* ation, either version 3 of the License, or (at your option) any later version.
|
|
|
|
*
|
2012-04-21 21:13:50 +00:00
|
|
|
* RetroArch is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
|
2011-01-31 15:06:46 +00:00
|
|
|
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
|
|
|
* PURPOSE. See the GNU General Public License for more details.
|
|
|
|
*
|
2012-04-21 21:31:57 +00:00
|
|
|
* You should have received a copy of the GNU General Public License along with RetroArch.
|
2011-01-31 15:06:46 +00:00
|
|
|
* If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
2012-04-21 21:25:32 +00:00
|
|
|
#ifndef __RARCH_REWIND_H
|
|
|
|
#define __RARCH_REWIND_H
|
2011-01-31 15:06:46 +00:00
|
|
|
|
2014-11-29 20:18:45 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2015-09-16 09:14:43 +00:00
|
|
|
#include <stdint.h>
|
2011-01-31 15:06:46 +00:00
|
|
|
#include <stddef.h>
|
2014-10-21 03:05:52 +00:00
|
|
|
#include <boolean.h>
|
2011-01-31 15:06:46 +00:00
|
|
|
|
|
|
|
typedef struct state_manager state_manager_t;
|
|
|
|
|
2014-02-18 07:22:36 +00:00
|
|
|
state_manager_t *state_manager_new(size_t state_size, size_t buffer_size);
|
2014-09-02 03:10:54 +00:00
|
|
|
|
2011-01-31 15:06:46 +00:00
|
|
|
void state_manager_free(state_manager_t *state);
|
2014-09-02 03:10:54 +00:00
|
|
|
|
2014-02-21 20:51:58 +00:00
|
|
|
bool state_manager_pop(state_manager_t *state, const void **data);
|
2014-09-02 03:10:54 +00:00
|
|
|
|
2014-02-21 20:42:05 +00:00
|
|
|
void state_manager_push_where(state_manager_t *state, void **data);
|
2014-09-02 03:10:54 +00:00
|
|
|
|
2014-02-21 20:42:05 +00:00
|
|
|
void state_manager_push_do(state_manager_t *state);
|
2014-09-02 03:10:54 +00:00
|
|
|
|
|
|
|
void state_manager_capacity(state_manager_t *state,
|
|
|
|
unsigned int *entries, size_t *bytes, bool *full);
|
2011-01-31 15:06:46 +00:00
|
|
|
|
2015-04-11 11:36:33 +00:00
|
|
|
void init_rewind(void);
|
|
|
|
|
2015-06-27 02:53:37 +00:00
|
|
|
|
|
|
|
/* Returns the maximum compressed size of a savestate. It is very likely to compress to far less. */
|
|
|
|
size_t state_manager_raw_maxsize(size_t uncomp);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* See state_manager_raw_compress for information about this.
|
|
|
|
* When you're done with it, send it to free().
|
|
|
|
*/
|
|
|
|
void *state_manager_raw_alloc(size_t len, uint16_t uniq);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Takes two savestates and creates a patch that turns 'src' into 'dst'.
|
|
|
|
* Both 'src' and 'dst' must be returned from state_manager_raw_alloc(), with the same 'len', and different 'uniq'.
|
|
|
|
* 'patch' must be size 'state_manager_raw_maxsize(len)' or more.
|
|
|
|
* Returns the number of bytes actually written to 'patch'.
|
|
|
|
*/
|
|
|
|
size_t state_manager_raw_compress(const void *src, const void *dst, size_t len, void *patch);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Takes 'patch' from a previous call to 'state_manager_raw_compress' and applies it to 'data' ('src' from that call),
|
|
|
|
* yielding 'dst' in that call.
|
|
|
|
* If the given arguments do not match a previous call to state_manager_raw_compress(), anything at all can happen.
|
|
|
|
*/
|
|
|
|
void state_manager_raw_decompress(const void *patch, size_t patchlen, void *data, size_t datalen);
|
|
|
|
|
2015-09-16 09:14:43 +00:00
|
|
|
bool state_manager_frame_is_reversed(void);
|
|
|
|
|
|
|
|
void state_manager_set_frame_is_reversed(bool value);
|
|
|
|
|
2015-11-30 21:25:13 +00:00
|
|
|
void state_manager_event_deinit(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* check_rewind:
|
|
|
|
* @pressed : was rewind key pressed or held?
|
|
|
|
*
|
|
|
|
* Checks if rewind toggle/hold was being pressed and/or held.
|
|
|
|
**/
|
|
|
|
void state_manager_check_rewind(bool pressed);
|
|
|
|
|
2014-11-29 20:18:45 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2011-01-31 15:06:46 +00:00
|
|
|
#endif
|