mirror of
https://github.com/esphome/esphome.git
synced 2025-09-17 18:52:19 +01:00
Merge branch 'libretiny_vector_prefs' into integration
This commit is contained in:
@@ -15,7 +15,14 @@ static const char *const TAG = "lt.preferences";
|
|||||||
|
|
||||||
struct NVSData {
|
struct NVSData {
|
||||||
std::string key;
|
std::string key;
|
||||||
std::vector<uint8_t> data;
|
std::unique_ptr<uint8_t[]> data;
|
||||||
|
size_t len;
|
||||||
|
|
||||||
|
void set_data(const uint8_t *src, size_t size) {
|
||||||
|
data = std::make_unique<uint8_t[]>(size);
|
||||||
|
memcpy(data.get(), src, size);
|
||||||
|
len = size;
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
static std::vector<NVSData> s_pending_save; // NOLINT(cppcoreguidelines-avoid-non-const-global-variables)
|
static std::vector<NVSData> s_pending_save; // NOLINT(cppcoreguidelines-avoid-non-const-global-variables)
|
||||||
@@ -30,15 +37,15 @@ class LibreTinyPreferenceBackend : public ESPPreferenceBackend {
|
|||||||
// try find in pending saves and update that
|
// try find in pending saves and update that
|
||||||
for (auto &obj : s_pending_save) {
|
for (auto &obj : s_pending_save) {
|
||||||
if (obj.key == key) {
|
if (obj.key == key) {
|
||||||
obj.data.assign(data, data + len);
|
obj.set_data(data, len);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
NVSData save{};
|
NVSData save{};
|
||||||
save.key = key;
|
save.key = key;
|
||||||
save.data.assign(data, data + len);
|
save.set_data(data, len);
|
||||||
s_pending_save.emplace_back(save);
|
s_pending_save.emplace_back(std::move(save));
|
||||||
ESP_LOGVV(TAG, "s_pending_save: key: %s, len: %d", key.c_str(), len);
|
ESP_LOGVV(TAG, "s_pending_save: key: %s, len: %zu", key.c_str(), len);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -46,11 +53,11 @@ class LibreTinyPreferenceBackend : public ESPPreferenceBackend {
|
|||||||
// try find in pending saves and load from that
|
// try find in pending saves and load from that
|
||||||
for (auto &obj : s_pending_save) {
|
for (auto &obj : s_pending_save) {
|
||||||
if (obj.key == key) {
|
if (obj.key == key) {
|
||||||
if (obj.data.size() != len) {
|
if (obj.len != len) {
|
||||||
// size mismatch
|
// size mismatch
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
memcpy(data, obj.data.data(), len);
|
memcpy(data, obj.data.get(), len);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -58,10 +65,10 @@ class LibreTinyPreferenceBackend : public ESPPreferenceBackend {
|
|||||||
fdb_blob_make(blob, data, len);
|
fdb_blob_make(blob, data, len);
|
||||||
size_t actual_len = fdb_kv_get_blob(db, key.c_str(), blob);
|
size_t actual_len = fdb_kv_get_blob(db, key.c_str(), blob);
|
||||||
if (actual_len != len) {
|
if (actual_len != len) {
|
||||||
ESP_LOGVV(TAG, "NVS length does not match (%u!=%u)", actual_len, len);
|
ESP_LOGVV(TAG, "NVS length does not match (%zu!=%zu)", actual_len, len);
|
||||||
return false;
|
return false;
|
||||||
} else {
|
} else {
|
||||||
ESP_LOGVV(TAG, "fdb_kv_get_blob: key: %s, len: %d", key.c_str(), len);
|
ESP_LOGVV(TAG, "fdb_kv_get_blob: key: %s, len: %zu", key.c_str(), len);
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@@ -101,7 +108,7 @@ class LibreTinyPreferences : public ESPPreferences {
|
|||||||
if (s_pending_save.empty())
|
if (s_pending_save.empty())
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
ESP_LOGV(TAG, "Saving %d items...", s_pending_save.size());
|
ESP_LOGV(TAG, "Saving %zu items...", s_pending_save.size());
|
||||||
// goal try write all pending saves even if one fails
|
// goal try write all pending saves even if one fails
|
||||||
int cached = 0, written = 0, failed = 0;
|
int cached = 0, written = 0, failed = 0;
|
||||||
fdb_err_t last_err = FDB_NO_ERR;
|
fdb_err_t last_err = FDB_NO_ERR;
|
||||||
@@ -112,11 +119,11 @@ class LibreTinyPreferences : public ESPPreferences {
|
|||||||
const auto &save = s_pending_save[i];
|
const auto &save = s_pending_save[i];
|
||||||
ESP_LOGVV(TAG, "Checking if FDB data %s has changed", save.key.c_str());
|
ESP_LOGVV(TAG, "Checking if FDB data %s has changed", save.key.c_str());
|
||||||
if (is_changed(&db, save)) {
|
if (is_changed(&db, save)) {
|
||||||
ESP_LOGV(TAG, "sync: key: %s, len: %d", save.key.c_str(), save.data.size());
|
ESP_LOGV(TAG, "sync: key: %s, len: %zu", save.key.c_str(), save.len);
|
||||||
fdb_blob_make(&blob, save.data.data(), save.data.size());
|
fdb_blob_make(&blob, save.data.get(), save.len);
|
||||||
fdb_err_t err = fdb_kv_set_blob(&db, save.key.c_str(), &blob);
|
fdb_err_t err = fdb_kv_set_blob(&db, save.key.c_str(), &blob);
|
||||||
if (err != FDB_NO_ERR) {
|
if (err != FDB_NO_ERR) {
|
||||||
ESP_LOGV(TAG, "fdb_kv_set_blob('%s', len=%u) failed: %d", save.key.c_str(), save.data.size(), err);
|
ESP_LOGV(TAG, "fdb_kv_set_blob('%s', len=%zu) failed: %d", save.key.c_str(), save.len, err);
|
||||||
failed++;
|
failed++;
|
||||||
last_err = err;
|
last_err = err;
|
||||||
last_key = save.key;
|
last_key = save.key;
|
||||||
@@ -124,7 +131,7 @@ class LibreTinyPreferences : public ESPPreferences {
|
|||||||
}
|
}
|
||||||
written++;
|
written++;
|
||||||
} else {
|
} else {
|
||||||
ESP_LOGD(TAG, "FDB data not changed; skipping %s len=%u", save.key.c_str(), save.data.size());
|
ESP_LOGD(TAG, "FDB data not changed; skipping %s len=%zu", save.key.c_str(), save.len);
|
||||||
cached++;
|
cached++;
|
||||||
}
|
}
|
||||||
s_pending_save.erase(s_pending_save.begin() + i);
|
s_pending_save.erase(s_pending_save.begin() + i);
|
||||||
@@ -147,7 +154,7 @@ class LibreTinyPreferences : public ESPPreferences {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Check size first - if different, data has changed
|
// Check size first - if different, data has changed
|
||||||
if (kv.value_len != to_save.data.size()) {
|
if (kv.value_len != to_save.len) {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -161,7 +168,7 @@ class LibreTinyPreferences : public ESPPreferences {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Compare the actual data
|
// Compare the actual data
|
||||||
return memcmp(to_save.data.data(), stored_data.get(), kv.value_len) != 0;
|
return memcmp(to_save.data.get(), stored_data.get(), kv.value_len) != 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool reset() override {
|
bool reset() override {
|
||||||
|
Reference in New Issue
Block a user