/* 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 . */ #include #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 #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 (query[0] == '\0') 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_command(EVENT_CMD_CORE_INFO_INIT); else if (type_hash == CB_UPDATE_ASSETS) event_command(EVENT_CMD_REINIT); } 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; } 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 (!strcasecmp(file_ext, "zip")) { rarch_task_push_decompress(output_path, dir_path, NULL, NULL, cb_decompressed, (void*)(uintptr_t)transf->type_hash); } #else if (transf->type_hash == CB_CORE_UPDATER_DOWNLOAD) event_command(EVENT_CMD_CORE_INFO_INIT); #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); } #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_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; }