#include #include #include <3ds.h> #include "action/action.h" #include "section.h" #include "../error.h" #include "../../screen.h" #define PENDINGTITLES_MAX 1024 typedef struct { list_item items[PENDINGTITLES_MAX]; u32 count; Handle cancelEvent; bool populated; } pendingtitles_data; #define PENDINGTITLES_ACTION_COUNT 2 static u32 pending_titles_action_count = PENDINGTITLES_ACTION_COUNT; static list_item pending_titles_action_items[PENDINGTITLES_ACTION_COUNT] = { {"Delete Pending Title", COLOR_TEXT, action_delete_pending_title}, {"Delete All Pending Titles", COLOR_TEXT, action_delete_all_pending_titles}, }; typedef struct { pending_title_info* info; bool* populated; } pendingtitles_action_data; static void pendingtitles_action_draw_top(ui_view* view, void* data, float x1, float y1, float x2, float y2, list_item* selected) { ui_draw_pending_title_info(view, ((pendingtitles_action_data*) data)->info, x1, y1, x2, y2); } static void pendingtitles_action_update(ui_view* view, void* data, list_item** items, u32** itemCount, list_item* selected, bool selectedTouched) { pendingtitles_action_data* actionData = (pendingtitles_action_data*) data; if(hidKeysDown() & KEY_B) { ui_pop(); list_destroy(view); free(data); return; } if(selected != NULL && selected->data != NULL && (selectedTouched || (hidKeysDown() & KEY_A))) { void(*action)(pending_title_info*, bool*) = (void(*)(pending_title_info*, bool*)) selected->data; ui_pop(); list_destroy(view); action(actionData->info, actionData->populated); free(data); return; } if(*itemCount != &pending_titles_action_count || *items != pending_titles_action_items) { *itemCount = &pending_titles_action_count; *items = pending_titles_action_items; } } static void pendingtitles_action_open(pending_title_info* info, bool* populated) { pendingtitles_action_data* data = (pendingtitles_action_data*) calloc(1, sizeof(pendingtitles_action_data)); if(data == NULL) { error_display(NULL, NULL, NULL, "Failed to allocate pending titles action data."); return; } data->info = info; data->populated = populated; list_display("Pending Title Action", "A: Select, B: Return", data, pendingtitles_action_update, pendingtitles_action_draw_top); } static void pendingtitles_draw_top(ui_view* view, void* data, float x1, float y1, float x2, float y2, list_item* selected) { if(selected != NULL && selected->data != NULL) { ui_draw_pending_title_info(view, selected->data, x1, y1, x2, y2); } } static void pendingtitles_update(ui_view* view, void* data, list_item** items, u32** itemCount, list_item* selected, bool selectedTouched) { pendingtitles_data* listData = (pendingtitles_data*) data; if(hidKeysDown() & KEY_B) { if(listData->cancelEvent != 0) { svcSignalEvent(listData->cancelEvent); while(svcWaitSynchronization(listData->cancelEvent, 0) == 0) { svcSleepThread(1000000); } listData->cancelEvent = 0; } ui_pop(); list_destroy(view); task_clear_pending_titles(listData->items, &listData->count); free(listData); return; } if(!listData->populated || (hidKeysDown() & KEY_X)) { if(listData->cancelEvent != 0) { svcSignalEvent(listData->cancelEvent); while(svcWaitSynchronization(listData->cancelEvent, 0) == 0) { svcSleepThread(1000000); } listData->cancelEvent = 0; } listData->cancelEvent = task_populate_pending_titles(listData->items, &listData->count, PENDINGTITLES_MAX); listData->populated = true; } if(selected != NULL && selected->data != NULL && (selectedTouched || (hidKeysDown() & KEY_A))) { pendingtitles_action_open((pending_title_info*) selected->data, &listData->populated); return; } if(*itemCount != &listData->count || *items != listData->items) { *itemCount = &listData->count; *items = listData->items; } } void pendingtitles_open() { pendingtitles_data* data = (pendingtitles_data*) calloc(1, sizeof(pendingtitles_data)); if(data == NULL) { error_display(NULL, NULL, NULL, "Failed to allocate pending titles data."); return; } list_display("Pending Titles", "A: Select, B: Return, X: Refresh", data, pendingtitles_update, pendingtitles_draw_top); }