Disable “disappearing messages” job when inactive.

// FREEBIE
pull/1/head
Matthew Chen 9 years ago
parent 6e52009ff0
commit c89b9fb0bf

@ -52,9 +52,23 @@ NS_ASSUME_NONNULL_BEGIN
OWSSingletonAssert(); OWSSingletonAssert();
[[NSNotificationCenter defaultCenter] addObserver:self
selector:@selector(applicationDidBecomeActive:)
name:UIApplicationDidBecomeActiveNotification
object:nil];
[[NSNotificationCenter defaultCenter] addObserver:self
selector:@selector(applicationWillResignActive:)
name:UIApplicationWillResignActiveNotification
object:nil];
return self; return self;
} }
- (void)dealloc
{
[[NSNotificationCenter defaultCenter] removeObserver:self];
}
+ (dispatch_queue_t)serialQueue + (dispatch_queue_t)serialQueue
{ {
static dispatch_queue_t queue = nil; static dispatch_queue_t queue = nil;
@ -260,11 +274,16 @@ NS_ASSUME_NONNULL_BEGIN
{ {
OWSAssert(date); OWSAssert(date);
NSDateFormatter *dateFormatter = [NSDateFormatter new];
dateFormatter.dateStyle = NSDateFormatterShortStyle;
dateFormatter.timeStyle = kCFDateFormatterMediumStyle;
dispatch_async(dispatch_get_main_queue(), ^{ dispatch_async(dispatch_get_main_queue(), ^{
if ([UIApplication sharedApplication].applicationState != UIApplicationStateActive) {
// Don't schedule run when inactive.
return;
}
NSDateFormatter *dateFormatter = [NSDateFormatter new];
dateFormatter.dateStyle = NSDateFormatterNoStyle;
dateFormatter.timeStyle = kCFDateFormatterMediumStyle;
// Don't run more often than once per second. // Don't run more often than once per second.
const NSTimeInterval kMinDelaySeconds = ignoreMinDelay ? 0.f : 1.f; const NSTimeInterval kMinDelaySeconds = ignoreMinDelay ? 0.f : 1.f;
// Don't run less often than once per N minutes. // Don't run less often than once per N minutes.
@ -283,15 +302,12 @@ NS_ASSUME_NONNULL_BEGIN
} }
// Update Schedule // Update Schedule
NSDateFormatter *dateFormatter = [NSDateFormatter new];
dateFormatter.dateStyle = NSDateFormatterShortStyle;
dateFormatter.timeStyle = kCFDateFormatterMediumStyle;
DDLogVerbose(@"%@ Scheduled run at %@ (%d sec.)", DDLogVerbose(@"%@ Scheduled run at %@ (%d sec.)",
self.tag, self.tag,
[dateFormatter stringFromDate:timerScheduleDate], [dateFormatter stringFromDate:timerScheduleDate],
(int)round(MAX(0, [timerScheduleDate timeIntervalSinceDate:[NSDate new]]))); (int)round(MAX(0, [timerScheduleDate timeIntervalSinceDate:[NSDate new]])));
[self resetTimer];
self.timerScheduleDate = timerScheduleDate; self.timerScheduleDate = timerScheduleDate;
[self.timer invalidate];
self.timer = [NSTimer weakScheduledTimerWithTimeInterval:delaySeconds self.timer = [NSTimer weakScheduledTimerWithTimeInterval:delaySeconds
target:self target:self
selector:@selector(timerDidFire) selector:@selector(timerDidFire)
@ -302,15 +318,46 @@ NS_ASSUME_NONNULL_BEGIN
- (void)timerDidFire - (void)timerDidFire
{ {
[self.timer invalidate]; OWSAssert([NSThread isMainThread]);
self.timer = nil;
self.timerScheduleDate = nil; if ([UIApplication sharedApplication].applicationState != UIApplicationStateActive) {
// Don't run when inactive.
OWSAssert(0);
return;
}
[self resetTimer];
dispatch_async(OWSDisappearingMessagesJob.serialQueue, ^{ dispatch_async(OWSDisappearingMessagesJob.serialQueue, ^{
[self runLoop]; [self runLoop];
}); });
} }
- (void)resetTimer
{
OWSAssert([NSThread isMainThread]);
[self.timer invalidate];
self.timer = nil;
self.timerScheduleDate = nil;
}
#pragma mark - Notifications
- (void)applicationDidBecomeActive:(NSNotification *)notification
{
OWSAssert([NSThread isMainThread]);
[self runNow];
}
- (void)applicationWillResignActive:(NSNotification *)notification
{
OWSAssert([NSThread isMainThread]);
[self resetTimer];
}
#pragma mark - Logging #pragma mark - Logging
+ (NSString *)tag + (NSString *)tag

Loading…
Cancel
Save