moved pmem setting restore before top bar is loaded (#1105)

* moved pmem setting restore before top bar is loaded
* added a check pmem from sdcard function, replaced occurences, added a save to file on back button
* Added defines for flag file and dump file, changed test func name to should_use_sdcard_for_pmem, used file_exists, removed save and load pmem parameter
* changed a text to a more comprehesible one
This commit is contained in:
gullradriel 2023-06-04 21:25:25 +02:00 committed by GitHub
parent e3e179e380
commit 7e8a139732
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 31 additions and 30 deletions

View File

@ -446,27 +446,16 @@ SetPersistentMemoryView::SetPersistentMemoryView(NavigationView& nav) {
add_children({&text_pmem_about, add_children({&text_pmem_about,
&text_pmem_informations, &text_pmem_informations,
&text_pmem_status, &text_pmem_status,
&check_load_mem_at_startup, &check_use_sdcard_for_pmem,
&button_save_mem_to_file, &button_save_mem_to_file,
&button_load_mem_from_file, &button_load_mem_from_file,
&button_load_mem_defaults, &button_load_mem_defaults,
&button_return}); &button_return});
bool load_mem_at_startup = false; check_use_sdcard_for_pmem.set_value(portapack::persistent_memory::should_use_sdcard_for_pmem());
check_use_sdcard_for_pmem.on_select = [this](Checkbox&, bool v) {
File pmem_flag_file_handle; File pmem_flag_file_handle;
std::string pmem_flag_file = PMEM_FILEFLAG;
std::string folder = "SETTINGS";
make_new_directory(folder);
std::string pmem_flag_file = "/SETTINGS/PMEM_FILEFLAG";
auto result = pmem_flag_file_handle.open(pmem_flag_file);
if (!result.is_valid()) {
load_mem_at_startup = true;
}
check_load_mem_at_startup.set_value(load_mem_at_startup);
check_load_mem_at_startup.on_select = [this](Checkbox&, bool v) {
File pmem_flag_file_handle;
std::string pmem_flag_file = "/SETTINGS/PMEM_FILEFLAG";
if (v) { if (v) {
auto result = pmem_flag_file_handle.open(pmem_flag_file); auto result = pmem_flag_file_handle.open(pmem_flag_file);
if (result.is_valid()) { if (result.is_valid()) {
@ -490,7 +479,7 @@ SetPersistentMemoryView::SetPersistentMemoryView(NavigationView& nav) {
}; };
button_save_mem_to_file.on_select = [&nav, this](Button&) { button_save_mem_to_file.on_select = [&nav, this](Button&) {
if (!portapack::persistent_memory::save_persistent_settings_to_file("SETTINGS/pmem_settings")) { if (!portapack::persistent_memory::save_persistent_settings_to_file()) {
text_pmem_status.set("!problem saving settings!"); text_pmem_status.set("!problem saving settings!");
} else { } else {
text_pmem_status.set("settings saved"); text_pmem_status.set("settings saved");
@ -498,7 +487,7 @@ SetPersistentMemoryView::SetPersistentMemoryView(NavigationView& nav) {
}; };
button_load_mem_from_file.on_select = [&nav, this](Button&) { button_load_mem_from_file.on_select = [&nav, this](Button&) {
if (!portapack::persistent_memory::load_persistent_settings_from_file("SETTINGS/pmem_settings")) { if (!portapack::persistent_memory::load_persistent_settings_from_file()) {
text_pmem_status.set("!problem loading settings!"); text_pmem_status.set("!problem loading settings!");
} else { } else {
text_pmem_status.set("settings loaded"); text_pmem_status.set("settings loaded");

View File

@ -485,10 +485,10 @@ class SetPersistentMemoryView : public View {
{0, 3 * 16, 240, 16}, {0, 3 * 16, 240, 16},
""}; ""};
Checkbox check_load_mem_at_startup{ Checkbox check_use_sdcard_for_pmem{
{18, 6 * 16}, {18, 6 * 16},
19, 19,
"load from sd at startup"}; "use sdcard for p.mem"};
Button button_save_mem_to_file{ Button button_save_mem_to_file{
{0, 8 * 16, 240, 32}, {0, 8 * 16, 240, 32},

View File

@ -126,6 +126,10 @@ SystemStatusView::SystemStatusView(
&sd_card_status_view, &sd_card_status_view,
}); });
if (portapack::persistent_memory::should_use_sdcard_for_pmem()) {
portapack::persistent_memory::load_persistent_settings_from_file();
}
if (portapack::persistent_memory::config_speaker()) if (portapack::persistent_memory::config_speaker())
button_speaker.hidden(false); button_speaker.hidden(false);
else else
@ -156,6 +160,9 @@ SystemStatusView::SystemStatusView(
refresh(); refresh();
button_back.on_select = [this](ImageButton&) { button_back.on_select = [this](ImageButton&) {
if (portapack::persistent_memory::should_use_sdcard_for_pmem()) {
portapack::persistent_memory::save_persistent_settings_to_file();
}
if (this->on_back) if (this->on_back)
this->on_back(); this->on_back();
}; };
@ -692,13 +699,6 @@ SystemView::SystemView(
navigation_view.push<SystemMenuView>(); navigation_view.push<SystemMenuView>();
File pmem_flag_file_handle;
std::string pmem_flag_file = "/SETTINGS/PMEM_FILEFLAG";
auto result = pmem_flag_file_handle.open(pmem_flag_file);
if (!result.is_valid()) {
portapack::persistent_memory::load_persistent_settings_from_file("SETTINGS/pmem_settings");
}
if (portapack::persistent_memory::config_splash()) { if (portapack::persistent_memory::config_splash()) {
navigation_view.push<BMPView>(); navigation_view.push<BMPView>();
} }

View File

@ -820,8 +820,13 @@ void set_encoder_dial_sensitivity(uint8_t v) {
data->encoder_dial_sensitivity = v; data->encoder_dial_sensitivity = v;
} }
bool should_use_sdcard_for_pmem() {
return std::filesystem::file_exists(PMEM_FILEFLAG);
}
// sd persisting settings // sd persisting settings
int save_persistent_settings_to_file(std::string filename) { int save_persistent_settings_to_file() {
std::string filename = PMEM_SETTING_FILE;
delete_file(filename); delete_file(filename);
File outfile; File outfile;
auto result = outfile.create(filename); auto result = outfile.create(filename);
@ -832,7 +837,8 @@ int save_persistent_settings_to_file(std::string filename) {
return true; return true;
} }
int load_persistent_settings_from_file(std::string filename) { int load_persistent_settings_from_file() {
std::string filename = PMEM_SETTING_FILE;
File infile; File infile;
auto result = infile.open(filename); auto result = infile.open(filename);
if (!result.is_valid()) { if (!result.is_valid()) {

View File

@ -32,6 +32,11 @@
#include "modems.hpp" #include "modems.hpp"
#include "serializer.hpp" #include "serializer.hpp"
// persistant memory from/to sdcard flag file
#define PMEM_FILEFLAG "/SETTINGS/PMEM_FILEFLAG"
// persistant memory from/to sdcard flag file
#define PMEM_SETTING_FILE "/SETTINGS/pmem_settings"
using namespace modems; using namespace modems;
using namespace serializer; using namespace serializer;
@ -244,8 +249,9 @@ void set_recon_load_hamradios(const bool v);
void set_recon_match_mode(const bool v); void set_recon_match_mode(const bool v);
// sd persisting settings // sd persisting settings
int save_persistent_settings_to_file(std::string filename); bool should_use_sdcard_for_pmem();
int load_persistent_settings_from_file(std::string filename); int save_persistent_settings_to_file();
int load_persistent_settings_from_file();
} /* namespace persistent_memory */ } /* namespace persistent_memory */