summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorSunny Goyal <sunnygoyal@google.com>2016-09-02 19:14:38 +0000
committerAndroid (Google) Code Review <android-gerrit@google.com>2016-09-02 19:14:39 +0000
commitdbbb1fee90b9bbb6a9c271eb9739804cf7d8a6f3 (patch)
tree2f01dbd08b2b5eaaa6079a2acbfd0aff955f10df /src
parentd9033f3ae118f928d90dacd03e37d04489a8f6e5 (diff)
parent6f2bb1ada5a68da74ad29d135fa32ec45b234dba (diff)
downloadandroid_packages_apps_Trebuchet-dbbb1fee90b9bbb6a9c271eb9739804cf7d8a6f3.tar.gz
android_packages_apps_Trebuchet-dbbb1fee90b9bbb6a9c271eb9739804cf7d8a6f3.tar.bz2
android_packages_apps_Trebuchet-dbbb1fee90b9bbb6a9c271eb9739804cf7d8a6f3.zip
Merge "Bug fix in Alarm where it was not getting called correctly if the new timeout was set that was smaller than the previously set timeout" into ub-launcher3-calgary
Diffstat (limited to 'src')
-rw-r--r--src/com/android/launcher3/Alarm.java15
1 files changed, 11 insertions, 4 deletions
diff --git a/src/com/android/launcher3/Alarm.java b/src/com/android/launcher3/Alarm.java
index e9f1fd963..d5b434c64 100644
--- a/src/com/android/launcher3/Alarm.java
+++ b/src/com/android/launcher3/Alarm.java
@@ -17,6 +17,7 @@
package com.android.launcher3;
import android.os.Handler;
+import android.os.SystemClock;
public class Alarm implements Runnable{
// if we reach this time and the alarm hasn't been cancelled, call the listener
@@ -41,9 +42,16 @@ public class Alarm implements Runnable{
// Sets the alarm to go off in a certain number of milliseconds. If the alarm is already set,
// it's overwritten and only the new alarm setting is used
public void setAlarm(long millisecondsInFuture) {
- long currentTime = System.currentTimeMillis();
+ long currentTime = SystemClock.uptimeMillis();
mAlarmPending = true;
+ long oldTriggerTime = mAlarmTriggerTime;
mAlarmTriggerTime = currentTime + millisecondsInFuture;
+
+ // If the previous alarm was set for a longer duration, cancel it.
+ if (mWaitingForCallback && oldTriggerTime > mAlarmTriggerTime) {
+ mHandler.removeCallbacks(this);
+ mWaitingForCallback = false;
+ }
if (!mWaitingForCallback) {
mHandler.postDelayed(this, mAlarmTriggerTime - currentTime);
mWaitingForCallback = true;
@@ -51,15 +59,14 @@ public class Alarm implements Runnable{
}
public void cancelAlarm() {
- mAlarmTriggerTime = 0;
mAlarmPending = false;
}
// this is called when our timer runs out
public void run() {
mWaitingForCallback = false;
- if (mAlarmTriggerTime != 0) {
- long currentTime = System.currentTimeMillis();
+ if (mAlarmPending) {
+ long currentTime = SystemClock.uptimeMillis();
if (mAlarmTriggerTime > currentTime) {
// We still need to wait some time to trigger spring loaded mode--
// post a new callback