summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorjacqueline <me@jacqueline.id.au>2024-04-02 20:41:36 +1100
committerjacqueline <me@jacqueline.id.au>2024-04-02 20:41:36 +1100
commit654fde5f6819cb52a198a524ab78d97e51ab97c7 (patch)
treebad528f15ebfa35f4c1d9a0a027d01453495fb67
parent1e278d55c4dc0a9ae7b5b4511904202824e5c5df (diff)
downloadtangara-fw-654fde5f6819cb52a198a524ab78d97e51ab97c7.tar.gz
Support disabling automatic database updates
-rw-r--r--lua/settings.lua136
-rw-r--r--src/drivers/include/nvs.hpp4
-rw-r--r--src/drivers/nvs.cpp14
-rw-r--r--src/system_fsm/running.cpp16
-rw-r--r--src/ui/include/ui_fsm.hpp1
-rw-r--r--src/ui/ui_fsm.cpp18
6 files changed, 125 insertions, 64 deletions
diff --git a/lua/settings.lua b/lua/settings.lua
index d19a6180..1e2debea 100644
--- a/lua/settings.lua
+++ b/lua/settings.lua
@@ -54,10 +54,10 @@ local BluetoothSettings = screen:new {
bluetooth.enabled:set(enabled)
end)
- theme.set_style(self.menu.content:Label {
- text = "Paired Device",
- pad_bottom = 1,
- }, "settings_title")
+ theme.set_style(self.menu.content:Label {
+ text = "Paired Device",
+ pad_bottom = 1,
+ }, "settings_title")
local paired_container = self.menu.content:Object {
flex = {
@@ -80,10 +80,10 @@ local BluetoothSettings = screen:new {
bluetooth.paired_device:set()
end)
- theme.set_style(self.menu.content:Label {
- text = "Nearby Devices",
- pad_bottom = 1,
- }, "settings_title")
+ theme.set_style(self.menu.content:Label {
+ text = "Nearby Devices",
+ pad_bottom = 1,
+ }, "settings_title")
local devices = self.menu.content:List {
w = lvgl.PCT(100),
@@ -123,9 +123,9 @@ local HeadphonesSettings = screen:new {
createUi = function(self)
self.menu = SettingsScreen("Headphones")
- theme.set_style(self.menu.content:Label {
- text = "Maxiumum volume limit",
- }, "settings_title")
+ theme.set_style(self.menu.content:Label {
+ text = "Maxiumum volume limit",
+ }, "settings_title")
local volume_chooser = self.menu.content:Dropdown {
options = "Line Level (-10 dB)\nCD Level (+6 dB)\nMaximum (+10dB)",
@@ -138,9 +138,9 @@ local HeadphonesSettings = screen:new {
volume.limit_db:set(limits[selection])
end)
- theme.set_style(self.menu.content:Label {
- text = "Left/Right balance",
- }, "settings_title")
+ theme.set_style(self.menu.content:Label {
+ text = "Left/Right balance",
+ }, "settings_title")
local balance = self.menu.content:Slider {
w = lvgl.PCT(100),
@@ -186,20 +186,20 @@ local DisplaySettings = screen:new {
createUi = function(self)
self.menu = SettingsScreen("Display")
- local brightness_title = self.menu.content:Object {
- flex = {
- flex_direction = "row",
- justify_content = "flex-start",
- align_items = "flex-start",
- align_content = "flex-start",
- },
- w = lvgl.PCT(100),
- h = lvgl.SIZE_CONTENT,
+ local brightness_title = self.menu.content:Object {
+ flex = {
+ flex_direction = "row",
+ justify_content = "flex-start",
+ align_items = "flex-start",
+ align_content = "flex-start",
+ },
+ w = lvgl.PCT(100),
+ h = lvgl.SIZE_CONTENT,
- }
- brightness_title:Label { text = "Brightness", flex_grow = 1 }
- local brightness_pct = brightness_title:Label {}
- theme.set_style(brightness_pct, "settings_title")
+ }
+ brightness_title:Label { text = "Brightness", flex_grow = 1 }
+ local brightness_pct = brightness_title:Label {}
+ theme.set_style(brightness_pct, "settings_title")
local brightness = self.menu.content:Slider {
w = lvgl.PCT(100),
@@ -223,9 +223,9 @@ local InputSettings = screen:new {
createUi = function(self)
self.menu = SettingsScreen("Input Method")
- theme.set_style(self.menu.content:Label {
- text = "Control scheme",
- }, "settings_title")
+ theme.set_style(self.menu.content:Label {
+ text = "Control scheme",
+ }, "settings_title")
local schemes = controls.schemes()
local option_to_scheme = {}
@@ -261,9 +261,9 @@ local InputSettings = screen:new {
controls.scheme:set(scheme)
end)
- theme.set_style(self.menu.content:Label {
- text = "Scroll Sensitivity",
- }, "settings_title")
+ theme.set_style(self.menu.content:Label {
+ text = "Scroll Sensitivity",
+ }, "settings_title")
local slider_scale = 4; -- Power steering
local sensitivity = self.menu.content:Slider {
@@ -333,25 +333,53 @@ local DatabaseSettings = screen:new {
widgets.Row(self.menu.content, "Schema version", db.version())
widgets.Row(self.menu.content, "Size on disk", string.format("%.1f KiB", db.size() / 1024))
- local actions_container = self.menu.content:Object {
- w = lvgl.PCT(100),
- h = lvgl.SIZE_CONTENT,
- flex = {
- flex_direction = "row",
- justify_content = "center",
- align_items = "space-evenly",
- align_content = "center",
- },
- pad_top = 4,
- pad_column = 4,
- }
- actions_container:add_style(styles.list_item)
+ local auto_update_container = self.menu.content:Object {
+ flex = {
+ flex_direction = "row",
+ justify_content = "flex-start",
+ align_items = "flex-start",
+ align_content = "flex-start",
+ },
+ w = lvgl.PCT(100),
+ h = lvgl.SIZE_CONTENT,
+ }
+ auto_update_container:add_style(styles.list_item)
+ auto_update_container:Label { text = "Auto update", flex_grow = 1 }
+ local auto_update_sw = auto_update_container:Switch {}
+
+ auto_update_sw:onevent(lvgl.EVENT.VALUE_CHANGED, function()
+ database.auto_update:set(auto_update_sw:enabled())
+ end)
+
+ local actions_container = self.menu.content:Object {
+ w = lvgl.PCT(100),
+ h = lvgl.SIZE_CONTENT,
+ flex = {
+ flex_direction = "row",
+ justify_content = "center",
+ align_items = "space-evenly",
+ align_content = "center",
+ },
+ pad_top = 4,
+ pad_column = 4,
+ }
+ actions_container:add_style(styles.list_item)
local update = actions_container:Button {}
- update:Label { text = "Update" }
+ update:Label { text = "Update now" }
update:onClicked(function()
database.update()
end)
+
+ self.bindings = {
+ database.auto_update:bind(function(en)
+ if en then
+ auto_update_sw:add_state(lvgl.STATE.CHECKED)
+ else
+ auto_update_sw:clear_state(lvgl.STATE.CHECKED)
+ end
+ end),
+ }
end
}
@@ -383,13 +411,13 @@ return screen:new {
flex_grow = 1,
}
- local function section(name)
- local elem = self.list:Label {
- text = name,
- pad_left = 4,
- }
- theme.set_style(elem, "settings_title")
- end
+ local function section(name)
+ local elem = self.list:Label {
+ text = name,
+ pad_left = 4,
+ }
+ theme.set_style(elem, "settings_title")
+ end
local function submenu(name, class)
local item = self.list:add_btn(nil, name)
diff --git a/src/drivers/include/nvs.hpp b/src/drivers/include/nvs.hpp
index f288f8e2..25396622 100644
--- a/src/drivers/include/nvs.hpp
+++ b/src/drivers/include/nvs.hpp
@@ -114,6 +114,9 @@ class NvsStorage {
auto PrimaryInput() -> InputModes;
auto PrimaryInput(InputModes) -> void;
+ auto DbAutoIndex() -> bool;
+ auto DbAutoIndex(bool) -> void;
+
explicit NvsStorage(nvs_handle_t);
~NvsStorage();
@@ -136,6 +139,7 @@ class NvsStorage {
Setting<uint8_t> input_mode_;
Setting<uint8_t> output_mode_;
Setting<bluetooth::MacAndName> bt_preferred_;
+ Setting<uint8_t> db_auto_index_;
util::LruCache<10, bluetooth::mac_addr_t, uint8_t> bt_volumes_;
bool bt_volumes_dirty_;
diff --git a/src/drivers/nvs.cpp b/src/drivers/nvs.cpp
index 28cb542c..33d92a9f 100644
--- a/src/drivers/nvs.cpp
+++ b/src/drivers/nvs.cpp
@@ -39,6 +39,7 @@ static constexpr char kKeyScrollSensitivity[] = "scroll";
static constexpr char kKeyLockPolarity[] = "lockpol";
static constexpr char kKeyDisplayCols[] = "dispcols";
static constexpr char kKeyDisplayRows[] = "disprows";
+static constexpr char kKeyDbAutoIndex[] = "dbautoindex";
static auto nvs_get_string(nvs_handle_t nvs, const char* key)
-> std::optional<std::string> {
@@ -173,6 +174,7 @@ NvsStorage::NvsStorage(nvs_handle_t handle)
input_mode_(kKeyPrimaryInput),
output_mode_(kKeyOutput),
bt_preferred_(kKeyBluetoothPreferred),
+ db_auto_index_(kKeyDbAutoIndex),
bt_volumes_(),
bt_volumes_dirty_(false) {}
@@ -194,6 +196,7 @@ auto NvsStorage::Read() -> void {
input_mode_.read(handle_);
output_mode_.read(handle_);
bt_preferred_.read(handle_);
+ db_auto_index_.read(handle_);
readBtVolumes();
}
@@ -210,6 +213,7 @@ auto NvsStorage::Write() -> bool {
input_mode_.write(handle_);
output_mode_.write(handle_);
bt_preferred_.write(handle_);
+ db_auto_index_.write(handle_);
writeBtVolumes();
return nvs_commit(handle_) == ESP_OK;
}
@@ -370,6 +374,16 @@ auto NvsStorage::PrimaryInput(InputModes mode) -> void {
input_mode_.set(static_cast<uint8_t>(mode));
}
+auto NvsStorage::DbAutoIndex() -> bool {
+ std::lock_guard<std::mutex> lock{mutex_};
+ return db_auto_index_.get().value_or(true);
+}
+
+auto NvsStorage::DbAutoIndex(bool en) -> void {
+ std::lock_guard<std::mutex> lock{mutex_};
+ db_auto_index_.set(static_cast<uint8_t>(en));
+}
+
class VolumesParseClient : public cppbor::ParseClient {
public:
VolumesParseClient(util::LruCache<10, bluetooth::mac_addr_t, uint8_t>& out)
diff --git a/src/system_fsm/running.cpp b/src/system_fsm/running.cpp
index a6ab5d47..8625ac66 100644
--- a/src/system_fsm/running.cpp
+++ b/src/system_fsm/running.cpp
@@ -166,13 +166,15 @@ auto Running::mountStorage() -> bool {
// Tell the database to refresh so that we pick up any changes from the newly
// mounted card.
- sServices->bg_worker().Dispatch<void>([&]() {
- auto db = sServices->database().lock();
- if (!db) {
- return;
- }
- db->updateIndexes();
- });
+ if (sServices->nvs().DbAutoIndex()) {
+ sServices->bg_worker().Dispatch<void>([&]() {
+ auto db = sServices->database().lock();
+ if (!db) {
+ return;
+ }
+ db->updateIndexes();
+ });
+ }
return true;
}
diff --git a/src/ui/include/ui_fsm.hpp b/src/ui/include/ui_fsm.hpp
index 5e1cc487..9f9aa9b9 100644
--- a/src/ui/include/ui_fsm.hpp
+++ b/src/ui/include/ui_fsm.hpp
@@ -130,6 +130,7 @@ class UiState : public tinyfsm::Fsm<UiState> {
static lua::Property sLockSwitch;
static lua::Property sDatabaseUpdating;
+ static lua::Property sDatabaseAutoUpdate;
static lua::Property sUsbMassStorageEnabled;
};
diff --git a/src/ui/ui_fsm.cpp b/src/ui/ui_fsm.cpp
index 835da19e..bb1503b2 100644
--- a/src/ui/ui_fsm.cpp
+++ b/src/ui/ui_fsm.cpp
@@ -282,6 +282,14 @@ lua::Property UiState::sScrollSensitivity{
lua::Property UiState::sLockSwitch{false};
lua::Property UiState::sDatabaseUpdating{false};
+lua::Property UiState::sDatabaseAutoUpdate{
+ false, [](const lua::LuaValue& val) {
+ if (!std::holds_alternative<bool>(val)) {
+ return false;
+ }
+ sServices->nvs().DbAutoIndex(std::get<bool>(val));
+ return true;
+ }};
lua::Property UiState::sUsbMassStorageEnabled{
false, [](const lua::LuaValue& val) {
@@ -557,14 +565,18 @@ void Lua::entry() {
"time", {
{"ticks", [&](lua_State* s) { return Ticks(s); }},
});
- registry.AddPropertyModule("database", {
- {"updating", &sDatabaseUpdating},
- });
+ registry.AddPropertyModule("database",
+ {
+ {"updating", &sDatabaseUpdating},
+ {"auto_update", &sDatabaseAutoUpdate},
+ });
registry.AddPropertyModule("usb",
{
{"msc_enabled", &sUsbMassStorageEnabled},
});
+ sDatabaseAutoUpdate.Update(sServices->nvs().DbAutoIndex());
+
auto bt = sServices->bluetooth();
sBluetoothEnabled.Update(bt.IsEnabled());
sBluetoothConnected.Update(bt.IsConnected());