RetroArch/runloop.h

356 lines
7.4 KiB
C
Raw Normal View History

2015-01-09 17:40:33 +00:00
/* RetroArch - A frontend for libretro.
* Copyright (C) 2011-2015 - Daniel De Matteis
*
* RetroArch is free software: you can redistribute it and/or modify it under the terms
* 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.
*
* RetroArch is distributed in the hope that it will be useful, 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 along with RetroArch.
* If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef __RETROARCH_RUNLOOP_H
#define __RETROARCH_RUNLOOP_H
2015-03-21 00:59:47 +00:00
#include <setjmp.h>
#include "libretro.h"
2015-03-21 00:59:47 +00:00
#include "core_info.h"
#include "core_options.h"
#include "driver.h"
#include "rewind.h"
#include "autosave.h"
#include "movie.h"
#include "cheats.h"
2015-06-20 21:42:30 +00:00
#include "dynamic.h"
2015-06-25 10:22:38 +00:00
#include "system.h"
2015-01-09 17:40:33 +00:00
#ifdef __cplusplus
extern "C" {
#endif
2015-08-03 18:15:46 +00:00
typedef struct rarch_resolution
{
unsigned idx;
unsigned id;
} rarch_resolution_t;
2015-08-03 18:15:46 +00:00
/* All run-time- / command line flag-related globals go here. */
typedef struct global
{
/* Lifecycle state checks. */
bool is_idle;
2015-04-12 23:55:35 +00:00
bool ui_companion_is_on_foreground;
struct
{
struct
{
retro_time_t minimum_time;
retro_time_t last_time;
} limit;
} frames;
2015-08-03 18:03:14 +00:00
bool is_slowmotion;
bool is_paused;
2015-08-03 17:49:34 +00:00
unsigned max_frames;
2015-03-21 00:59:47 +00:00
bool verbosity;
bool perfcnt_enable;
bool force_fullscreen;
bool core_shutdown_initiated;
struct string_list *temporary_content;
2015-07-27 15:18:10 +00:00
struct
{
core_info_list_t *list;
core_info_t *current;
} core_info;
2015-03-21 00:59:47 +00:00
uint32_t content_crc;
2015-07-27 15:18:10 +00:00
struct
{
char gb_rom[PATH_MAX_LENGTH];
char bsx_rom[PATH_MAX_LENGTH];
char sufami_rom[2][PATH_MAX_LENGTH];
/* Config associated with global "default" config. */
char config[PATH_MAX_LENGTH];
char append_config[PATH_MAX_LENGTH];
char input_config[PATH_MAX_LENGTH];
2015-03-21 00:59:47 +00:00
#ifdef HAVE_FILE_LOGGER
2015-07-27 15:18:10 +00:00
char default_log[PATH_MAX_LENGTH];
2015-03-21 00:59:47 +00:00
#endif
2015-07-27 15:18:10 +00:00
char fullpath[PATH_MAX_LENGTH];
/* Config file associated with per-core configs. */
char core_specific_config[PATH_MAX_LENGTH];
} path;
struct
{
bool input_descriptors;
bool save_path;
bool state_path;
bool libretro_device[MAX_USERS];
bool libretro;
bool libretro_directory;
bool verbosity;
bool netplay_mode;
bool username;
bool netplay_ip_address;
bool netplay_delay_frames;
bool netplay_ip_port;
bool ups_pref;
bool bps_pref;
bool ips_pref;
} has_set;
2015-03-21 00:59:47 +00:00
2015-07-27 15:18:10 +00:00
bool overrides_active;
struct
{
char base[PATH_MAX_LENGTH];
char savefile[PATH_MAX_LENGTH];
char savestate[PATH_MAX_LENGTH];
char cheatfile[PATH_MAX_LENGTH];
char ups[PATH_MAX_LENGTH];
char bps[PATH_MAX_LENGTH];
char ips[PATH_MAX_LENGTH];
} name;
2015-03-21 00:59:47 +00:00
/* A list of save types and associated paths for all content. */
struct string_list *savefiles;
/* For --subsystem content. */
char subsystem[PATH_MAX_LENGTH];
struct string_list *subsystem_fullpaths;
2015-07-27 15:18:10 +00:00
struct
{
/* Used on reentrancy to use a savestate dir. */
char savefile[PATH_MAX_LENGTH];
char savestate[PATH_MAX_LENGTH];
2015-03-21 00:59:47 +00:00
#ifdef HAVE_OVERLAY
2015-07-27 15:18:10 +00:00
char overlay[PATH_MAX_LENGTH];
char osk_overlay[PATH_MAX_LENGTH];
2015-03-21 00:59:47 +00:00
#endif
2015-07-27 15:18:10 +00:00
} dir;
2015-03-21 00:59:47 +00:00
2015-07-27 15:18:10 +00:00
struct
{
bool block_patch;
bool ups_pref;
bool bps_pref;
bool ips_pref;
} patch;
2015-03-21 00:59:47 +00:00
struct
{
unsigned windowed_scale;
} pending;
#ifdef HAVE_MENU
struct
{
struct retro_system_info info;
bool bind_mode_keyboard;
} menu;
#endif
bool exec;
struct
{
/* Rewind support. */
state_manager_t *state;
size_t size;
bool frame_is_reverse;
} rewind;
struct
{
/* Movie playback/recording support. */
bsv_movie_t *movie;
char movie_path[PATH_MAX_LENGTH];
bool movie_playback;
bool eof_exit;
/* Immediate playback/recording. */
char movie_start_path[PATH_MAX_LENGTH];
bool movie_start_recording;
bool movie_start_playback;
bool movie_end;
} bsv;
2015-07-27 15:18:10 +00:00
struct
{
bool load_disable;
bool save_disable;
bool use;
} sram;
2015-03-21 00:59:47 +00:00
/* Turbo support. */
2015-07-27 15:18:10 +00:00
struct
{
bool frame_enable[MAX_USERS];
unsigned count;
} turbo;
2015-03-21 00:59:47 +00:00
/* Autosave support. */
2015-07-27 15:18:10 +00:00
struct
{
autosave_t **list;
unsigned num;
} autosave;
2015-03-21 00:59:47 +00:00
#ifdef HAVE_NETPLAY
/* Netplay. */
2015-07-27 15:18:10 +00:00
struct
{
char server[PATH_MAX_LENGTH];
bool enable;
bool is_client;
bool is_spectate;
unsigned sync_frames;
unsigned port;
} netplay;
2015-03-21 00:59:47 +00:00
#endif
/* Recording. */
struct
{
char path[PATH_MAX_LENGTH];
char config[PATH_MAX_LENGTH];
bool enable;
unsigned width;
unsigned height;
uint8_t *gpu_buffer;
size_t gpu_width;
size_t gpu_height;
2015-04-15 10:42:36 +00:00
char output_dir[PATH_MAX_LENGTH];
char config_dir[PATH_MAX_LENGTH];
bool use_output_dir;
2015-03-21 00:59:47 +00:00
} record;
struct
{
struct string_list *list;
size_t ptr;
} shader_dir;
struct
{
struct string_list *list;
size_t ptr;
} filter_dir;
cheat_manager_t *cheat;
bool block_config_read;
/* Settings and/or global state that is specific to
* a console-style implementation. */
struct
{
struct
{
struct
{
rarch_resolution_t current;
rarch_resolution_t initial;
uint32_t *list;
unsigned count;
bool check;
2015-07-06 05:29:51 +00:00
unsigned width;
unsigned height;
2015-03-21 00:59:47 +00:00
} resolutions;
unsigned gamma_correction;
unsigned char flicker_filter_index;
unsigned char soft_filter_index;
bool pal_enable;
bool pal60_enable;
} screen;
struct
{
unsigned mode;
bool system_bgm_enable;
} sound;
bool flickerfilter_enable;
bool softfilter_enable;
} console;
/* If this is non-NULL. RARCH_LOG and friends
* will write to this file. */
FILE *log_file;
2015-07-27 15:18:10 +00:00
struct
{
bool main;
bool content;
bool error;
struct
{
bool no_content;
enum rarch_core_type type;
} core;
} inited;
2015-03-21 00:59:47 +00:00
2015-07-27 15:18:10 +00:00
jmp_buf error_sjlj_context;
char error_string[PATH_MAX_LENGTH];
2015-03-21 00:59:47 +00:00
retro_keyboard_event_t frontend_key_event;
} global_t;
global_t *global_get_ptr(void);
2015-01-09 17:40:33 +00:00
/**
* rarch_main_iterate:
*
2015-01-09 23:59:05 +00:00
* Run Libretro core in RetroArch for one frame.
2015-01-09 17:40:33 +00:00
*
2015-01-09 23:59:05 +00:00
* Returns: 0 on successful run, 1 if we have to wait until button input in order
* to wake up the loop, -1 if we forcibly quit out of the RetroArch iteration loop.
2015-01-09 17:40:33 +00:00
**/
int rarch_main_iterate(void);
void rarch_main_msg_queue_push(const char *msg, unsigned prio,
unsigned duration, bool flush);
2015-06-30 23:49:32 +00:00
void rarch_main_msg_queue_push_new(uint32_t hash, unsigned prio,
unsigned duration, bool flush);
const char *rarch_main_msg_queue_pull(void);
void rarch_main_msg_queue_free(void);
void rarch_main_msg_queue_init(void);
2015-03-18 05:47:22 +00:00
void rarch_main_clear_state(void);
bool rarch_main_verbosity(void);
FILE *rarch_main_log_file(void);
2015-03-18 19:48:17 +00:00
bool rarch_main_is_idle(void);
2015-03-22 02:41:20 +00:00
void rarch_main_state_free(void);
2015-03-21 18:43:46 +00:00
2015-03-22 02:41:20 +00:00
void rarch_main_global_free(void);
2015-03-21 18:43:46 +00:00
2015-01-09 17:40:33 +00:00
#ifdef __cplusplus
}
#endif
#endif