diff options
| -rw-r--r-- | src/components/alarm/AlarmController.cpp | 13 | ||||
| -rw-r--r-- | src/systemtask/SystemTask.cpp | 2 |
2 files changed, 14 insertions, 1 deletions
diff --git a/src/components/alarm/AlarmController.cpp b/src/components/alarm/AlarmController.cpp index 28b328d..89ed689 100644 --- a/src/components/alarm/AlarmController.cpp +++ b/src/components/alarm/AlarmController.cpp @@ -48,6 +48,19 @@ void AlarmController::SetAlarmTime(uint8_t alarmHr, uint8_t alarmMin) { minutes = alarmMin; } +void AlarmController::RescheduleAlarm() { + + app_timer_stop(alarmAppTimer); + auto now = dateTimeController.CurrentDateTime(); + alarmTime = now; + auto mSecToAlarm = std::chrono::duration_cast<std::chrono::milliseconds>(alarmTime - now).count(); + + if (mSecToAlarm < 0) { mSecToAlarm = 0; } + + app_timer_start(alarmAppTimer, APP_TIMER_TICKS(mSecToAlarm), this); + +} + void AlarmController::ScheduleAlarm() { // Determine the next time the alarm needs to go off and set the app_timer app_timer_stop(alarmAppTimer); diff --git a/src/systemtask/SystemTask.cpp b/src/systemtask/SystemTask.cpp index 3e4f8f6..2ab7fd3 100644 --- a/src/systemtask/SystemTask.cpp +++ b/src/systemtask/SystemTask.cpp @@ -295,7 +295,7 @@ void SystemTask::Work() { ReloadIdleTimer(); displayApp.PushMessage(Pinetime::Applications::Display::Messages::UpdateDateTime); if (alarmController.State() == Controllers::AlarmController::AlarmState::Set) { - alarmController.ScheduleAlarm(); + alarmController.RescheduleAlarm(); } break; case Messages::OnNewNotification: |
