mirror of
https://github.com/DarkFlippers/unleashed-firmware.git
synced 2024-12-23 21:34:35 +03:00
f4122a924a
* Abstract primitive type from main logic in FuriEventLoop * Remove message_queue_i.h * Add stream buffer support for event loop * Add semaphore support for event loop * Add temporary unit test workaround * Make the linter happy * Add mutex support for event loop * Implement event subscription and unsubscription while the event loop is running * Implement edge events * Fix leftover logical errors * Add event loop timer example application * Implement flag-based edge trigger and one-shot mode * Add event loop mutex example application * Only notify the event loop if stream buffer is at or above its trigger level * Reformat comments * Add event loop stream buffer example application * Add event loop multiple elements example application * Improve event loop flag names * Remove redundant signal handler as it is already handled by the event loop * Refactor Power service, improve ViewHolder * Use ViewHolder instead of ViewDispatcher in About app * Enable ViewDispatcher queue on construction, deprecate view_dispatcher_enable_queue() * Remove all invocations of view_dispatcher_enable_queue() * Remove app-scened-template * Remove missing library from target.json * Port Accessor app to ViewHolder * Make the linter happy * Add example_view_holder application, update ViewHolder docs * Add example_view_dispatcher application, update ViewDispatcher docs * Replace FuriSemaphore with FuriApiLock, remove workaround delay * Fix logical error * Fix another logical error * Use the sources directive to speed up compilation * Use constant define macro * Improve FuriEventLoop documentation * Improve FuriEventLoop documentation once more * Bump API Version * Gui: remove redundant checks from ViewDispatcher * Gui: remove dead ifs from ViewDispatcher Co-authored-by: Silent <CookiePLMonster@users.noreply.github.com> Co-authored-by: hedger <hedger@users.noreply.github.com> Co-authored-by: あく <alleteam@gmail.com>
348 lines
11 KiB
C
348 lines
11 KiB
C
#include "system_settings.h"
|
|
#include <loader/loader.h>
|
|
#include <lib/toolbox/value_index.h>
|
|
#include <locale/locale.h>
|
|
|
|
const char* const log_level_text[] = {
|
|
"Default",
|
|
"None",
|
|
"Error",
|
|
"Warning",
|
|
"Info",
|
|
"Debug",
|
|
"Trace",
|
|
};
|
|
|
|
const uint32_t log_level_value[] = {
|
|
FuriLogLevelDefault,
|
|
FuriLogLevelNone,
|
|
FuriLogLevelError,
|
|
FuriLogLevelWarn,
|
|
FuriLogLevelInfo,
|
|
FuriLogLevelDebug,
|
|
FuriLogLevelTrace,
|
|
};
|
|
|
|
static void log_level_changed(VariableItem* item) {
|
|
uint8_t index = variable_item_get_current_value_index(item);
|
|
variable_item_set_current_value_text(item, log_level_text[index]);
|
|
furi_hal_rtc_set_log_level(log_level_value[index]);
|
|
}
|
|
|
|
const char* const log_device_text[] = {
|
|
"USART",
|
|
"LPUART",
|
|
"None",
|
|
};
|
|
|
|
const uint32_t log_device_value[] = {
|
|
FuriHalRtcLogDeviceUsart,
|
|
FuriHalRtcLogDeviceLpuart,
|
|
FuriHalRtcLogDeviceNone};
|
|
|
|
static void log_device_changed(VariableItem* item) {
|
|
uint8_t index = variable_item_get_current_value_index(item);
|
|
variable_item_set_current_value_text(item, log_device_text[index]);
|
|
furi_hal_rtc_set_log_device(log_device_value[index]);
|
|
}
|
|
|
|
const char* const log_baud_rate_text[] = {
|
|
"9600",
|
|
"38400",
|
|
"57600",
|
|
"115200",
|
|
"230400",
|
|
"460800",
|
|
"921600",
|
|
"1843200",
|
|
};
|
|
|
|
const uint32_t log_baud_rate_value[] = {
|
|
FuriHalRtcLogBaudRate9600,
|
|
FuriHalRtcLogBaudRate38400,
|
|
FuriHalRtcLogBaudRate57600,
|
|
FuriHalRtcLogBaudRate115200,
|
|
FuriHalRtcLogBaudRate230400,
|
|
FuriHalRtcLogBaudRate460800,
|
|
FuriHalRtcLogBaudRate921600,
|
|
FuriHalRtcLogBaudRate1843200,
|
|
};
|
|
|
|
static void log_baud_rate_changed(VariableItem* item) {
|
|
uint8_t index = variable_item_get_current_value_index(item);
|
|
variable_item_set_current_value_text(item, log_baud_rate_text[index]);
|
|
furi_hal_rtc_set_log_baud_rate(log_baud_rate_value[index]);
|
|
}
|
|
|
|
const char* const debug_text[] = {
|
|
"OFF",
|
|
"ON",
|
|
};
|
|
|
|
static void debug_changed(VariableItem* item) {
|
|
uint8_t index = variable_item_get_current_value_index(item);
|
|
variable_item_set_current_value_text(item, debug_text[index]);
|
|
if(index) {
|
|
furi_hal_rtc_set_flag(FuriHalRtcFlagDebug);
|
|
} else {
|
|
furi_hal_rtc_reset_flag(FuriHalRtcFlagDebug);
|
|
}
|
|
}
|
|
|
|
const char* const heap_trace_mode_text[] = {
|
|
"None",
|
|
"Main",
|
|
#ifdef FURI_DEBUG
|
|
"Tree",
|
|
"All",
|
|
#endif
|
|
};
|
|
|
|
const uint32_t heap_trace_mode_value[] = {
|
|
FuriHalRtcHeapTrackModeNone,
|
|
FuriHalRtcHeapTrackModeMain,
|
|
#ifdef FURI_DEBUG
|
|
FuriHalRtcHeapTrackModeTree,
|
|
FuriHalRtcHeapTrackModeAll,
|
|
#endif
|
|
};
|
|
|
|
static void heap_trace_mode_changed(VariableItem* item) {
|
|
uint8_t index = variable_item_get_current_value_index(item);
|
|
variable_item_set_current_value_text(item, heap_trace_mode_text[index]);
|
|
furi_hal_rtc_set_heap_track_mode(heap_trace_mode_value[index]);
|
|
}
|
|
|
|
const char* const mesurement_units_text[] = {
|
|
"Metric",
|
|
"Imperial",
|
|
};
|
|
|
|
const uint32_t mesurement_units_value[] = {
|
|
LocaleMeasurementUnitsMetric,
|
|
LocaleMeasurementUnitsImperial,
|
|
};
|
|
|
|
static void mesurement_units_changed(VariableItem* item) {
|
|
uint8_t index = variable_item_get_current_value_index(item);
|
|
variable_item_set_current_value_text(item, mesurement_units_text[index]);
|
|
locale_set_measurement_unit(mesurement_units_value[index]);
|
|
}
|
|
|
|
const char* const time_format_text[] = {
|
|
"24h",
|
|
"12h",
|
|
};
|
|
|
|
const uint32_t time_format_value[] = {
|
|
LocaleTimeFormat24h,
|
|
LocaleTimeFormat12h,
|
|
};
|
|
|
|
static void time_format_changed(VariableItem* item) {
|
|
uint8_t index = variable_item_get_current_value_index(item);
|
|
variable_item_set_current_value_text(item, time_format_text[index]);
|
|
locale_set_time_format(time_format_value[index]);
|
|
}
|
|
|
|
const char* const date_format_text[] = {
|
|
"D/M/Y",
|
|
"M/D/Y",
|
|
"Y/M/D",
|
|
};
|
|
|
|
const uint32_t date_format_value[] = {
|
|
LocaleDateFormatDMY,
|
|
LocaleDateFormatMDY,
|
|
LocaleDateFormatYMD,
|
|
};
|
|
|
|
static void date_format_changed(VariableItem* item) {
|
|
uint8_t index = variable_item_get_current_value_index(item);
|
|
variable_item_set_current_value_text(item, date_format_text[index]);
|
|
locale_set_date_format(date_format_value[index]);
|
|
}
|
|
|
|
const char* const hand_mode[] = {
|
|
"Righty",
|
|
"Lefty",
|
|
};
|
|
|
|
static void hand_orient_changed(VariableItem* item) {
|
|
uint8_t index = variable_item_get_current_value_index(item);
|
|
variable_item_set_current_value_text(item, hand_mode[index]);
|
|
if(index) {
|
|
furi_hal_rtc_set_flag(FuriHalRtcFlagHandOrient);
|
|
} else {
|
|
furi_hal_rtc_reset_flag(FuriHalRtcFlagHandOrient);
|
|
}
|
|
}
|
|
|
|
const char* const sleep_method[] = {
|
|
"Default",
|
|
"Legacy",
|
|
};
|
|
|
|
static void sleep_method_changed(VariableItem* item) {
|
|
uint8_t index = variable_item_get_current_value_index(item);
|
|
variable_item_set_current_value_text(item, sleep_method[index]);
|
|
if(index) {
|
|
furi_hal_rtc_set_flag(FuriHalRtcFlagLegacySleep);
|
|
} else {
|
|
furi_hal_rtc_reset_flag(FuriHalRtcFlagLegacySleep);
|
|
}
|
|
}
|
|
|
|
const char* const filename_scheme[] = {
|
|
"Default",
|
|
"Detailed",
|
|
};
|
|
|
|
static void filename_scheme_changed(VariableItem* item) {
|
|
uint8_t index = variable_item_get_current_value_index(item);
|
|
variable_item_set_current_value_text(item, filename_scheme[index]);
|
|
if(index) {
|
|
furi_hal_rtc_set_flag(FuriHalRtcFlagDetailedFilename);
|
|
} else {
|
|
furi_hal_rtc_reset_flag(FuriHalRtcFlagDetailedFilename);
|
|
}
|
|
}
|
|
|
|
static uint32_t system_settings_exit(void* context) {
|
|
UNUSED(context);
|
|
return VIEW_NONE;
|
|
}
|
|
|
|
SystemSettings* system_settings_alloc(void) {
|
|
SystemSettings* app = malloc(sizeof(SystemSettings));
|
|
|
|
// Load settings
|
|
app->gui = furi_record_open(RECORD_GUI);
|
|
|
|
app->view_dispatcher = view_dispatcher_alloc();
|
|
view_dispatcher_set_event_callback_context(app->view_dispatcher, app);
|
|
|
|
view_dispatcher_attach_to_gui(app->view_dispatcher, app->gui, ViewDispatcherTypeFullscreen);
|
|
|
|
VariableItem* item;
|
|
uint8_t value_index;
|
|
app->var_item_list = variable_item_list_alloc();
|
|
|
|
item = variable_item_list_add(
|
|
app->var_item_list, "Hand Orient", COUNT_OF(hand_mode), hand_orient_changed, app);
|
|
value_index = furi_hal_rtc_is_flag_set(FuriHalRtcFlagHandOrient) ? 1 : 0;
|
|
variable_item_set_current_value_index(item, value_index);
|
|
variable_item_set_current_value_text(item, hand_mode[value_index]);
|
|
|
|
item = variable_item_list_add(
|
|
app->var_item_list,
|
|
"Units",
|
|
COUNT_OF(mesurement_units_text),
|
|
mesurement_units_changed,
|
|
app);
|
|
value_index = value_index_uint32(
|
|
locale_get_measurement_unit(), mesurement_units_value, COUNT_OF(mesurement_units_value));
|
|
variable_item_set_current_value_index(item, value_index);
|
|
variable_item_set_current_value_text(item, mesurement_units_text[value_index]);
|
|
|
|
item = variable_item_list_add(
|
|
app->var_item_list, "Time Format", COUNT_OF(time_format_text), time_format_changed, app);
|
|
value_index = value_index_uint32(
|
|
locale_get_time_format(), time_format_value, COUNT_OF(time_format_value));
|
|
variable_item_set_current_value_index(item, value_index);
|
|
variable_item_set_current_value_text(item, time_format_text[value_index]);
|
|
|
|
item = variable_item_list_add(
|
|
app->var_item_list, "Date Format", COUNT_OF(date_format_text), date_format_changed, app);
|
|
value_index = value_index_uint32(
|
|
locale_get_date_format(), date_format_value, COUNT_OF(date_format_value));
|
|
variable_item_set_current_value_index(item, value_index);
|
|
variable_item_set_current_value_text(item, date_format_text[value_index]);
|
|
|
|
item = variable_item_list_add(
|
|
app->var_item_list, "Log Level", COUNT_OF(log_level_text), log_level_changed, app);
|
|
value_index = value_index_uint32(
|
|
furi_hal_rtc_get_log_level(), log_level_value, COUNT_OF(log_level_text));
|
|
variable_item_set_current_value_index(item, value_index);
|
|
variable_item_set_current_value_text(item, log_level_text[value_index]);
|
|
|
|
item = variable_item_list_add(
|
|
app->var_item_list, "Log Device", COUNT_OF(log_device_text), log_device_changed, app);
|
|
value_index = value_index_uint32(
|
|
furi_hal_rtc_get_log_device(), log_device_value, COUNT_OF(log_device_text));
|
|
variable_item_set_current_value_index(item, value_index);
|
|
variable_item_set_current_value_text(item, log_device_text[value_index]);
|
|
|
|
item = variable_item_list_add(
|
|
app->var_item_list,
|
|
"Log Baud Rate",
|
|
COUNT_OF(log_baud_rate_text),
|
|
log_baud_rate_changed,
|
|
app);
|
|
value_index = value_index_uint32(
|
|
furi_hal_rtc_get_log_baud_rate(), log_baud_rate_value, COUNT_OF(log_baud_rate_text));
|
|
variable_item_set_current_value_index(item, value_index);
|
|
variable_item_set_current_value_text(item, log_baud_rate_text[value_index]);
|
|
|
|
item = variable_item_list_add(
|
|
app->var_item_list, "Debug", COUNT_OF(debug_text), debug_changed, app);
|
|
value_index = furi_hal_rtc_is_flag_set(FuriHalRtcFlagDebug) ? 1 : 0;
|
|
variable_item_set_current_value_index(item, value_index);
|
|
variable_item_set_current_value_text(item, debug_text[value_index]);
|
|
|
|
item = variable_item_list_add(
|
|
app->var_item_list,
|
|
"Heap Trace",
|
|
COUNT_OF(heap_trace_mode_text),
|
|
heap_trace_mode_changed,
|
|
app);
|
|
value_index = value_index_uint32(
|
|
furi_hal_rtc_get_heap_track_mode(), heap_trace_mode_value, COUNT_OF(heap_trace_mode_text));
|
|
furi_hal_rtc_set_heap_track_mode(heap_trace_mode_value[value_index]);
|
|
variable_item_set_current_value_index(item, value_index);
|
|
variable_item_set_current_value_text(item, heap_trace_mode_text[value_index]);
|
|
|
|
item = variable_item_list_add(
|
|
app->var_item_list, "Sleep Method", COUNT_OF(sleep_method), sleep_method_changed, app);
|
|
value_index = furi_hal_rtc_is_flag_set(FuriHalRtcFlagLegacySleep) ? 1 : 0;
|
|
variable_item_set_current_value_index(item, value_index);
|
|
variable_item_set_current_value_text(item, sleep_method[value_index]);
|
|
|
|
item = variable_item_list_add(
|
|
app->var_item_list, "File Naming", COUNT_OF(filename_scheme), filename_scheme_changed, app);
|
|
value_index = furi_hal_rtc_is_flag_set(FuriHalRtcFlagDetailedFilename) ? 1 : 0;
|
|
variable_item_set_current_value_index(item, value_index);
|
|
variable_item_set_current_value_text(item, filename_scheme[value_index]);
|
|
|
|
view_set_previous_callback(
|
|
variable_item_list_get_view(app->var_item_list), system_settings_exit);
|
|
view_dispatcher_add_view(
|
|
app->view_dispatcher,
|
|
SystemSettingsViewVarItemList,
|
|
variable_item_list_get_view(app->var_item_list));
|
|
|
|
view_dispatcher_switch_to_view(app->view_dispatcher, SystemSettingsViewVarItemList);
|
|
|
|
return app;
|
|
}
|
|
|
|
void system_settings_free(SystemSettings* app) {
|
|
furi_assert(app);
|
|
// Variable item list
|
|
view_dispatcher_remove_view(app->view_dispatcher, SystemSettingsViewVarItemList);
|
|
variable_item_list_free(app->var_item_list);
|
|
// View dispatcher
|
|
view_dispatcher_free(app->view_dispatcher);
|
|
// Records
|
|
furi_record_close(RECORD_GUI);
|
|
free(app);
|
|
}
|
|
|
|
int32_t system_settings_app(void* p) {
|
|
UNUSED(p);
|
|
SystemSettings* app = system_settings_alloc();
|
|
view_dispatcher_run(app->view_dispatcher);
|
|
system_settings_free(app);
|
|
return 0;
|
|
}
|