274c12fc56
* Streams: string stream * String stream: updated insert/delete api * Streams: generic stream interface and string stream implementation * Streams: helpers for insert and delete_and_insert * FFF: now compatible with streams * MinUnit: introduced tests with arguments * FFF: stream access violation * Streams: copy data between streams * Streams: file stream * FFF: documentation * FFStream: documentation * FFF: alloc as file * MinUnit: support for nested tests * Streams: changed delete_and_insert, now it returns success flag. Added ability dump stream inner parameters and data to cout. * FFF: simplified file open function * Streams: unit tests * FFF: tests * Streams: declare cache_size constant as define, to allow variable modified arrays * FFF: lib moved to a separate folder * iButton: new FFF * RFID: new FFF * Animations: new FFF * IR: new FFF * NFC: new FFF * Flipper file format: delete lib * U2F: new FFF * Subghz: new FFF and streams * Streams: read line * Streams: split * FuriCore: implement memset with extra asserts * FuriCore: implement extra heap asserts without inventing memset * Scene manager: protected access to the scene id stack with a size check * NFC worker: dirty fix for issue where hal_nfc was busy on app start * Furi: update allocator to erase memory on allocation. Replace furi_alloc with malloc. * FuriCore: cleanup memmgr code. * Furi HAL: furi_hal_init is split into critical and non-critical parts. The critical part is currently clock and console. * Memmgr: added ability to track allocations and deallocations through console. * FFStream: some speedup * Streams, FF: minor fixes * Tests: restore * File stream: a slightly more thread-safe version of file_stream_delete_and_insert Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
124 lines
3.7 KiB
C
124 lines
3.7 KiB
C
#include "system_settings.h"
|
|
#include <loader/loader.h>
|
|
|
|
static uint8_t
|
|
uint32_value_index(const uint32_t value, const uint32_t values[], uint8_t values_count) {
|
|
int64_t last_value = INT64_MIN;
|
|
uint8_t index = 0;
|
|
for(uint8_t i = 0; i < values_count; i++) {
|
|
if((value >= last_value) && (value <= values[i])) {
|
|
index = i;
|
|
break;
|
|
}
|
|
last_value = values[i];
|
|
}
|
|
return index;
|
|
}
|
|
|
|
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) {
|
|
// SystemSettings* app = variable_item_get_context(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 debug_text[] = {
|
|
"Disable",
|
|
"Enable",
|
|
};
|
|
|
|
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);
|
|
}
|
|
loader_update_menu();
|
|
}
|
|
|
|
static uint32_t system_settings_exit(void* context) {
|
|
return VIEW_NONE;
|
|
}
|
|
|
|
SystemSettings* system_settings_alloc() {
|
|
SystemSettings* app = malloc(sizeof(SystemSettings));
|
|
|
|
// Load settings
|
|
app->gui = furi_record_open("gui");
|
|
|
|
app->view_dispatcher = view_dispatcher_alloc();
|
|
view_dispatcher_enable_queue(app->view_dispatcher);
|
|
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, "Log Level", COUNT_OF(log_level_text), log_level_changed, app);
|
|
value_index = uint32_value_index(
|
|
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, "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]);
|
|
|
|
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("gui");
|
|
free(app);
|
|
}
|
|
|
|
int32_t system_settings_app(void* p) {
|
|
SystemSettings* app = system_settings_alloc();
|
|
view_dispatcher_run(app->view_dispatcher);
|
|
system_settings_free(app);
|
|
return 0;
|
|
}
|