Improve menu response

Dont load the info on every frame!
Use the init function so it is loaded once.
This commit is contained in:
Robin Jones 2024-07-20 14:44:43 +01:00
parent 99abea6aa8
commit 967d846f0e

View File

@ -10,12 +10,6 @@ static cpak_info_t cpak_info;
static void process (menu_t *menu) { static void process (menu_t *menu) {
// check which paks are available
JOYPAD_PORT_FOREACH (port) {
accessory_is_cpak[port] = joypad_get_accessory_type(port) == JOYPAD_ACCESSORY_TYPE_CONTROLLER_PAK;
}
cpak_info_load(JOYPAD_PORT_1, &cpak_info);
if (menu->actions.enter) { if (menu->actions.enter) {
// TODO: handle all ports // TODO: handle all ports
@ -24,6 +18,7 @@ static void process (menu_t *menu) {
path_t *path = path_init(menu->storage_prefix, CPAK_BACKUP_DIRECTORY"/"CPAK_BACKUP_FILE); path_t *path = path_init(menu->storage_prefix, CPAK_BACKUP_DIRECTORY"/"CPAK_BACKUP_FILE);
cpak_clone_contents_to_file(path_get(path), JOYPAD_PORT_1); cpak_clone_contents_to_file(path_get(path), JOYPAD_PORT_1);
path_free(path); path_free(path);
component_messagebox_draw("Done");
} }
} }
@ -87,7 +82,13 @@ static void draw (menu_t *menu, surface_t *d) {
} }
void view_joypad_controller_pak_init (menu_t *menu){ void view_joypad_controller_pak_init (menu_t *menu){
// Nothing to initialize (yet)
// check which paks are available
JOYPAD_PORT_FOREACH (port) {
accessory_is_cpak[port] = joypad_get_accessory_type(port) == JOYPAD_ACCESSORY_TYPE_CONTROLLER_PAK;
}
cpak_info_load(JOYPAD_PORT_1, &cpak_info);
} }
void view_joypad_controller_pak_display (menu_t *menu, surface_t *display) { void view_joypad_controller_pak_display (menu_t *menu, surface_t *display) {