mirror of
https://github.com/DarkFlippers/unleashed-firmware.git
synced 2025-01-05 20:33:01 +03:00
8f9b2513ff
* SYSTEM: tickless mode with deep sleep. * Move FreeRTOS ticks to lptim2 * API: move all sumbodules init routines to one place. Timebase: working lptim2 at tick source. * API Timebase: lp-timer routines, timer access safe zones prediction and synchronization. FreeRTOS: adjust configuration for tickless mode. * NFC: support for tickless mode. * API Timebase: improve tick error handling in IRQ. Apploader: use insomnia mode to run applications. * BLE: prevent sleep while core2 starting * HAL: nap while in insomnia mode * init records work * try to implement record delete * tests and flapp * flapp subsystem * new core functions to get app stat, simplify core code * fix thread termination * add strdup to core * fix tests * Refactoring: remove all unusued parts, update API usage, aggreagate API sources and headers, new record storage * Refactoring: update furi record api usage, cleanup code * Fix broken merge for freertos apps * Core, Target: fix compilation warnings * Drop firmware target local * HAL Timebase, Power, Clock: semaphore guarded access to clock and power modes, better sleep mode. * SD-Filesystem: wait for all deps to arrive before adding widget. Core, BLE: disable debug dump to serial. * delete old app example-ipc * delete old app fatfs list * fix strobe app, add input header * delete old display driver * comment old app qr-code * fix sd-card test, add forced widget update * remove unused new core test * increase heap to 128k * comment and assert old core tests * fix syntax Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
157 lines
6.0 KiB
C
157 lines
6.0 KiB
C
#include "dolphin_i.h"
|
|
|
|
bool dolphin_view_first_start_input(InputEvent* event, void* context) {
|
|
furi_assert(event);
|
|
furi_assert(context);
|
|
Dolphin* dolphin = context;
|
|
if(event->state) {
|
|
if(event->input == InputRight) {
|
|
uint32_t page;
|
|
with_view_model(
|
|
dolphin->idle_view_first_start,
|
|
(DolphinViewFirstStartModel * model) { page = ++model->page; });
|
|
if(page > 8) {
|
|
dolphin_save(dolphin);
|
|
view_dispatcher_switch_to_view(dolphin->idle_view_dispatcher, DolphinViewIdleMain);
|
|
}
|
|
}
|
|
}
|
|
// All events consumed
|
|
return true;
|
|
}
|
|
|
|
bool dolphin_view_idle_main_input(InputEvent* event, void* context) {
|
|
furi_assert(event);
|
|
furi_assert(context);
|
|
Dolphin* dolphin = context;
|
|
|
|
if(event->state) {
|
|
if(event->input == InputOk) {
|
|
with_value_mutex(
|
|
dolphin->menu_vm, (Menu * menu) { menu_ok(menu); });
|
|
} else if(event->input == InputUp) {
|
|
view_dispatcher_switch_to_view(dolphin->idle_view_dispatcher, DolphinViewIdleStats);
|
|
} else if(event->input == InputDown) {
|
|
view_dispatcher_switch_to_view(dolphin->idle_view_dispatcher, DolphinViewIdleDebug);
|
|
}
|
|
}
|
|
// All events consumed
|
|
return true;
|
|
}
|
|
|
|
bool dolphin_view_idle_stats_input(InputEvent* event, void* context) {
|
|
furi_assert(event);
|
|
furi_assert(context);
|
|
Dolphin* dolphin = context;
|
|
|
|
if(!event->state) return false;
|
|
|
|
if(event->input == InputLeft) {
|
|
dolphin_deed(dolphin, DolphinDeedWrong);
|
|
} else if(event->input == InputRight) {
|
|
dolphin_deed(dolphin, DolphinDeedIButtonRead);
|
|
} else if(event->input == InputOk) {
|
|
dolphin_save(dolphin);
|
|
} else {
|
|
return false;
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
Dolphin* dolphin_alloc() {
|
|
Dolphin* dolphin = furi_alloc(sizeof(Dolphin));
|
|
// Message queue
|
|
dolphin->event_queue = osMessageQueueNew(8, sizeof(DolphinEvent), NULL);
|
|
furi_check(dolphin->event_queue);
|
|
// State
|
|
dolphin->state = dolphin_state_alloc();
|
|
// Menu
|
|
dolphin->menu_vm = furi_record_open("menu");
|
|
// GUI
|
|
dolphin->idle_view_dispatcher = view_dispatcher_alloc();
|
|
// First start View
|
|
dolphin->idle_view_first_start = view_alloc();
|
|
view_allocate_model(
|
|
dolphin->idle_view_first_start, ViewModelTypeLockFree, sizeof(DolphinViewFirstStartModel));
|
|
view_set_context(dolphin->idle_view_first_start, dolphin);
|
|
view_set_draw_callback(dolphin->idle_view_first_start, dolphin_view_first_start_draw);
|
|
view_set_input_callback(dolphin->idle_view_first_start, dolphin_view_first_start_input);
|
|
view_dispatcher_add_view(
|
|
dolphin->idle_view_dispatcher, DolphinViewFirstStart, dolphin->idle_view_first_start);
|
|
// Main Idle View
|
|
dolphin->idle_view_main = view_alloc();
|
|
view_set_context(dolphin->idle_view_main, dolphin);
|
|
view_set_draw_callback(dolphin->idle_view_main, dolphin_view_idle_main_draw);
|
|
view_set_input_callback(dolphin->idle_view_main, dolphin_view_idle_main_input);
|
|
view_dispatcher_add_view(
|
|
dolphin->idle_view_dispatcher, DolphinViewIdleMain, dolphin->idle_view_main);
|
|
// Stats Idle View
|
|
dolphin->idle_view_stats = view_alloc();
|
|
view_set_context(dolphin->idle_view_stats, dolphin);
|
|
view_allocate_model(
|
|
dolphin->idle_view_stats, ViewModelTypeLockFree, sizeof(DolphinViewIdleStatsModel));
|
|
view_set_draw_callback(dolphin->idle_view_stats, dolphin_view_idle_stats_draw);
|
|
view_set_input_callback(dolphin->idle_view_stats, dolphin_view_idle_stats_input);
|
|
view_set_previous_callback(dolphin->idle_view_stats, dolphin_view_idle_back);
|
|
view_dispatcher_add_view(
|
|
dolphin->idle_view_dispatcher, DolphinViewIdleStats, dolphin->idle_view_stats);
|
|
// Debug Idle View
|
|
dolphin->idle_view_debug = view_alloc();
|
|
view_set_draw_callback(dolphin->idle_view_debug, dolphin_view_idle_debug_draw);
|
|
view_set_previous_callback(dolphin->idle_view_debug, dolphin_view_idle_back);
|
|
view_dispatcher_add_view(
|
|
dolphin->idle_view_dispatcher, DolphinViewIdleDebug, dolphin->idle_view_debug);
|
|
|
|
return dolphin;
|
|
}
|
|
|
|
void dolphin_save(Dolphin* dolphin) {
|
|
furi_assert(dolphin);
|
|
DolphinEvent event;
|
|
event.type = DolphinEventTypeSave;
|
|
furi_check(osMessageQueuePut(dolphin->event_queue, &event, 0, osWaitForever) == osOK);
|
|
}
|
|
|
|
void dolphin_deed(Dolphin* dolphin, DolphinDeed deed) {
|
|
furi_assert(dolphin);
|
|
DolphinEvent event;
|
|
event.type = DolphinEventTypeDeed;
|
|
event.deed = deed;
|
|
furi_check(osMessageQueuePut(dolphin->event_queue, &event, 0, osWaitForever) == osOK);
|
|
}
|
|
|
|
void dolphin_task() {
|
|
Dolphin* dolphin = dolphin_alloc();
|
|
|
|
Gui* gui = furi_record_open("gui");
|
|
view_dispatcher_attach_to_gui(dolphin->idle_view_dispatcher, gui, ViewDispatcherTypeWindow);
|
|
if(dolphin_state_load(dolphin->state)) {
|
|
view_dispatcher_switch_to_view(dolphin->idle_view_dispatcher, DolphinViewIdleMain);
|
|
} else {
|
|
view_dispatcher_switch_to_view(dolphin->idle_view_dispatcher, DolphinViewFirstStart);
|
|
}
|
|
with_view_model(
|
|
dolphin->idle_view_stats, (DolphinViewIdleStatsModel * model) {
|
|
model->icounter = dolphin_state_get_icounter(dolphin->state);
|
|
model->butthurt = dolphin_state_get_butthurt(dolphin->state);
|
|
});
|
|
|
|
furi_record_create("dolphin", dolphin);
|
|
|
|
DolphinEvent event;
|
|
while(1) {
|
|
furi_check(osMessageQueueGet(dolphin->event_queue, &event, NULL, osWaitForever) == osOK);
|
|
if(event.type == DolphinEventTypeDeed) {
|
|
dolphin_state_on_deed(dolphin->state, event.deed);
|
|
with_view_model(
|
|
dolphin->idle_view_stats, (DolphinViewIdleStatsModel * model) {
|
|
model->icounter = dolphin_state_get_icounter(dolphin->state);
|
|
model->butthurt = dolphin_state_get_butthurt(dolphin->state);
|
|
});
|
|
} else if(event.type == DolphinEventTypeSave) {
|
|
dolphin_state_save(dolphin->state);
|
|
}
|
|
}
|
|
}
|