libretro: Update core options API
This commit is contained in:
parent
d92ca688b3
commit
9b043daadf
|
@ -1117,7 +1117,7 @@ enum retro_mod
|
||||||
* This may be still be done regardless of the core options
|
* This may be still be done regardless of the core options
|
||||||
* interface version.
|
* interface version.
|
||||||
*
|
*
|
||||||
* If version is 1 however, core options may instead be set by
|
* If version is >= 1 however, core options may instead be set by
|
||||||
* passing an array of retro_core_option_definition structs to
|
* passing an array of retro_core_option_definition structs to
|
||||||
* RETRO_ENVIRONMENT_SET_CORE_OPTIONS, or a 2D array of
|
* RETRO_ENVIRONMENT_SET_CORE_OPTIONS, or a 2D array of
|
||||||
* retro_core_option_definition structs to RETRO_ENVIRONMENT_SET_CORE_OPTIONS_INTL.
|
* retro_core_option_definition structs to RETRO_ENVIRONMENT_SET_CORE_OPTIONS_INTL.
|
||||||
|
@ -1132,8 +1132,8 @@ enum retro_mod
|
||||||
* GET_VARIABLE.
|
* GET_VARIABLE.
|
||||||
* This allows the frontend to present these variables to
|
* This allows the frontend to present these variables to
|
||||||
* a user dynamically.
|
* a user dynamically.
|
||||||
* This should only be called if RETRO_ENVIRONMENT_GET_ENHANCED_CORE_OPTIONS
|
* This should only be called if RETRO_ENVIRONMENT_GET_CORE_OPTIONS_VERSION
|
||||||
* returns an API version of 1.
|
* returns an API version of >= 1.
|
||||||
* This should be called instead of RETRO_ENVIRONMENT_SET_VARIABLES.
|
* This should be called instead of RETRO_ENVIRONMENT_SET_VARIABLES.
|
||||||
* This should be called the first time as early as
|
* This should be called the first time as early as
|
||||||
* possible (ideally in retro_set_environment).
|
* possible (ideally in retro_set_environment).
|
||||||
|
@ -1169,14 +1169,12 @@ enum retro_mod
|
||||||
* i.e. it should be feasible to cycle through options
|
* i.e. it should be feasible to cycle through options
|
||||||
* without a keyboard.
|
* without a keyboard.
|
||||||
*
|
*
|
||||||
* First entry should be treated as a default.
|
|
||||||
*
|
|
||||||
* Example entry:
|
* Example entry:
|
||||||
* {
|
* {
|
||||||
* "foo_option",
|
* "foo_option",
|
||||||
* "Speed hack coprocessor X",
|
* "Speed hack coprocessor X",
|
||||||
* "Provides increased performance at the expense of reduced accuracy",
|
* "Provides increased performance at the expense of reduced accuracy",
|
||||||
* {
|
* {
|
||||||
* { "false", NULL },
|
* { "false", NULL },
|
||||||
* { "true", NULL },
|
* { "true", NULL },
|
||||||
* { "unstable", "Turbo (Unstable)" },
|
* { "unstable", "Turbo (Unstable)" },
|
||||||
|
@ -1196,8 +1194,8 @@ enum retro_mod
|
||||||
* GET_VARIABLE.
|
* GET_VARIABLE.
|
||||||
* This allows the frontend to present these variables to
|
* This allows the frontend to present these variables to
|
||||||
* a user dynamically.
|
* a user dynamically.
|
||||||
* This should only be called if RETRO_ENVIRONMENT_GET_ENHANCED_CORE_OPTIONS
|
* This should only be called if RETRO_ENVIRONMENT_GET_CORE_OPTIONS_VERSION
|
||||||
* returns an API version of 1.
|
* returns an API version of >= 1.
|
||||||
* This should be called instead of RETRO_ENVIRONMENT_SET_VARIABLES.
|
* This should be called instead of RETRO_ENVIRONMENT_SET_VARIABLES.
|
||||||
* This should be called the first time as early as
|
* This should be called the first time as early as
|
||||||
* possible (ideally in retro_set_environment).
|
* possible (ideally in retro_set_environment).
|
||||||
|
@ -1384,17 +1382,17 @@ typedef int (RETRO_CALLCONV *retro_vfs_closedir_t)(struct retro_vfs_dir_handle *
|
||||||
struct retro_vfs_interface
|
struct retro_vfs_interface
|
||||||
{
|
{
|
||||||
/* VFS API v1 */
|
/* VFS API v1 */
|
||||||
retro_vfs_get_path_t get_path;
|
retro_vfs_get_path_t get_path;
|
||||||
retro_vfs_open_t open;
|
retro_vfs_open_t open;
|
||||||
retro_vfs_close_t close;
|
retro_vfs_close_t close;
|
||||||
retro_vfs_size_t size;
|
retro_vfs_size_t size;
|
||||||
retro_vfs_tell_t tell;
|
retro_vfs_tell_t tell;
|
||||||
retro_vfs_seek_t seek;
|
retro_vfs_seek_t seek;
|
||||||
retro_vfs_read_t read;
|
retro_vfs_read_t read;
|
||||||
retro_vfs_write_t write;
|
retro_vfs_write_t write;
|
||||||
retro_vfs_flush_t flush;
|
retro_vfs_flush_t flush;
|
||||||
retro_vfs_remove_t remove;
|
retro_vfs_remove_t remove;
|
||||||
retro_vfs_rename_t rename;
|
retro_vfs_rename_t rename;
|
||||||
/* VFS API v2 */
|
/* VFS API v2 */
|
||||||
retro_vfs_truncate_t truncate;
|
retro_vfs_truncate_t truncate;
|
||||||
/* VFS API v3 */
|
/* VFS API v3 */
|
||||||
|
@ -1422,11 +1420,11 @@ struct retro_vfs_interface_info
|
||||||
|
|
||||||
enum retro_hw_render_interface_type
|
enum retro_hw_render_interface_type
|
||||||
{
|
{
|
||||||
RETRO_HW_RENDER_INTERFACE_VULKAN = 0,
|
RETRO_HW_RENDER_INTERFACE_VULKAN = 0,
|
||||||
RETRO_HW_RENDER_INTERFACE_D3D9 = 1,
|
RETRO_HW_RENDER_INTERFACE_D3D9 = 1,
|
||||||
RETRO_HW_RENDER_INTERFACE_D3D10 = 2,
|
RETRO_HW_RENDER_INTERFACE_D3D10 = 2,
|
||||||
RETRO_HW_RENDER_INTERFACE_D3D11 = 3,
|
RETRO_HW_RENDER_INTERFACE_D3D11 = 3,
|
||||||
RETRO_HW_RENDER_INTERFACE_D3D12 = 4,
|
RETRO_HW_RENDER_INTERFACE_D3D12 = 4,
|
||||||
RETRO_HW_RENDER_INTERFACE_GSKIT_PS2 = 5,
|
RETRO_HW_RENDER_INTERFACE_GSKIT_PS2 = 5,
|
||||||
RETRO_HW_RENDER_INTERFACE_DUMMY = INT_MAX
|
RETRO_HW_RENDER_INTERFACE_DUMMY = INT_MAX
|
||||||
};
|
};
|
||||||
|
@ -2504,8 +2502,20 @@ struct retro_core_option_display
|
||||||
};
|
};
|
||||||
|
|
||||||
/* Maximum number of values permitted for a core option
|
/* Maximum number of values permitted for a core option
|
||||||
* NOTE: This may be increased on a core-by-core basis
|
* > Note: We have to set a maximum value due the limitations
|
||||||
* if required (doing so has no effect on the frontend) */
|
* of the C language - i.e. it is not possible to create an
|
||||||
|
* array of structs each containing a variable sized array,
|
||||||
|
* so the retro_core_option_definition values array must
|
||||||
|
* have a fixed size. The size limit of 128 is a balancing
|
||||||
|
* act - it needs to be large enough to support all 'sane'
|
||||||
|
* core options, but setting it too large may impact low memory
|
||||||
|
* platforms. In practise, if a core option has more than
|
||||||
|
* 128 values then the implementation is likely flawed.
|
||||||
|
* To quote the above API reference:
|
||||||
|
* "The number of possible options should be very limited
|
||||||
|
* i.e. it should be feasible to cycle through options
|
||||||
|
* without a keyboard."
|
||||||
|
*/
|
||||||
#define RETRO_NUM_CORE_OPTION_VALUES_MAX 128
|
#define RETRO_NUM_CORE_OPTION_VALUES_MAX 128
|
||||||
|
|
||||||
struct retro_core_option_value
|
struct retro_core_option_value
|
||||||
|
@ -2749,4 +2759,4 @@ RETRO_API size_t retro_get_memory_size(unsigned id);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
|
@ -7,6 +7,28 @@
|
||||||
#include <libretro.h>
|
#include <libretro.h>
|
||||||
#include <retro_inline.h>
|
#include <retro_inline.h>
|
||||||
|
|
||||||
|
#ifndef HAVE_NO_LANGEXTRA
|
||||||
|
#include "libretro_core_options_intl.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
********************************
|
||||||
|
* VERSION: 1.3
|
||||||
|
********************************
|
||||||
|
*
|
||||||
|
* - 1.3: Move translations to libretro_core_options_intl.h
|
||||||
|
* - libretro_core_options_intl.h includes BOM and utf-8
|
||||||
|
* fix for MSVC 2010-2013
|
||||||
|
* - Added HAVE_NO_LANGEXTRA flag to disable translations
|
||||||
|
* on platforms/compilers without BOM support
|
||||||
|
* - 1.2: Use core options v1 interface when
|
||||||
|
* RETRO_ENVIRONMENT_GET_CORE_OPTIONS_VERSION is >= 1
|
||||||
|
* (previously required RETRO_ENVIRONMENT_GET_CORE_OPTIONS_VERSION == 1)
|
||||||
|
* - 1.1: Support generation of core options v0 retro_core_option_value
|
||||||
|
* arrays containing options with a single value
|
||||||
|
* - 1.0: First commit
|
||||||
|
*/
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
@ -462,48 +484,13 @@ struct retro_core_option_definition option_defs_us[] = {
|
||||||
{ NULL, NULL, NULL, {{0}}, NULL }
|
{ NULL, NULL, NULL, {{0}}, NULL }
|
||||||
};
|
};
|
||||||
|
|
||||||
/* RETRO_LANGUAGE_JAPANESE */
|
|
||||||
|
|
||||||
/* RETRO_LANGUAGE_FRENCH */
|
|
||||||
|
|
||||||
/* RETRO_LANGUAGE_SPANISH */
|
|
||||||
|
|
||||||
/* RETRO_LANGUAGE_GERMAN */
|
|
||||||
|
|
||||||
/* RETRO_LANGUAGE_ITALIAN */
|
|
||||||
|
|
||||||
/* RETRO_LANGUAGE_DUTCH */
|
|
||||||
|
|
||||||
/* RETRO_LANGUAGE_PORTUGUESE_BRAZIL */
|
|
||||||
|
|
||||||
/* RETRO_LANGUAGE_PORTUGUESE_PORTUGAL */
|
|
||||||
|
|
||||||
/* RETRO_LANGUAGE_RUSSIAN */
|
|
||||||
|
|
||||||
/* RETRO_LANGUAGE_KOREAN */
|
|
||||||
|
|
||||||
/* RETRO_LANGUAGE_CHINESE_TRADITIONAL */
|
|
||||||
|
|
||||||
/* RETRO_LANGUAGE_CHINESE_SIMPLIFIED */
|
|
||||||
|
|
||||||
/* RETRO_LANGUAGE_ESPERANTO */
|
|
||||||
|
|
||||||
/* RETRO_LANGUAGE_POLISH */
|
|
||||||
|
|
||||||
/* RETRO_LANGUAGE_VIETNAMESE */
|
|
||||||
|
|
||||||
/* RETRO_LANGUAGE_ARABIC */
|
|
||||||
|
|
||||||
/* RETRO_LANGUAGE_GREEK */
|
|
||||||
|
|
||||||
/* RETRO_LANGUAGE_TURKISH */
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
********************************
|
********************************
|
||||||
* Language Mapping
|
* Language Mapping
|
||||||
********************************
|
********************************
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
#ifndef HAVE_NO_LANGEXTRA
|
||||||
struct retro_core_option_definition *option_defs_intl[RETRO_LANGUAGE_LAST] = {
|
struct retro_core_option_definition *option_defs_intl[RETRO_LANGUAGE_LAST] = {
|
||||||
option_defs_us, /* RETRO_LANGUAGE_ENGLISH */
|
option_defs_us, /* RETRO_LANGUAGE_ENGLISH */
|
||||||
NULL, /* RETRO_LANGUAGE_JAPANESE */
|
NULL, /* RETRO_LANGUAGE_JAPANESE */
|
||||||
|
@ -525,6 +512,7 @@ struct retro_core_option_definition *option_defs_intl[RETRO_LANGUAGE_LAST] = {
|
||||||
NULL, /* RETRO_LANGUAGE_GREEK */
|
NULL, /* RETRO_LANGUAGE_GREEK */
|
||||||
NULL, /* RETRO_LANGUAGE_TURKISH */
|
NULL, /* RETRO_LANGUAGE_TURKISH */
|
||||||
};
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
********************************
|
********************************
|
||||||
|
@ -533,7 +521,8 @@ struct retro_core_option_definition *option_defs_intl[RETRO_LANGUAGE_LAST] = {
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* Handles configuration/setting of core options.
|
/* Handles configuration/setting of core options.
|
||||||
* Should only be called inside retro_set_environment().
|
* Should be called as early as possible - ideally inside
|
||||||
|
* retro_set_environment(), and no later than retro_load_game()
|
||||||
* > We place the function body in the header to avoid the
|
* > We place the function body in the header to avoid the
|
||||||
* necessity of adding more .c files (i.e. want this to
|
* necessity of adding more .c files (i.e. want this to
|
||||||
* be as painless as possible for core devs)
|
* be as painless as possible for core devs)
|
||||||
|
@ -546,8 +535,9 @@ static INLINE void libretro_set_core_options(retro_environment_t environ_cb)
|
||||||
if (!environ_cb)
|
if (!environ_cb)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (environ_cb(RETRO_ENVIRONMENT_GET_CORE_OPTIONS_VERSION, &version) && (version == 1))
|
if (environ_cb(RETRO_ENVIRONMENT_GET_CORE_OPTIONS_VERSION, &version) && (version >= 1))
|
||||||
{
|
{
|
||||||
|
#ifndef HAVE_NO_LANGEXTRA
|
||||||
struct retro_core_options_intl core_options_intl;
|
struct retro_core_options_intl core_options_intl;
|
||||||
unsigned language = 0;
|
unsigned language = 0;
|
||||||
|
|
||||||
|
@ -559,6 +549,9 @@ static INLINE void libretro_set_core_options(retro_environment_t environ_cb)
|
||||||
core_options_intl.local = option_defs_intl[language];
|
core_options_intl.local = option_defs_intl[language];
|
||||||
|
|
||||||
environ_cb(RETRO_ENVIRONMENT_SET_CORE_OPTIONS_INTL, &core_options_intl);
|
environ_cb(RETRO_ENVIRONMENT_SET_CORE_OPTIONS_INTL, &core_options_intl);
|
||||||
|
#else
|
||||||
|
environ_cb(RETRO_ENVIRONMENT_SET_CORE_OPTIONS, &option_defs_us);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -617,7 +610,7 @@ static INLINE void libretro_set_core_options(retro_environment_t environ_cb)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Build values string */
|
/* Build values string */
|
||||||
if (num_values > 1)
|
if (num_values > 0)
|
||||||
{
|
{
|
||||||
size_t j;
|
size_t j;
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,80 @@
|
||||||
|
#ifndef LIBRETRO_CORE_OPTIONS_INTL_H__
|
||||||
|
#define LIBRETRO_CORE_OPTIONS_INTL_H__
|
||||||
|
|
||||||
|
#if defined(_MSC_VER) && (_MSC_VER >= 1500 && _MSC_VER < 1900)
|
||||||
|
/* https://support.microsoft.com/en-us/kb/980263 */
|
||||||
|
#pragma execution_character_set("utf-8")
|
||||||
|
#pragma warning(disable:4566)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <libretro.h>
|
||||||
|
|
||||||
|
/*
|
||||||
|
********************************
|
||||||
|
* VERSION: 1.3
|
||||||
|
********************************
|
||||||
|
*
|
||||||
|
* - 1.3: Move translations to libretro_core_options_intl.h
|
||||||
|
* - libretro_core_options_intl.h includes BOM and utf-8
|
||||||
|
* fix for MSVC 2010-2013
|
||||||
|
* - Added HAVE_NO_LANGEXTRA flag to disable translations
|
||||||
|
* on platforms/compilers without BOM support
|
||||||
|
* - 1.2: Use core options v1 interface when
|
||||||
|
* RETRO_ENVIRONMENT_GET_CORE_OPTIONS_VERSION is >= 1
|
||||||
|
* (previously required RETRO_ENVIRONMENT_GET_CORE_OPTIONS_VERSION == 1)
|
||||||
|
* - 1.1: Support generation of core options v0 retro_core_option_value
|
||||||
|
* arrays containing options with a single value
|
||||||
|
* - 1.0: First commit
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
extern "C" {
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
********************************
|
||||||
|
* Core Option Definitions
|
||||||
|
********************************
|
||||||
|
*/
|
||||||
|
|
||||||
|
/* RETRO_LANGUAGE_JAPANESE */
|
||||||
|
|
||||||
|
/* RETRO_LANGUAGE_FRENCH */
|
||||||
|
|
||||||
|
/* RETRO_LANGUAGE_SPANISH */
|
||||||
|
|
||||||
|
/* RETRO_LANGUAGE_GERMAN */
|
||||||
|
|
||||||
|
/* RETRO_LANGUAGE_ITALIAN */
|
||||||
|
|
||||||
|
/* RETRO_LANGUAGE_DUTCH */
|
||||||
|
|
||||||
|
/* RETRO_LANGUAGE_PORTUGUESE_BRAZIL */
|
||||||
|
|
||||||
|
/* RETRO_LANGUAGE_PORTUGUESE_PORTUGAL */
|
||||||
|
|
||||||
|
/* RETRO_LANGUAGE_RUSSIAN */
|
||||||
|
|
||||||
|
/* RETRO_LANGUAGE_KOREAN */
|
||||||
|
|
||||||
|
/* RETRO_LANGUAGE_CHINESE_TRADITIONAL */
|
||||||
|
|
||||||
|
/* RETRO_LANGUAGE_CHINESE_SIMPLIFIED */
|
||||||
|
|
||||||
|
/* RETRO_LANGUAGE_ESPERANTO */
|
||||||
|
|
||||||
|
/* RETRO_LANGUAGE_POLISH */
|
||||||
|
|
||||||
|
/* RETRO_LANGUAGE_VIETNAMESE */
|
||||||
|
|
||||||
|
/* RETRO_LANGUAGE_ARABIC */
|
||||||
|
|
||||||
|
/* RETRO_LANGUAGE_GREEK */
|
||||||
|
|
||||||
|
/* RETRO_LANGUAGE_TURKISH */
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
Loading…
Reference in New Issue