mirror of
https://github.com/libretro/RetroArch
synced 2025-02-27 18:41:01 +00:00
Refactor "Frame Throttle" and "Rewind" settings lists
This commit is contained in:
parent
1b76f42b00
commit
84d9a58ec8
@ -1286,6 +1286,10 @@ static const char *menu_hash_to_str_us_label_enum(enum msg_hash_enums msg)
|
||||
return "deferred_saving_settings_list";
|
||||
case MENU_ENUM_LABEL_DEFERRED_LOGGING_SETTINGS_LIST:
|
||||
return "deferred_logging_settings_list";
|
||||
case MENU_ENUM_LABEL_DEFERRED_FRAME_THROTTLE_SETTINGS_LIST:
|
||||
return "deferred_frame_throttle_settings_list";
|
||||
case MENU_ENUM_LABEL_DEFERRED_REWIND_SETTINGS_LIST:
|
||||
return "deferred_rewind_settings_list";
|
||||
case MENU_ENUM_LABEL_ACCOUNTS_LIST:
|
||||
return "accounts_list";
|
||||
case MENU_ENUM_LABEL_DEFERRED_INPUT_HOTKEY_BINDS_LIST:
|
||||
@ -1314,6 +1318,10 @@ static const char *menu_hash_to_str_us_label_enum(enum msg_hash_enums msg)
|
||||
return "saving_settings";
|
||||
case MENU_ENUM_LABEL_LOGGING_SETTINGS:
|
||||
return "logging_settings";
|
||||
case MENU_ENUM_LABEL_FRAME_THROTTLE_SETTINGS:
|
||||
return "frame_throttle_settings";
|
||||
case MENU_ENUM_LABEL_REWIND_SETTINGS:
|
||||
return "rewind_settings";
|
||||
case MENU_ENUM_LABEL_AUDIO_SETTINGS:
|
||||
return "audio_settings";
|
||||
case MENU_ENUM_LABEL_DEBUG_PANEL_ENABLE:
|
||||
|
@ -129,6 +129,16 @@ static int deferred_push_logging_settings_list(menu_displaylist_info_t *info)
|
||||
return deferred_push_dlist(info, DISPLAYLIST_LOGGING_SETTINGS_LIST);
|
||||
}
|
||||
|
||||
static int deferred_push_frame_throttle_settings_list(menu_displaylist_info_t *info)
|
||||
{
|
||||
return deferred_push_dlist(info, DISPLAYLIST_FRAME_THROTTLE_SETTINGS_LIST);
|
||||
}
|
||||
|
||||
static int deferred_push_rewind_settings_list(menu_displaylist_info_t *info)
|
||||
{
|
||||
return deferred_push_dlist(info, DISPLAYLIST_REWIND_SETTINGS_LIST);
|
||||
}
|
||||
|
||||
static int deferred_push_audio_settings_list(menu_displaylist_info_t *info)
|
||||
{
|
||||
return deferred_push_dlist(info, DISPLAYLIST_AUDIO_SETTINGS_LIST);
|
||||
@ -637,6 +647,16 @@ static int menu_cbs_init_bind_deferred_push_compare_label(
|
||||
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_logging_settings_list);
|
||||
return 0;
|
||||
}
|
||||
else if (string_is_equal(label, msg_hash_to_str(MENU_ENUM_LABEL_DEFERRED_FRAME_THROTTLE_SETTINGS_LIST)))
|
||||
{
|
||||
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_frame_throttle_settings_list);
|
||||
return 0;
|
||||
}
|
||||
else if (string_is_equal(label, msg_hash_to_str(MENU_ENUM_LABEL_DEFERRED_REWIND_SETTINGS_LIST)))
|
||||
{
|
||||
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_rewind_settings_list);
|
||||
return 0;
|
||||
}
|
||||
else if (string_is_equal(label, msg_hash_to_str(MENU_ENUM_LABEL_DEFERRED_CORE_CONTENT_DIRS_LIST)))
|
||||
{
|
||||
#ifdef HAVE_NETWORKING
|
||||
@ -883,6 +903,12 @@ static int menu_cbs_init_bind_deferred_push_compare_label(
|
||||
case MENU_ENUM_LABEL_DEFERRED_LOGGING_SETTINGS_LIST:
|
||||
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_saving_settings_list);
|
||||
break;
|
||||
case MENU_ENUM_LABEL_DEFERRED_FRAME_THROTTLE_SETTINGS_LIST:
|
||||
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_frame_throttle_settings_list);
|
||||
break;
|
||||
case MENU_ENUM_LABEL_DEFERRED_REWIND_SETTINGS_LIST:
|
||||
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_rewind_settings_list);
|
||||
break;
|
||||
case MENU_ENUM_LABEL_DEFERRED_AUDIO_SETTINGS_LIST:
|
||||
BIND_ACTION_DEFERRED_PUSH(cbs, deferred_push_audio_settings_list);
|
||||
break;
|
||||
|
@ -486,6 +486,20 @@ int generic_action_ok_displaylist_push(const char *path,
|
||||
info_label = msg_hash_to_str(MENU_ENUM_LABEL_DEFERRED_LOGGING_SETTINGS_LIST);
|
||||
info.enum_idx = MENU_ENUM_LABEL_DEFERRED_LOGGING_SETTINGS_LIST;
|
||||
break;
|
||||
case ACTION_OK_DL_FRAME_THROTTLE_SETTINGS_LIST:
|
||||
info.directory_ptr = idx;
|
||||
info.type = type;
|
||||
info_path = path;
|
||||
info_label = msg_hash_to_str(MENU_ENUM_LABEL_DEFERRED_FRAME_THROTTLE_SETTINGS_LIST);
|
||||
info.enum_idx = MENU_ENUM_LABEL_DEFERRED_FRAME_THROTTLE_SETTINGS_LIST;
|
||||
break;
|
||||
case ACTION_OK_DL_REWIND_SETTINGS_LIST:
|
||||
info.directory_ptr = idx;
|
||||
info.type = type;
|
||||
info_path = path;
|
||||
info_label = msg_hash_to_str(MENU_ENUM_LABEL_DEFERRED_REWIND_SETTINGS_LIST);
|
||||
info.enum_idx = MENU_ENUM_LABEL_DEFERRED_REWIND_SETTINGS_LIST;
|
||||
break;
|
||||
case ACTION_OK_DL_AUDIO_SETTINGS_LIST:
|
||||
info.directory_ptr = idx;
|
||||
info.type = type;
|
||||
@ -2338,6 +2352,20 @@ static int action_ok_logging_list(const char *path,
|
||||
entry_idx, ACTION_OK_DL_LOGGING_SETTINGS_LIST);
|
||||
}
|
||||
|
||||
static int action_ok_frame_throttle_list(const char *path,
|
||||
const char *label, unsigned type, size_t idx, size_t entry_idx)
|
||||
{
|
||||
return generic_action_ok_displaylist_push(path, label, type, idx,
|
||||
entry_idx, ACTION_OK_DL_FRAME_THROTTLE_SETTINGS_LIST);
|
||||
}
|
||||
|
||||
static int action_ok_rewind_list(const char *path,
|
||||
const char *label, unsigned type, size_t idx, size_t entry_idx)
|
||||
{
|
||||
return generic_action_ok_displaylist_push(path, label, type, idx,
|
||||
entry_idx, ACTION_OK_DL_REWIND_SETTINGS_LIST);
|
||||
}
|
||||
|
||||
static int action_ok_rdb_entry(const char *path,
|
||||
const char *label, unsigned type, size_t idx, size_t entry_idx)
|
||||
{
|
||||
@ -2980,6 +3008,12 @@ static int menu_cbs_init_bind_ok_compare_label(menu_file_list_cbs_t *cbs,
|
||||
case MENU_ENUM_LABEL_LOGGING_SETTINGS:
|
||||
BIND_ACTION_OK(cbs, action_ok_logging_list);
|
||||
break;
|
||||
case MENU_ENUM_LABEL_FRAME_THROTTLE_SETTINGS:
|
||||
BIND_ACTION_OK(cbs, action_ok_frame_throttle_list);
|
||||
break;
|
||||
case MENU_ENUM_LABEL_REWIND_SETTINGS:
|
||||
BIND_ACTION_OK(cbs, action_ok_rewind_list);
|
||||
break;
|
||||
case MENU_ENUM_LABEL_SCREEN_RESOLUTION:
|
||||
BIND_ACTION_OK(cbs, action_ok_video_resolution);
|
||||
break;
|
||||
|
@ -221,6 +221,20 @@ static int action_get_logging_settings_list(const char *path, const char *label,
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int action_get_frame_throttle_settings_list(const char *path, const char *label,
|
||||
unsigned menu_type, char *s, size_t len)
|
||||
{
|
||||
sanitize_to_string(s, msg_hash_to_str(MENU_ENUM_LABEL_VALUE_FRAME_THROTTLE_SETTINGS), len);
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int action_get_rewind_settings_list(const char *path, const char *label,
|
||||
unsigned menu_type, char *s, size_t len)
|
||||
{
|
||||
sanitize_to_string(s, msg_hash_to_str(MENU_ENUM_LABEL_VALUE_REWIND_SETTINGS), len);
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int action_get_audio_settings_list(const char *path, const char *label,
|
||||
unsigned menu_type, char *s, size_t len)
|
||||
{
|
||||
@ -789,6 +803,18 @@ static int menu_cbs_init_bind_title_compare_label(menu_file_list_cbs_t *cbs,
|
||||
return 0;
|
||||
}
|
||||
|
||||
if (string_is_equal(label, msg_hash_to_str(MENU_ENUM_LABEL_DEFERRED_FRAME_THROTTLE_SETTINGS_LIST)))
|
||||
{
|
||||
BIND_ACTION_GET_TITLE(cbs, action_get_frame_throttle_settings_list);
|
||||
return 0;
|
||||
}
|
||||
|
||||
if (string_is_equal(label, msg_hash_to_str(MENU_ENUM_LABEL_DEFERRED_REWIND_SETTINGS_LIST)))
|
||||
{
|
||||
BIND_ACTION_GET_TITLE(cbs, action_get_rewind_settings_list);
|
||||
return 0;
|
||||
}
|
||||
|
||||
if (string_is_equal(label, msg_hash_to_str(MENU_ENUM_LABEL_DEFERRED_CORE_CONTENT_DIRS_LIST)))
|
||||
{
|
||||
BIND_ACTION_GET_TITLE(cbs, action_get_download_core_content_list);
|
||||
@ -1012,6 +1038,12 @@ static int menu_cbs_init_bind_title_compare_label(menu_file_list_cbs_t *cbs,
|
||||
case MENU_ENUM_LABEL_DEFERRED_SAVING_SETTINGS_LIST:
|
||||
BIND_ACTION_GET_TITLE(cbs, action_get_saving_settings_list);
|
||||
break;
|
||||
case MENU_ENUM_LABEL_DEFERRED_FRAME_THROTTLE_SETTINGS_LIST:
|
||||
BIND_ACTION_GET_TITLE(cbs, action_get_frame_throttle_settings_list);
|
||||
break;
|
||||
case MENU_ENUM_LABEL_DEFERRED_REWIND_SETTINGS_LIST:
|
||||
BIND_ACTION_GET_TITLE(cbs, action_get_rewind_settings_list);
|
||||
break;
|
||||
case MENU_ENUM_LABEL_DEFERRED_CORE_SETTINGS_LIST:
|
||||
BIND_ACTION_GET_TITLE(cbs, action_get_core_settings_list);
|
||||
break;
|
||||
|
@ -45,6 +45,8 @@ enum
|
||||
ACTION_OK_DL_CONFIGURATION_SETTINGS_LIST,
|
||||
ACTION_OK_DL_SAVING_SETTINGS_LIST,
|
||||
ACTION_OK_DL_LOGGING_SETTINGS_LIST,
|
||||
ACTION_OK_DL_FRAME_THROTTLE_SETTINGS_LIST,
|
||||
ACTION_OK_DL_REWIND_SETTINGS_LIST,
|
||||
ACTION_OK_DL_CORE_SETTINGS_LIST,
|
||||
ACTION_OK_DL_INPUT_HOTKEY_BINDS_LIST,
|
||||
ACTION_OK_DL_PLAYLIST_SETTINGS_LIST,
|
||||
|
@ -3740,6 +3740,8 @@ bool menu_displaylist_ctl(enum menu_displaylist_ctl_state type, void *data)
|
||||
case DISPLAYLIST_CONFIGURATION_SETTINGS_LIST:
|
||||
case DISPLAYLIST_LOGGING_SETTINGS_LIST:
|
||||
case DISPLAYLIST_SAVING_SETTINGS_LIST:
|
||||
case DISPLAYLIST_FRAME_THROTTLE_SETTINGS_LIST:
|
||||
case DISPLAYLIST_REWIND_SETTINGS_LIST:
|
||||
case DISPLAYLIST_AUDIO_SETTINGS_LIST:
|
||||
case DISPLAYLIST_CORE_SETTINGS_LIST:
|
||||
case DISPLAYLIST_INPUT_SETTINGS_LIST:
|
||||
@ -4105,6 +4107,31 @@ bool menu_displaylist_ctl(enum menu_displaylist_ctl_state type, void *data)
|
||||
MENU_ENUM_LABEL_PERFCNT_ENABLE,
|
||||
PARSE_ONLY_BOOL, false);
|
||||
|
||||
info->need_refresh = true;
|
||||
info->need_push = true;
|
||||
break;
|
||||
case DISPLAYLIST_FRAME_THROTTLE_SETTINGS_LIST:
|
||||
menu_displaylist_parse_settings_enum(menu, info,
|
||||
MENU_ENUM_LABEL_FASTFORWARD_RATIO,
|
||||
PARSE_ONLY_FLOAT, false);
|
||||
menu_displaylist_parse_settings_enum(menu, info,
|
||||
MENU_ENUM_LABEL_SLOWMOTION_RATIO,
|
||||
PARSE_ONLY_FLOAT, false);
|
||||
menu_displaylist_parse_settings_enum(menu, info,
|
||||
MENU_ENUM_LABEL_MENU_THROTTLE_FRAMERATE,
|
||||
PARSE_ONLY_BOOL, false);
|
||||
|
||||
info->need_refresh = true;
|
||||
info->need_push = true;
|
||||
break;
|
||||
case DISPLAYLIST_REWIND_SETTINGS_LIST:
|
||||
menu_displaylist_parse_settings_enum(menu, info,
|
||||
MENU_ENUM_LABEL_REWIND_ENABLE,
|
||||
PARSE_ONLY_BOOL, false);
|
||||
menu_displaylist_parse_settings_enum(menu, info,
|
||||
MENU_ENUM_LABEL_REWIND_GRANULARITY,
|
||||
PARSE_ONLY_UINT, false);
|
||||
|
||||
info->need_refresh = true;
|
||||
info->need_push = true;
|
||||
break;
|
||||
@ -4352,10 +4379,10 @@ bool menu_displaylist_ctl(enum menu_displaylist_ctl_state type, void *data)
|
||||
MENU_ENUM_LABEL_SAVING_SETTINGS, PARSE_ACTION, false);
|
||||
ret = menu_displaylist_parse_settings_enum(menu, info,
|
||||
MENU_ENUM_LABEL_LOGGING_SETTINGS, PARSE_ACTION, false);
|
||||
ret = menu_displaylist_parse_settings(menu, info,
|
||||
msg_hash_to_str(MENU_ENUM_LABEL_VALUE_FRAME_THROTTLE_SETTINGS), PARSE_ONLY_GROUP, false);
|
||||
ret = menu_displaylist_parse_settings(menu, info,
|
||||
msg_hash_to_str(MENU_ENUM_LABEL_VALUE_REWIND_SETTINGS), PARSE_ONLY_GROUP, false);
|
||||
ret = menu_displaylist_parse_settings_enum(menu, info,
|
||||
MENU_ENUM_LABEL_FRAME_THROTTLE_SETTINGS, PARSE_ACTION, false);
|
||||
ret = menu_displaylist_parse_settings_enum(menu, info,
|
||||
MENU_ENUM_LABEL_REWIND_SETTINGS, PARSE_ACTION, false);
|
||||
ret = menu_displaylist_parse_settings(menu, info,
|
||||
msg_hash_to_str(MENU_ENUM_LABEL_VALUE_RECORDING_SETTINGS), PARSE_ONLY_GROUP, false);
|
||||
ret = menu_displaylist_parse_settings(menu, info,
|
||||
|
@ -105,6 +105,8 @@ enum menu_displaylist_ctl_state
|
||||
DISPLAYLIST_CONFIGURATION_SETTINGS_LIST,
|
||||
DISPLAYLIST_SAVING_SETTINGS_LIST,
|
||||
DISPLAYLIST_LOGGING_SETTINGS_LIST,
|
||||
DISPLAYLIST_FRAME_THROTTLE_SETTINGS_LIST,
|
||||
DISPLAYLIST_REWIND_SETTINGS_LIST,
|
||||
DISPLAYLIST_AUDIO_SETTINGS_LIST,
|
||||
DISPLAYLIST_CORE_SETTINGS_LIST,
|
||||
DISPLAYLIST_INPUT_SETTINGS_LIST,
|
||||
|
@ -4245,6 +4245,24 @@ static bool setting_append_list(
|
||||
parent_group);
|
||||
menu_settings_list_current_add_enum_idx(list, list_info, MENU_ENUM_LABEL_LOGGING_SETTINGS);
|
||||
|
||||
CONFIG_ACTION(
|
||||
list, list_info,
|
||||
msg_hash_to_str(MENU_ENUM_LABEL_FRAME_THROTTLE_SETTINGS),
|
||||
msg_hash_to_str(MENU_ENUM_LABEL_VALUE_FRAME_THROTTLE_SETTINGS),
|
||||
&group_info,
|
||||
&subgroup_info,
|
||||
parent_group);
|
||||
menu_settings_list_current_add_enum_idx(list, list_info, MENU_ENUM_LABEL_FRAME_THROTTLE_SETTINGS);
|
||||
|
||||
CONFIG_ACTION(
|
||||
list, list_info,
|
||||
msg_hash_to_str(MENU_ENUM_LABEL_REWIND_SETTINGS),
|
||||
msg_hash_to_str(MENU_ENUM_LABEL_VALUE_REWIND_SETTINGS),
|
||||
&group_info,
|
||||
&subgroup_info,
|
||||
parent_group);
|
||||
menu_settings_list_current_add_enum_idx(list, list_info, MENU_ENUM_LABEL_REWIND_SETTINGS);
|
||||
|
||||
CONFIG_ACTION(
|
||||
list, list_info,
|
||||
msg_hash_to_str(MENU_ENUM_LABEL_PLAYLIST_SETTINGS),
|
||||
@ -4803,7 +4821,7 @@ static bool setting_append_list(
|
||||
case SETTINGS_LIST_REWIND:
|
||||
START_GROUP(list, list_info, &group_info, msg_hash_to_str(MENU_ENUM_LABEL_VALUE_REWIND_SETTINGS), parent_group);
|
||||
|
||||
parent_group = msg_hash_to_str(MENU_ENUM_LABEL_SETTINGS);
|
||||
parent_group = msg_hash_to_str(MENU_ENUM_LABEL_REWIND_SETTINGS);
|
||||
|
||||
START_SUB_GROUP(list, list_info, "State", &group_info, &subgroup_info, parent_group);
|
||||
|
||||
@ -6151,7 +6169,7 @@ static bool setting_append_list(
|
||||
msg_hash_to_str(MENU_ENUM_LABEL_VALUE_FRAME_THROTTLE_SETTINGS),
|
||||
parent_group);
|
||||
|
||||
parent_group = msg_hash_to_str(MENU_ENUM_LABEL_SETTINGS);
|
||||
parent_group = msg_hash_to_str(MENU_ENUM_LABEL_FRAME_THROTTLE_SETTINGS);
|
||||
|
||||
START_SUB_GROUP(list, list_info, "State", &group_info, &subgroup_info, parent_group);
|
||||
|
||||
|
@ -688,6 +688,8 @@ enum msg_hash_enums
|
||||
MENU_ENUM_LABEL_DEFERRED_VIDEO_SETTINGS_LIST,
|
||||
MENU_ENUM_LABEL_DEFERRED_CONFIGURATION_SETTINGS_LIST,
|
||||
MENU_ENUM_LABEL_DEFERRED_SAVING_SETTINGS_LIST,
|
||||
MENU_ENUM_LABEL_DEFERRED_FRAME_THROTTLE_SETTINGS_LIST,
|
||||
MENU_ENUM_LABEL_DEFERRED_REWIND_SETTINGS_LIST,
|
||||
MENU_ENUM_LABEL_DEFERRED_LOGGING_SETTINGS_LIST,
|
||||
MENU_ENUM_LABEL_DEFERRED_AUDIO_SETTINGS_LIST,
|
||||
MENU_ENUM_LABEL_DEFERRED_CORE_SETTINGS_LIST,
|
||||
@ -775,6 +777,7 @@ enum msg_hash_enums
|
||||
MENU_ENUM_LABEL_VALUE_NO_PERFORMANCE_COUNTERS,
|
||||
|
||||
|
||||
MENU_ENUM_LABEL_FRAME_THROTTLE_SETTINGS,
|
||||
MENU_ENUM_LABEL_VALUE_FRAME_THROTTLE_SETTINGS,
|
||||
|
||||
MENU_ENUM_LABEL_FRAME_THROTTLE_ENABLE,
|
||||
@ -1345,7 +1348,9 @@ enum msg_hash_enums
|
||||
MENU_ENUM_LABEL_SAVING_SETTINGS,
|
||||
MENU_ENUM_LABEL_VALUE_SAVING_SETTINGS,
|
||||
|
||||
MENU_ENUM_LABEL_REWIND_SETTINGS,
|
||||
MENU_ENUM_LABEL_VALUE_REWIND_SETTINGS,
|
||||
|
||||
MENU_ENUM_LABEL_RECORDING_SETTINGS,
|
||||
MENU_ENUM_LABEL_VALUE_RECORDING_SETTINGS,
|
||||
MENU_ENUM_LABEL_SHADER_SETTINGS,
|
||||
|
Loading…
x
Reference in New Issue
Block a user