diff options
| author | Selene ToyKeeper | 2020-07-30 03:25:45 -0600 |
|---|---|---|
| committer | Selene ToyKeeper | 2020-07-30 03:25:45 -0600 |
| commit | da2e70747481a89a70eaeda1a494a99a7aaf8c94 (patch) | |
| tree | 75e64b64da4bbf286a56a7dbf60f12464e4f9797 /spaghetti-monster | |
| parent | fixed bug where light would shut itself off immediately if sunset timer was a... (diff) | |
| download | anduril-da2e70747481a89a70eaeda1a494a99a7aaf8c94.tar.gz anduril-da2e70747481a89a70eaeda1a494a99a7aaf8c94.tar.bz2 anduril-da2e70747481a89a70eaeda1a494a99a7aaf8c94.zip | |
fixed bug: ramp mode acted strange if ramp level was changed after turning on sunset timer
(it kept trying to adjust based on the original brightness, instead of the new brightness)
Diffstat (limited to 'spaghetti-monster')
| -rw-r--r-- | spaghetti-monster/anduril/ramp-mode.c | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/spaghetti-monster/anduril/ramp-mode.c b/spaghetti-monster/anduril/ramp-mode.c index a0a123d..5ca5dbb 100644 --- a/spaghetti-monster/anduril/ramp-mode.c +++ b/spaghetti-monster/anduril/ramp-mode.c @@ -21,6 +21,7 @@ #define RAMP_MODE_C #include "ramp-mode.h" + #ifdef USE_SUNSET_TIMER #include "sunset-timer.h" #endif @@ -117,6 +118,9 @@ uint8_t steady_state(Event event, uint16_t arg) { else { set_level_and_therm_target(memorized_level); } + #ifdef USE_SUNSET_TIMER + timer_orig_level = actual_level; + #endif return MISCHIEF_MANAGED; } // hold: change brightness (brighter) @@ -185,6 +189,9 @@ uint8_t steady_state(Event event, uint16_t arg) { } #endif set_level_and_therm_target(memorized_level); + #ifdef USE_SUNSET_TIMER + timer_orig_level = actual_level; + #endif return MISCHIEF_MANAGED; } #if defined(USE_REVERSING) || defined(START_AT_MEMORIZED_LEVEL) @@ -242,6 +249,9 @@ uint8_t steady_state(Event event, uint16_t arg) { } #endif set_level_and_therm_target(memorized_level); + #ifdef USE_SUNSET_TIMER + timer_orig_level = actual_level; + #endif return MISCHIEF_MANAGED; } #ifdef START_AT_MEMORIZED_LEVEL @@ -381,6 +391,9 @@ uint8_t steady_state(Event event, uint16_t arg) { blip(); memorized_level = nearest_level(actual_level); set_level_and_therm_target(memorized_level); + #ifdef USE_SUNSET_TIMER + timer_orig_level = actual_level; + #endif return MISCHIEF_MANAGED; } |
