mirror of
https://github.com/oliverschmidt/contiki.git
synced 2025-01-02 19:29:30 +00:00
[doc] updated settings manager documentation
This commit is contained in:
parent
548321e66d
commit
e4db33f560
@ -36,10 +36,14 @@
|
|||||||
/** @file settings.h
|
/** @file settings.h
|
||||||
* @brief Settings Manager
|
* @brief Settings Manager
|
||||||
* @author Robert Quattlebaum <darco@deepdarc.com>
|
* @author Robert Quattlebaum <darco@deepdarc.com>
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** @addtogroup lib
|
||||||
|
* @{ */
|
||||||
|
|
||||||
|
/** @defgroup settings_lib Settings Manager
|
||||||
*
|
*
|
||||||
* ## Overview ##
|
* The settings manager is an EEPROM-based key-value store. Keys
|
||||||
*
|
|
||||||
* The settings manager is a EEPROM-based key-value store. Keys
|
|
||||||
* are 16-bit integers and values may be up to 16,383 bytes long.
|
* are 16-bit integers and values may be up to 16,383 bytes long.
|
||||||
* It is intended to be used to store configuration-related information,
|
* It is intended to be used to store configuration-related information,
|
||||||
* like network settings, radio channels, etc.
|
* like network settings, radio channels, etc.
|
||||||
@ -64,37 +68,13 @@
|
|||||||
* EEPROM.
|
* EEPROM.
|
||||||
*
|
*
|
||||||
* Each key-value pair is stored in memory in the following format:
|
* Each key-value pair is stored in memory in the following format:
|
||||||
* <table>
|
*
|
||||||
* <thead>
|
* | Order | Size | Name | Description |
|
||||||
* <td>Order</td>
|
* | -------- | -------- | ---------- | ------------------------------- |
|
||||||
* <td>Size<small> (in bytes)</small></td>
|
* | 0 | 2 | key | |
|
||||||
* <td>Name</td>
|
* | -2 | 1 | size_check | One's-complement of next byte |
|
||||||
* <td>Description</td>
|
* | -3 | 1 or 2 | size | The size of the value, in bytes |
|
||||||
* </thead>
|
* | -4 or -5 | variable | value | |
|
||||||
* <tr>
|
|
||||||
* <td>0</td>
|
|
||||||
* <td>2</td>
|
|
||||||
* <td>key</td>
|
|
||||||
* <td></td>
|
|
||||||
* </tr>
|
|
||||||
* <tr>
|
|
||||||
* <td>-2</td>
|
|
||||||
* <td>1</td>
|
|
||||||
* <td>size_check</td>
|
|
||||||
* <td>One's-complement of next byte</td>
|
|
||||||
* </tr>
|
|
||||||
* <tr>
|
|
||||||
* <td>-3</td>
|
|
||||||
* <td>1 or 2</td>
|
|
||||||
* <td>size</td>
|
|
||||||
* <td>The size of the value, in bytes.</td>
|
|
||||||
* </tr>
|
|
||||||
* <tr>
|
|
||||||
* <td>-4 or -5</td>
|
|
||||||
* <td>variable</td>
|
|
||||||
* <td>value</td>
|
|
||||||
* </tr>
|
|
||||||
* </table>
|
|
||||||
*
|
*
|
||||||
* The end of the key-value pairs is denoted by the first invalid entry.
|
* The end of the key-value pairs is denoted by the first invalid entry.
|
||||||
* An invalid entry has any of the following attributes:
|
* An invalid entry has any of the following attributes:
|
||||||
@ -103,7 +83,7 @@
|
|||||||
* of the size byte (or size_low byte).
|
* of the size byte (or size_low byte).
|
||||||
* * The key has a value of 0x0000.
|
* * The key has a value of 0x0000.
|
||||||
*
|
*
|
||||||
*/
|
* @{ */
|
||||||
|
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
@ -156,9 +136,9 @@ typedef uint16_t settings_length_t;
|
|||||||
|
|
||||||
/** Use this when you want to retrieve the last item */
|
/** Use this when you want to retrieve the last item */
|
||||||
#define SETTINGS_LAST_INDEX 0xFF
|
#define SETTINGS_LAST_INDEX 0xFF
|
||||||
|
/** Returned when key is invalid. */
|
||||||
#define SETTINGS_INVALID_KEY 0xFFFF
|
#define SETTINGS_INVALID_KEY 0xFFFF
|
||||||
|
/** Returned if no (further) element was found. */
|
||||||
#define SETTINGS_INVALID_ITER EEPROM_NULL
|
#define SETTINGS_INVALID_ITER EEPROM_NULL
|
||||||
|
|
||||||
#ifndef SETTINGS_CONF_SUPPORT_LARGE_VALUES
|
#ifndef SETTINGS_CONF_SUPPORT_LARGE_VALUES
|
||||||
@ -205,10 +185,10 @@ extern settings_status_t settings_delete(settings_key_t key, uint8_t index);
|
|||||||
|
|
||||||
typedef eeprom_addr_t settings_iter_t;
|
typedef eeprom_addr_t settings_iter_t;
|
||||||
|
|
||||||
/** Will return extern SETTINGS_INVALID_ITER if the settings store is empty. */
|
/** Will return \ref SETTINGS_INVALID_ITER if the settings store is empty. */
|
||||||
extern settings_iter_t settings_iter_begin();
|
extern settings_iter_t settings_iter_begin();
|
||||||
|
|
||||||
/** Will return extern SETTINGS_INVALID_ITER if at the end of settings list. */
|
/** Will return \ref SETTINGS_INVALID_ITER if at the end of settings list. */
|
||||||
extern settings_iter_t settings_iter_next(settings_iter_t iter);
|
extern settings_iter_t settings_iter_next(settings_iter_t iter);
|
||||||
|
|
||||||
extern uint8_t settings_iter_is_valid(settings_iter_t iter);
|
extern uint8_t settings_iter_is_valid(settings_iter_t iter);
|
||||||
@ -367,3 +347,6 @@ settings_set_uint64(settings_key_t key, uint64_t value)
|
|||||||
#endif /* !SETTINGS_CONF_SKIP_CONVENIENCE_FUNCS */
|
#endif /* !SETTINGS_CONF_SKIP_CONVENIENCE_FUNCS */
|
||||||
|
|
||||||
#endif /* !defined(CONTIKI_SETTINGS_H_) */
|
#endif /* !defined(CONTIKI_SETTINGS_H_) */
|
||||||
|
|
||||||
|
/** @} */
|
||||||
|
/** @} */
|
||||||
|
Loading…
Reference in New Issue
Block a user