Persistent Settings / Config storage library for Arduino framework on ESP32 / ESP8266 devices, using the NVS partition.
Config object / settings are stored as a CRC16 protected byte array within the NVS partition of the device's flash. The config object can be any structure or class object, but must initialize its members to default values. The constructor requires a non-zero version identifier, which should be change if the data layout of the config object is changed. It's recommended this identifier by "built-into" the config object, as a static constant, if only to "co-locate" it with the object definition.
When reading the config object from the persistent storage, the following checks are performed on the data. If any check fails, the config object is reset to the default values.
- Persistent NVS name space is not initialized (i.e. no config has previously been stored)
- The version does not match the expected version
- The size of the object read does not match the template object provided
- The CRC16 indicates an error in the data
- Define an object to use as the config, with default values.
- Construct the PersistSettings object using the config as a template.
- Call the Begin() method to read the config from the NVS.
- Access / update the config values through the Config member of PersistSettings.
- Use the Write() method to save any changes to the Config member values.
- Use the ResetToDefault() method to reset (and write) the defauls back to NVS.
- examples/simple_config - Stores a simple configuration struct to the NVS, that contains an integer value. That value is incremented and stored each time the platform is reset.