LevelMeter-Display  2.0
An ultrasonic Level Meter for Stormwater Cisterns
Data Structures | Macros | Enumerations | Functions | Variables
config.h File Reference

Structures and Constants for Configuration Handling. More...

Include dependency graph for config.h:
This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Data Structures

struct  confStruct_t
 Holds all Configuration Data stored in EEPROM. More...
 
struct  signalOutput_t
 Holds the Thresholds for a Signal Optocoupler Output. More...
 

Macros

#define CONF_MAGIC   0x3797
 Change this value if confStruct_t becomes incompatible to previous versions! More...
 
#define NUM_SIGNAL   2
 Number of available signal outputs. More...
 
#define SNDMASK_ALERT1ALWAYS   1
 Signal 2 Alert is played outside silent period, too. More...
 
#define SNDMASK_ALERT2ALWAYS   2
 Signal 1 Alert is played outside silent period, too. More...
 
#define SNDMASK_HOURBELL   4
 Big Ben is played every hour. More...
 

Enumerations

enum  cisternType_T { CIST_CONST_AREA, CIST_HORIZ_CYL, CIST_SPHERE }
 

Functions

void DumpConfig (void)
 Lists the current configuration values. More...
 
void DumpConfigSignal (uint8_t number)
 DumpConfig Helper Function for Optocoupler outputs. More...
 
void ReadConfig (void)
 Reads the Config-Struct from EEPROM into config. More...
 
bool SoundsOK (void)
 Checks if sounds may currently be played. More...
 
void WriteConfig (void)
 Writes the Config-Struct to EEPROM. More...
 

Variables

confStruct_t config
 The Configuration. It is read on startup from the EEPROM. More...
 
bool configDirty
 Set to true by routines affecting configuration if config memory needs to be saved to the EEPROM. More...
 

Detailed Description

Structures and Constants for Configuration Handling.

This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program. If not, see http://www.gnu.org/licenses/.

Macro Definition Documentation

◆ CONF_MAGIC

#define CONF_MAGIC   0x3797

Change this value if confStruct_t becomes incompatible to previous versions!

◆ NUM_SIGNAL

#define NUM_SIGNAL   2

Number of available signal outputs.

◆ SNDMASK_ALERT1ALWAYS

#define SNDMASK_ALERT1ALWAYS   1

Signal 2 Alert is played outside silent period, too.

◆ SNDMASK_ALERT2ALWAYS

#define SNDMASK_ALERT2ALWAYS   2

Signal 1 Alert is played outside silent period, too.

◆ SNDMASK_HOURBELL

#define SNDMASK_HOURBELL   4

Big Ben is played every hour.

Enumeration Type Documentation

◆ cisternType_T

Enumerator
CIST_CONST_AREA 

Cistern with constant area over volume.

CIST_HORIZ_CYL 

Cistern of horizontal cylinder type.

CIST_SPHERE 

Spherical cistern.

Function Documentation

◆ DumpConfig()

void DumpConfig ( void  )

◆ DumpConfigSignal()

void DumpConfigSignal ( uint8_t  number)

DumpConfig Helper Function for Optocoupler outputs.

Parameters
numberThe Number of the Signal Output (Zero-based)

References signalOutput_t::activeAbove, signalOutput_t::activeBelow, config, hprintf_P(), and confStruct_t::signalOutputs.

Referenced by CmdSetSignal(), and DumpConfig().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ ReadConfig()

void ReadConfig ( void  )

Reads the Config-Struct from EEPROM into config.

Only the config-struct in RAM will be used. Changes in config will only become permanent if you use a write-command. There is a configDirty-flag that is set by every routine that changes config and is used to remind the user to execute a write-command.

References CONF_MAGIC, config, configDirty, defaultConfig, DefaultConfig(), and confStruct_t::magic.

Referenced by Init().

Here is the call graph for this function:
Here is the caller graph for this function:

◆ SoundsOK()

bool SoundsOK ( void  )

Checks if sounds may currently be played.

"Currently" means at the actual time-of-day. Check this function before you play sounds that should not be always enabled.

Returns
true if sounds are ok, false if not

References config, hrCnt, confStruct_t::sndHourFrom, and confStruct_t::sndHourTo.

Referenced by DoTflags().

Here is the caller graph for this function:

◆ WriteConfig()

void WriteConfig ( void  )

Writes the Config-Struct to EEPROM.

References config, configDirty, and defaultConfig.

Referenced by CmdWrite(), and DefaultConfig().

Here is the caller graph for this function:

Variable Documentation

◆ config

confStruct_t config

◆ configDirty

bool configDirty

Set to true by routines affecting configuration if config memory needs to be saved to the EEPROM.

Referenced by CmdCalibrate(), CmdSetBright(), CmdSetCistern(), CmdSetContrast(), CmdSetDCFInv(), CmdSetDisplay(), CmdSetPTime(), CmdSetPTimeK(), CmdSetSignal(), CmdSetSounds(), CmdSetSpontaneous(), CmdUseRts(), CmdWrite(), ExecCommand(), ReadConfig(), and WriteConfig().