From a11929d2ca68f19ed45790612a5ff764d2ba519a Mon Sep 17 00:00:00 2001 From: Mark Thompson <129641948+NotherNgineer@users.noreply.github.com> Date: Mon, 30 Oct 2023 05:32:01 -0500 Subject: [PATCH] Preallocate enough vectors for common app settings #1535 --- firmware/application/app_settings.cpp | 2 +- firmware/application/app_settings.hpp | 4 +++- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/firmware/application/app_settings.cpp b/firmware/application/app_settings.cpp index 3b99b926..8bdb1bdc 100644 --- a/firmware/application/app_settings.cpp +++ b/firmware/application/app_settings.cpp @@ -250,7 +250,7 @@ SettingsManager::SettingsManager( settings_.options = options; // Pre-alloc enough for app settings and additional settings. - additional_settings.reserve(17 + additional_settings.size()); + additional_settings.reserve(COMMON_APP_SETTINGS_COUNT + additional_settings.size()); bindings_ = std::move(additional_settings); // Settings should always be loaded because apps now rely diff --git a/firmware/application/app_settings.hpp b/firmware/application/app_settings.hpp index 1dc58b2e..b06a5921 100644 --- a/firmware/application/app_settings.hpp +++ b/firmware/application/app_settings.hpp @@ -42,6 +42,8 @@ // Bring in the string_view literal. using std::literals::operator""sv; +#define COMMON_APP_SETTINGS_COUNT 19 + /* Represents a named setting bound to a variable instance. */ /* Using void* instead of std::variant, because variant is a pain to dispatch over. */ class BoundSetting { @@ -143,8 +145,8 @@ struct AppSettings { uint8_t nbfm_config_index = 0; uint8_t wfm_config_index = 0; uint8_t squelch = 80; - uint8_t volume; + // NOTE: update COMMON_APP_SETTINGS_COUNT when adding to this }; /* Copies common values to the receiver/transmitter models. */