summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/components/alarm/AlarmController.cpp13
-rw-r--r--src/systemtask/SystemTask.cpp2
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: