mirror of
https://github.com/CTCaer/RetroArch.git
synced 2025-01-10 04:51:32 +00:00
1017 lines
32 KiB
C
1017 lines
32 KiB
C
/* RetroArch - A frontend for libretro.
|
|
* Copyright (C) 2011-2016 - 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/>.
|
|
*/
|
|
|
|
#include <file/file_path.h>
|
|
#include <string/stdstring.h>
|
|
|
|
#include "../menu_driver.h"
|
|
#include "../menu_cbs.h"
|
|
#include "../../msg_hash.h"
|
|
|
|
#ifdef HAVE_LIBRETRODB
|
|
#include "../../database_info.h"
|
|
#endif
|
|
|
|
#include "../../cores/internal_cores.h"
|
|
|
|
#include "../../core_info.h"
|
|
#include "../../general.h"
|
|
#include "../../system.h"
|
|
#include "../../verbosity.h"
|
|
#include "../../tasks/tasks.h"
|
|
|
|
#define CB_CORE_UPDATER_DOWNLOAD 0x7412da7dU
|
|
#define CB_CORE_UPDATER_LIST 0x32fd4f01U
|
|
#define CB_UPDATE_ASSETS 0xbf85795eU
|
|
#define CB_UPDATE_CORE_INFO_FILES 0xe6084091U
|
|
#define CB_UPDATE_AUTOCONFIG_PROFILES 0x28ada67dU
|
|
#define CB_UPDATE_CHEATS 0xc360fec3U
|
|
#define CB_UPDATE_OVERLAYS 0x699009a0U
|
|
#define CB_UPDATE_DATABASES 0x931eb8d3U
|
|
#define CB_UPDATE_SHADERS_GLSL 0x0121a186U
|
|
#define CB_UPDATE_SHADERS_CG 0xc93a53feU
|
|
#define CB_CORE_CONTENT_LIST 0xebc51227U
|
|
#define CB_CORE_CONTENT_DOWNLOAD 0x03b3c0a3U
|
|
#define CB_LAKKA_DOWNLOAD 0x54eaa904U
|
|
|
|
#ifndef BIND_ACTION_DEFERRED_PUSH
|
|
#define BIND_ACTION_DEFERRED_PUSH(cbs, name) \
|
|
cbs->action_deferred_push = name; \
|
|
cbs->action_deferred_push_ident = #name;
|
|
#endif
|
|
|
|
static int deferred_push_dlist(menu_displaylist_info_t *info, unsigned val)
|
|
{
|
|
if (menu_displaylist_push_list(info, val) != 0)
|
|
return -1;
|
|
menu_displaylist_push_list_process(info);
|
|
return 0;
|
|
}
|
|
|
|
static int deferred_push_core_information(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_CORE_INFO);
|
|
}
|
|
|
|
static int deferred_push_system_information(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_SYSTEM_INFO);
|
|
}
|
|
|
|
static int deferred_push_debug_information(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_DEBUG_INFO);
|
|
}
|
|
|
|
static int deferred_push_achievement_list(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_ACHIEVEMENT_LIST);
|
|
}
|
|
|
|
static int deferred_push_rdb_collection(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_PLAYLIST_COLLECTION);
|
|
}
|
|
|
|
static int deferred_user_binds_list(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_USER_BINDS_LIST);
|
|
}
|
|
|
|
static int deferred_push_accounts_list(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_ACCOUNTS_LIST);
|
|
}
|
|
|
|
static int deferred_push_input_settings_list(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_INPUT_SETTINGS_LIST);
|
|
}
|
|
|
|
static int deferred_push_playlist_settings_list(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_PLAYLIST_SETTINGS_LIST);
|
|
}
|
|
|
|
static int deferred_push_input_hotkey_binds_list(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_INPUT_HOTKEY_BINDS_LIST);
|
|
}
|
|
|
|
static int deferred_push_accounts_cheevos_list(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_ACCOUNTS_CHEEVOS_LIST);
|
|
}
|
|
|
|
static int deferred_push_help(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_HELP_SCREEN_LIST);
|
|
}
|
|
|
|
static int deferred_push_rdb_entry_detail(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_DATABASE_ENTRY);
|
|
}
|
|
|
|
static int deferred_push_rpl_entry_actions(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_HORIZONTAL_CONTENT_ACTIONS);
|
|
}
|
|
|
|
static int deferred_push_core_list_deferred(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_CORES_SUPPORTED);
|
|
}
|
|
|
|
static int deferred_push_core_collection_list_deferred(
|
|
menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_CORES_COLLECTION_SUPPORTED);
|
|
}
|
|
|
|
static int deferred_push_database_manager_list_deferred(
|
|
menu_displaylist_info_t *info)
|
|
{
|
|
strlcpy(info->path_b, info->path, sizeof(info->path_b));
|
|
info->path_c[0] = '\0';
|
|
|
|
return deferred_push_dlist(info, DISPLAYLIST_DATABASE_QUERY);
|
|
}
|
|
|
|
static int deferred_push_cursor_manager_list_deferred(
|
|
menu_displaylist_info_t *info)
|
|
{
|
|
char rdb_path[PATH_MAX_LENGTH];
|
|
int ret = -1;
|
|
char *query = NULL;
|
|
char *rdb = NULL;
|
|
settings_t *settings = config_get_ptr();
|
|
config_file_t *conf = config_file_new(info->path);
|
|
|
|
if (!conf || !settings)
|
|
goto end;
|
|
|
|
if (!config_get_string(conf, "query", &query))
|
|
goto end;
|
|
|
|
if (!config_get_string(conf, "rdb", &rdb))
|
|
goto end;
|
|
|
|
fill_pathname_join(rdb_path, settings->content_database,
|
|
rdb, sizeof(rdb_path));
|
|
|
|
strlcpy(info->path_b, info->path, sizeof(info->path_b));
|
|
strlcpy(info->path, rdb_path, sizeof(info->path));
|
|
strlcpy(info->path_c, query, sizeof(info->path_c));
|
|
|
|
ret = deferred_push_dlist(info, DISPLAYLIST_DATABASE_QUERY);
|
|
|
|
end:
|
|
if (conf)
|
|
config_file_free(conf);
|
|
return ret;
|
|
}
|
|
|
|
static int deferred_push_cursor_manager_list_deferred_query_subsearch(
|
|
menu_displaylist_info_t *info)
|
|
{
|
|
int ret = -1;
|
|
#ifdef HAVE_LIBRETRODB
|
|
char query[PATH_MAX_LENGTH] = {0};
|
|
struct string_list *str_list = string_split(info->path, "|");
|
|
|
|
database_info_build_query(query, sizeof(query),
|
|
info->label, str_list->elems[0].data);
|
|
|
|
if (string_is_empty(query))
|
|
goto end;
|
|
|
|
strlcpy(info->path, str_list->elems[1].data, sizeof(info->path));
|
|
strlcpy(info->path_b, str_list->elems[0].data, sizeof(info->path_b));
|
|
strlcpy(info->path_c, query, sizeof(info->path_c));
|
|
|
|
ret = deferred_push_dlist(info, DISPLAYLIST_DATABASE_QUERY);
|
|
|
|
end:
|
|
if (str_list)
|
|
string_list_free(str_list);
|
|
#endif
|
|
return ret;
|
|
}
|
|
|
|
static int deferred_push_video_shader_preset_parameters(
|
|
menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_SHADER_PARAMETERS_PRESET);
|
|
}
|
|
|
|
static int deferred_push_video_shader_parameters(
|
|
menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_SHADER_PARAMETERS);
|
|
}
|
|
|
|
static int deferred_push_settings(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_SETTINGS_ALL);
|
|
}
|
|
|
|
static int deferred_push_category(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_SETTINGS);
|
|
}
|
|
|
|
static int deferred_push_shader_options(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_OPTIONS_SHADERS);
|
|
}
|
|
|
|
static int deferred_push_options(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_OPTIONS);
|
|
}
|
|
|
|
static int deferred_push_content_settings(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_CONTENT_SETTINGS);
|
|
}
|
|
|
|
static int deferred_push_add_content_list(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_ADD_CONTENT_LIST);
|
|
}
|
|
|
|
static int deferred_push_load_content_list(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_LOAD_CONTENT_LIST);
|
|
}
|
|
|
|
static int deferred_push_information_list(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_INFORMATION_LIST);
|
|
}
|
|
|
|
static int deferred_push_management_options(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_OPTIONS_MANAGEMENT);
|
|
}
|
|
|
|
static int deferred_push_core_counters(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_PERFCOUNTERS_CORE);
|
|
}
|
|
|
|
static int deferred_push_frontend_counters(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_PERFCOUNTERS_FRONTEND);
|
|
}
|
|
|
|
static int deferred_push_core_cheat_options(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_OPTIONS_CHEATS);
|
|
}
|
|
|
|
static int deferred_push_core_input_remapping_options(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_OPTIONS_REMAPPINGS);
|
|
}
|
|
|
|
static int deferred_push_core_options(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_CORE_OPTIONS);
|
|
}
|
|
|
|
static int deferred_push_disk_options(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_OPTIONS_DISK);
|
|
}
|
|
|
|
#ifdef HAVE_NETWORKING
|
|
/* HACK - we have to find some way to pass state inbetween
|
|
* function pointer callback functions that don't necessarily
|
|
* call each other. */
|
|
char *core_buf;
|
|
size_t core_len;
|
|
|
|
void cb_net_generic(void *task_data, void *user_data, const char *err)
|
|
{
|
|
bool refresh = false;
|
|
http_transfer_data_t *data = (http_transfer_data_t*)task_data;
|
|
|
|
if (core_buf)
|
|
free(core_buf);
|
|
|
|
core_buf = NULL;
|
|
core_len = 0;
|
|
|
|
if (!data || err)
|
|
goto finish;
|
|
|
|
core_buf = (char*)malloc((data->len+1) * sizeof(char));
|
|
|
|
if (!core_buf)
|
|
goto finish;
|
|
|
|
memcpy(core_buf, data->data, data->len * sizeof(char));
|
|
core_buf[data->len] = '\0';
|
|
core_len = data->len;
|
|
|
|
finish:
|
|
refresh = true;
|
|
menu_entries_ctl(MENU_ENTRIES_CTL_UNSET_REFRESH, &refresh);
|
|
|
|
if (err)
|
|
RARCH_ERR("Download failed: %s\n", err);
|
|
|
|
if (data)
|
|
{
|
|
if (data->data)
|
|
free(data->data);
|
|
free(data);
|
|
}
|
|
}
|
|
|
|
static void cb_decompressed(void *task_data, void *user_data, const char *err)
|
|
{
|
|
decompress_task_data_t *dec = (decompress_task_data_t*)task_data;
|
|
unsigned type_hash = (uintptr_t)user_data;
|
|
|
|
if (dec && !err)
|
|
{
|
|
if (type_hash == CB_CORE_UPDATER_DOWNLOAD)
|
|
event_cmd_ctl(EVENT_CMD_CORE_INFO_INIT, NULL);
|
|
else if (type_hash == CB_UPDATE_ASSETS)
|
|
event_cmd_ctl(EVENT_CMD_REINIT, NULL);
|
|
}
|
|
|
|
if (err)
|
|
RARCH_ERR("%s", err);
|
|
|
|
if (dec)
|
|
{
|
|
if (path_file_exists(dec->source_file))
|
|
remove(dec->source_file);
|
|
|
|
free(dec->source_file);
|
|
free(dec);
|
|
}
|
|
}
|
|
|
|
/* expects http_transfer_t*, menu_file_transfer_t* */
|
|
void cb_generic_download(void *task_data, void *user_data, const char *err)
|
|
#if 0
|
|
(void *data, size_t len, const char *dir_path)
|
|
#endif
|
|
{
|
|
char output_path[PATH_MAX_LENGTH];
|
|
char shaderdir[PATH_MAX_LENGTH];
|
|
const char *file_ext = NULL;
|
|
const char *dir_path = NULL;
|
|
menu_file_transfer_t *transf = (menu_file_transfer_t*)user_data;
|
|
settings_t *settings = config_get_ptr();
|
|
http_transfer_data_t *data = (http_transfer_data_t*)task_data;
|
|
|
|
if (!data || !data->data | !transf)
|
|
goto finish;
|
|
|
|
/* we have to determine dir_path at the time of writting or else
|
|
* we'd run into races when the user changes the setting during an
|
|
* http transfer. */
|
|
switch (transf->type_hash)
|
|
{
|
|
case CB_CORE_UPDATER_DOWNLOAD:
|
|
dir_path = settings->libretro_directory;
|
|
break;
|
|
case CB_CORE_CONTENT_DOWNLOAD:
|
|
dir_path = settings->core_assets_directory;
|
|
break;
|
|
case CB_UPDATE_CORE_INFO_FILES:
|
|
dir_path = settings->libretro_info_path;
|
|
break;
|
|
case CB_UPDATE_ASSETS:
|
|
dir_path = settings->assets_directory;
|
|
break;
|
|
case CB_UPDATE_AUTOCONFIG_PROFILES:
|
|
dir_path = settings->input.autoconfig_dir;
|
|
break;
|
|
case CB_UPDATE_DATABASES:
|
|
dir_path = settings->content_database;
|
|
break;
|
|
case CB_UPDATE_OVERLAYS:
|
|
dir_path = settings->overlay_directory;
|
|
break;
|
|
case CB_UPDATE_CHEATS:
|
|
dir_path = settings->cheat_database;
|
|
break;
|
|
case CB_UPDATE_SHADERS_CG:
|
|
case CB_UPDATE_SHADERS_GLSL:
|
|
{
|
|
const char *dirname = transf->type_hash == CB_UPDATE_SHADERS_CG ?
|
|
"shaders_cg" : "shaders_glsl";
|
|
|
|
fill_pathname_join(shaderdir, settings->video.shader_dir, dirname,
|
|
sizeof(shaderdir));
|
|
if (!path_file_exists(shaderdir))
|
|
if (!path_mkdir(shaderdir))
|
|
goto finish;
|
|
|
|
dir_path = shaderdir;
|
|
break;
|
|
}
|
|
case CB_LAKKA_DOWNLOAD:
|
|
dir_path = "/storage/.update/"; /* TODO unhardcode this ? */
|
|
break;
|
|
default:
|
|
RARCH_WARN("Unknown transfer type '%u' bailing out.\n",
|
|
transf->type_hash);
|
|
break;
|
|
}
|
|
|
|
fill_pathname_join(output_path, dir_path,
|
|
transf->path, sizeof(output_path));
|
|
|
|
/* Make sure the directory exists */
|
|
path_basedir(output_path);
|
|
if (!path_mkdir(output_path))
|
|
{
|
|
err = "Failed to create the directory.";
|
|
goto finish;
|
|
}
|
|
|
|
fill_pathname_join(output_path, dir_path,
|
|
transf->path, sizeof(output_path));
|
|
|
|
if (!retro_write_file(output_path, data->data, data->len))
|
|
{
|
|
err = "Write failed.";
|
|
goto finish;
|
|
}
|
|
|
|
#ifdef HAVE_ZLIB
|
|
file_ext = path_get_extension(output_path);
|
|
|
|
if (!settings->network.buildbot_auto_extract_archive)
|
|
goto finish;
|
|
|
|
if (string_is_equal_noncase(file_ext, "zip"))
|
|
{
|
|
rarch_task_push_decompress(output_path, dir_path, NULL, NULL, NULL,
|
|
cb_decompressed, (void*)(uintptr_t)transf->type_hash);
|
|
}
|
|
#else
|
|
if (transf->type_hash == CB_CORE_UPDATER_DOWNLOAD)
|
|
event_cmd_ctl(EVENT_CMD_CORE_INFO_INIT, NULL);
|
|
#endif
|
|
|
|
finish:
|
|
if (err)
|
|
{
|
|
RARCH_ERR("Download of '%s' failed: %s\n",
|
|
(transf ? transf->path: "unknown"), err);
|
|
}
|
|
|
|
if (data)
|
|
{
|
|
if (data->data)
|
|
free(data->data);
|
|
free(data);
|
|
}
|
|
|
|
if (transf)
|
|
free(transf);
|
|
}
|
|
|
|
static int deferred_push_core_updater_list(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_CORES_UPDATER);
|
|
}
|
|
|
|
static int deferred_push_core_content_list(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_CORE_CONTENT);
|
|
}
|
|
|
|
static int deferred_push_lakka_list(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_LAKKA);
|
|
}
|
|
|
|
#endif
|
|
|
|
static int deferred_archive_action_detect_core(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_ARCHIVE_ACTION_DETECT_CORE);
|
|
}
|
|
|
|
static int deferred_archive_action(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_ARCHIVE_ACTION);
|
|
}
|
|
|
|
enum
|
|
{
|
|
PUSH_ARCHIVE_OPEN_DETECT_CORE = 0,
|
|
PUSH_ARCHIVE_OPEN,
|
|
PUSH_DEFAULT,
|
|
PUSH_DETECT_CORE_LIST
|
|
};
|
|
|
|
|
|
static int general_push(menu_displaylist_info_t *info,
|
|
unsigned id, unsigned type)
|
|
{
|
|
struct retro_system_info *system_menu = NULL;
|
|
settings_t *settings = config_get_ptr();
|
|
rarch_system_info_t *system = NULL;
|
|
menu_handle_t *menu = menu_driver_get_ptr();
|
|
const char *exts = core_info_list_get_all_extensions();
|
|
|
|
menu_driver_ctl(RARCH_MENU_CTL_SYSTEM_INFO_GET, &system_menu);
|
|
runloop_ctl(RUNLOOP_CTL_SYSTEM_INFO_GET, &system);
|
|
|
|
switch (id)
|
|
{
|
|
case PUSH_DEFAULT:
|
|
case PUSH_DETECT_CORE_LIST:
|
|
break;
|
|
default:
|
|
fill_pathname_join(info->path, menu->scratch2_buf,
|
|
menu->scratch_buf, sizeof(info->path));
|
|
fill_pathname_join(info->label, menu->scratch2_buf,
|
|
menu->scratch_buf, sizeof(info->label));
|
|
break;
|
|
}
|
|
|
|
info->type_default = MENU_FILE_PLAIN;
|
|
|
|
switch (id)
|
|
{
|
|
case PUSH_ARCHIVE_OPEN_DETECT_CORE:
|
|
info->setting = menu_setting_find(info->label);
|
|
|
|
if (exts)
|
|
strlcpy(info->exts, exts, sizeof(info->exts));
|
|
else if (system_menu->valid_extensions)
|
|
{
|
|
if (*system_menu->valid_extensions)
|
|
strlcpy(info->exts, system_menu->valid_extensions,
|
|
sizeof(info->exts));
|
|
}
|
|
else
|
|
strlcpy(info->exts, system->valid_extensions, sizeof(info->exts));
|
|
break;
|
|
case PUSH_ARCHIVE_OPEN:
|
|
info->setting = menu_setting_find(info->label);
|
|
if (system_menu->valid_extensions)
|
|
{
|
|
if (*system_menu->valid_extensions)
|
|
strlcpy(info->exts, system_menu->valid_extensions,
|
|
sizeof(info->exts));
|
|
}
|
|
else
|
|
strlcpy(info->exts, system->valid_extensions, sizeof(info->exts));
|
|
break;
|
|
case PUSH_DEFAULT:
|
|
info->setting = menu_setting_find(info->label);
|
|
if (menu_setting_get_browser_selection_type(info->setting) == ST_DIR)
|
|
{
|
|
}
|
|
else if (system_menu->valid_extensions)
|
|
{
|
|
if (*system_menu->valid_extensions)
|
|
strlcpy(info->exts, system_menu->valid_extensions,
|
|
sizeof(info->exts));
|
|
}
|
|
else
|
|
strlcpy(info->exts, system->valid_extensions, sizeof(info->exts));
|
|
break;
|
|
case PUSH_DETECT_CORE_LIST:
|
|
if (exts)
|
|
strlcpy(info->exts, exts, sizeof(info->exts));
|
|
break;
|
|
}
|
|
|
|
(void)settings;
|
|
|
|
if (settings->multimedia.builtin_mediaplayer_enable ||
|
|
settings->multimedia.builtin_imageviewer_enable)
|
|
{
|
|
struct retro_system_info sysinfo = {0};
|
|
|
|
(void)sysinfo;
|
|
#ifdef HAVE_FFMPEG
|
|
if (settings->multimedia.builtin_mediaplayer_enable)
|
|
{
|
|
libretro_ffmpeg_retro_get_system_info(&sysinfo);
|
|
strlcat(info->exts, "|", sizeof(info->exts));
|
|
strlcat(info->exts, sysinfo.valid_extensions, sizeof(info->exts));
|
|
}
|
|
#endif
|
|
#ifdef HAVE_IMAGEVIEWER
|
|
if (settings->multimedia.builtin_imageviewer_enable)
|
|
{
|
|
libretro_imageviewer_retro_get_system_info(&sysinfo);
|
|
strlcat(info->exts, "|", sizeof(info->exts));
|
|
strlcat(info->exts, sysinfo.valid_extensions, sizeof(info->exts));
|
|
}
|
|
#endif
|
|
}
|
|
|
|
return deferred_push_dlist(info, type);
|
|
}
|
|
|
|
static int deferred_push_detect_core_list(menu_displaylist_info_t *info)
|
|
{
|
|
return general_push(info, PUSH_DETECT_CORE_LIST,
|
|
DISPLAYLIST_CORES_DETECTED);
|
|
}
|
|
|
|
static int deferred_archive_open_detect_core(menu_displaylist_info_t *info)
|
|
{
|
|
return general_push(info, PUSH_ARCHIVE_OPEN_DETECT_CORE,
|
|
DISPLAYLIST_DEFAULT);
|
|
}
|
|
|
|
static int deferred_archive_open(menu_displaylist_info_t *info)
|
|
{
|
|
return general_push(info, PUSH_ARCHIVE_OPEN, DISPLAYLIST_DEFAULT);
|
|
}
|
|
|
|
static int deferred_push_default(menu_displaylist_info_t *info)
|
|
{
|
|
return general_push(info, PUSH_DEFAULT, DISPLAYLIST_DEFAULT);
|
|
}
|
|
|
|
static int deferred_push_history_list(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_HISTORY);
|
|
}
|
|
|
|
int deferred_push_content_list(void *data, void *userdata, const char *path,
|
|
const char *label, unsigned type)
|
|
{
|
|
file_list_t *selection_buf = menu_entries_get_selection_buf_ptr(0);
|
|
return action_refresh_default((file_list_t*)data, selection_buf);
|
|
}
|
|
|
|
static int deferred_push_database_manager_list(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_DATABASES);
|
|
}
|
|
|
|
static int deferred_push_cursor_manager_list(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_DATABASE_CURSORS);
|
|
}
|
|
|
|
static int deferred_push_content_collection_list(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_DATABASE_PLAYLISTS);
|
|
}
|
|
|
|
static int deferred_push_core_list(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_CORES);
|
|
}
|
|
|
|
static int deferred_push_configurations(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_CONFIG_FILES);
|
|
}
|
|
|
|
static int deferred_push_video_shader_preset(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_SHADER_PRESET);
|
|
}
|
|
|
|
static int deferred_push_video_shader_pass(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_SHADER_PASS);
|
|
}
|
|
|
|
static int deferred_push_video_filter(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_VIDEO_FILTERS);
|
|
}
|
|
|
|
static int deferred_push_images(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_IMAGES);
|
|
}
|
|
|
|
static int deferred_push_audio_dsp_plugin(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_AUDIO_FILTERS);
|
|
}
|
|
|
|
static int deferred_push_cheat_file_load(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_CHEAT_FILES);
|
|
}
|
|
|
|
static int deferred_push_remap_file_load(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_REMAP_FILES);
|
|
}
|
|
|
|
static int deferred_push_record_configfile(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_RECORD_CONFIG_FILES);
|
|
}
|
|
|
|
static int deferred_push_input_overlay(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_OVERLAYS);
|
|
}
|
|
|
|
static int deferred_push_input_osk_overlay(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_OVERLAYS);
|
|
}
|
|
|
|
static int deferred_push_video_font_path(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_FONTS);
|
|
}
|
|
|
|
static int deferred_push_content_history_path(menu_displaylist_info_t *info)
|
|
{
|
|
return deferred_push_dlist(info, DISPLAYLIST_CONTENT_HISTORY);
|
|
}
|
|
|
|
static int menu_cbs_init_bind_deferred_push_compare_label(
|
|
menu_file_list_cbs_t *cbs,
|
|
const char *label, uint32_t label_hash)
|
|
{
|
|
if (strstr(label, menu_hash_to_str(MENU_LABEL_DEFERRED_RDB_ENTRY_DETAIL)))
|
|
{
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_rdb_entry_detail);
|
|
}
|
|
else if (strstr(label,
|
|
menu_hash_to_str(MENU_LABEL_DEFERRED_RPL_ENTRY_ACTIONS)))
|
|
{
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_rpl_entry_actions);
|
|
}
|
|
else
|
|
{
|
|
switch (label_hash)
|
|
{
|
|
case MENU_LABEL_DEFERRED_USER_BINDS_LIST:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_user_binds_list);
|
|
break;
|
|
case MENU_LABEL_DEFERRED_ACCOUNTS_LIST:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_accounts_list);
|
|
break;
|
|
case MENU_LABEL_DEFERRED_INPUT_SETTINGS_LIST:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_input_settings_list);
|
|
break;
|
|
case MENU_LABEL_DEFERRED_PLAYLIST_SETTINGS_LIST:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_playlist_settings_list);
|
|
break;
|
|
case MENU_LABEL_DEFERRED_INPUT_HOTKEY_BINDS_LIST:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_input_hotkey_binds_list);
|
|
break;
|
|
case MENU_LABEL_DEFERRED_ACCOUNTS_CHEEVOS_LIST:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_accounts_cheevos_list);
|
|
break;
|
|
case MENU_LABEL_DEFERRED_ARCHIVE_ACTION_DETECT_CORE:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_archive_action_detect_core);
|
|
break;
|
|
case MENU_LABEL_DEFERRED_ARCHIVE_ACTION:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_archive_action);
|
|
break;
|
|
case MENU_LABEL_DEFERRED_ARCHIVE_OPEN_DETECT_CORE:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_archive_open_detect_core);
|
|
break;
|
|
case MENU_LABEL_DEFERRED_ARCHIVE_OPEN:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_archive_open);
|
|
break;
|
|
case MENU_LABEL_DEFERRED_CORE_CONTENT_LIST:
|
|
#ifdef HAVE_NETWORKING
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_core_content_list);
|
|
#endif
|
|
break;
|
|
case MENU_LABEL_DEFERRED_CORE_UPDATER_LIST:
|
|
#ifdef HAVE_NETWORKING
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_core_updater_list);
|
|
#endif
|
|
break;
|
|
case MENU_LABEL_DEFERRED_LAKKA_LIST:
|
|
#ifdef HAVE_NETWORKING
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_lakka_list);
|
|
#endif
|
|
break;
|
|
case MENU_LABEL_LOAD_CONTENT_HISTORY:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_history_list);
|
|
break;
|
|
case MENU_LABEL_DATABASE_MANAGER_LIST:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_database_manager_list);
|
|
break;
|
|
case MENU_LABEL_CURSOR_MANAGER_LIST:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_cursor_manager_list);
|
|
break;
|
|
case MENU_LABEL_CHEAT_FILE_LOAD:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_cheat_file_load);
|
|
break;
|
|
case MENU_LABEL_REMAP_FILE_LOAD:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_remap_file_load);
|
|
break;
|
|
case MENU_LABEL_RECORD_CONFIG:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_record_configfile);
|
|
break;
|
|
case MENU_LABEL_SHADER_OPTIONS:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_shader_options);
|
|
break;
|
|
case MENU_LABEL_ONLINE_UPDATER:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_options);
|
|
break;
|
|
case MENU_LABEL_CONTENT_SETTINGS:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_content_settings);
|
|
break;
|
|
case MENU_LABEL_ADD_CONTENT_LIST:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_add_content_list);
|
|
break;
|
|
case MENU_LABEL_LOAD_CONTENT_LIST:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_load_content_list);
|
|
break;
|
|
case MENU_LABEL_INFORMATION_LIST:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_information_list);
|
|
break;
|
|
case MENU_LABEL_MANAGEMENT:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_management_options);
|
|
break;
|
|
case MENU_LABEL_HELP_LIST:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_help);
|
|
break;
|
|
case MENU_LABEL_DEFERRED_CORE_LIST:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_core_list_deferred);
|
|
break;
|
|
case MENU_LABEL_DEFERRED_CORE_LIST_SET:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_core_collection_list_deferred);
|
|
break;
|
|
case MENU_LABEL_DEFERRED_VIDEO_FILTER:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_video_filter);
|
|
break;
|
|
case MENU_LABEL_DEFERRED_DATABASE_MANAGER_LIST:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_database_manager_list_deferred);
|
|
break;
|
|
case MENU_LABEL_DEFERRED_CURSOR_MANAGER_LIST:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_cursor_manager_list_deferred);
|
|
break;
|
|
case MENU_LABEL_DEFERRED_CURSOR_MANAGER_LIST_RDB_ENTRY_PUBLISHER:
|
|
case MENU_LABEL_DEFERRED_CURSOR_MANAGER_LIST_RDB_ENTRY_DEVELOPER:
|
|
case MENU_LABEL_DEFERRED_CURSOR_MANAGER_LIST_RDB_ENTRY_ORIGIN:
|
|
case MENU_LABEL_DEFERRED_CURSOR_MANAGER_LIST_RDB_ENTRY_FRANCHISE:
|
|
case MENU_LABEL_DEFERRED_CURSOR_MANAGER_LIST_RDB_ENTRY_ENHANCEMENT_HW:
|
|
case MENU_LABEL_DEFERRED_CURSOR_MANAGER_LIST_RDB_ENTRY_ESRB_RATING:
|
|
case MENU_LABEL_DEFERRED_CURSOR_MANAGER_LIST_RDB_ENTRY_BBFC_RATING:
|
|
case MENU_LABEL_DEFERRED_CURSOR_MANAGER_LIST_RDB_ENTRY_ELSPA_RATING:
|
|
case MENU_LABEL_DEFERRED_CURSOR_MANAGER_LIST_RDB_ENTRY_PEGI_RATING:
|
|
case MENU_LABEL_DEFERRED_CURSOR_MANAGER_LIST_RDB_ENTRY_CERO_RATING:
|
|
case MENU_LABEL_DEFERRED_CURSOR_MANAGER_LIST_RDB_ENTRY_EDGE_MAGAZINE_RATING:
|
|
case MENU_LABEL_DEFERRED_CURSOR_MANAGER_LIST_RDB_ENTRY_EDGE_MAGAZINE_ISSUE:
|
|
case MENU_LABEL_DEFERRED_CURSOR_MANAGER_LIST_RDB_ENTRY_FAMITSU_MAGAZINE_RATING:
|
|
case MENU_LABEL_DEFERRED_CURSOR_MANAGER_LIST_RDB_ENTRY_MAX_USERS:
|
|
case MENU_LABEL_DEFERRED_CURSOR_MANAGER_LIST_RDB_ENTRY_RELEASEMONTH:
|
|
case MENU_LABEL_DEFERRED_CURSOR_MANAGER_LIST_RDB_ENTRY_RELEASEYEAR:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_cursor_manager_list_deferred_query_subsearch);
|
|
break;
|
|
case MENU_LABEL_CORE_INFORMATION:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_core_information);
|
|
break;
|
|
case MENU_LABEL_SYSTEM_INFORMATION:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_system_information);
|
|
break;
|
|
case MENU_LABEL_DEBUG_INFORMATION:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_debug_information);
|
|
break;
|
|
case MENU_LABEL_ACHIEVEMENT_LIST:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_achievement_list);
|
|
break;
|
|
case MENU_LABEL_CORE_COUNTERS:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_core_counters);
|
|
break;
|
|
case MENU_LABEL_FRONTEND_COUNTERS:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_frontend_counters);
|
|
break;
|
|
case MENU_LABEL_VIDEO_SHADER_PRESET_PARAMETERS:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_video_shader_preset_parameters);
|
|
break;
|
|
case MENU_LABEL_VIDEO_SHADER_PARAMETERS:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_video_shader_parameters);
|
|
break;
|
|
case MENU_LABEL_SETTINGS:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_settings);
|
|
break;
|
|
case MENU_LABEL_CORE_OPTIONS:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_core_options);
|
|
break;
|
|
case MENU_LABEL_CORE_CHEAT_OPTIONS:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_core_cheat_options);
|
|
break;
|
|
case MENU_LABEL_CORE_INPUT_REMAPPING_OPTIONS:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_core_input_remapping_options);
|
|
break;
|
|
case MENU_LABEL_CORE_LIST:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_core_list);
|
|
break;
|
|
case MENU_LABEL_CONTENT_COLLECTION_LIST:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_content_collection_list);
|
|
break;
|
|
case MENU_LABEL_CONFIGURATIONS:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_configurations);
|
|
break;
|
|
case MENU_LABEL_VIDEO_SHADER_PRESET:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_video_shader_preset);
|
|
break;
|
|
case MENU_LABEL_VIDEO_SHADER_PASS:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_video_shader_pass);
|
|
break;
|
|
case MENU_LABEL_VIDEO_FILTER:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_video_filter);
|
|
break;
|
|
case MENU_LABEL_MENU_WALLPAPER:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_images);
|
|
break;
|
|
case MENU_LABEL_AUDIO_DSP_PLUGIN:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_audio_dsp_plugin);
|
|
break;
|
|
case MENU_LABEL_INPUT_OVERLAY:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_input_overlay);
|
|
break;
|
|
case MENU_LABEL_INPUT_OSK_OVERLAY:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_input_osk_overlay);
|
|
break;
|
|
case MENU_LABEL_VIDEO_FONT_PATH:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_video_font_path);
|
|
break;
|
|
case MENU_LABEL_CONTENT_HISTORY_PATH:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_content_history_path);
|
|
break;
|
|
case MENU_LABEL_DOWNLOADED_FILE_DETECT_CORE_LIST:
|
|
case MENU_LABEL_DETECT_CORE_LIST:
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_detect_core_list);
|
|
break;
|
|
default:
|
|
return -1;
|
|
}
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
static int menu_cbs_init_bind_deferred_push_compare_type(
|
|
menu_file_list_cbs_t *cbs, unsigned type,
|
|
uint32_t label_hash)
|
|
{
|
|
if (type == MENU_SETTING_GROUP)
|
|
{
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_category);
|
|
}
|
|
else if (type == MENU_FILE_PLAYLIST_COLLECTION)
|
|
{
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_rdb_collection);
|
|
}
|
|
else if (type == MENU_SETTING_ACTION_CORE_DISK_OPTIONS)
|
|
{
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_disk_options);
|
|
}
|
|
else
|
|
return -1;
|
|
|
|
return 0;
|
|
}
|
|
|
|
int menu_cbs_init_bind_deferred_push(menu_file_list_cbs_t *cbs,
|
|
const char *path, const char *label, unsigned type, size_t idx,
|
|
const char *elem0, const char *elem1,
|
|
uint32_t label_hash, uint32_t menu_label_hash)
|
|
{
|
|
if (!cbs)
|
|
return -1;
|
|
|
|
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_default);
|
|
|
|
if (menu_cbs_init_bind_deferred_push_compare_label(
|
|
cbs, label, label_hash) == 0)
|
|
return 0;
|
|
|
|
if (menu_cbs_init_bind_deferred_push_compare_type(
|
|
cbs, type, label_hash) == 0)
|
|
return 0;
|
|
|
|
return -1;
|
|
}
|