TimerCycle.smali
.class public Lcom/adjust/sdk/TimerCycle;
.super Ljava/lang/Object;
.source "TimerCycle.java"
# instance fields
.field private command:Ljava/lang/Runnable;
.field private cycleDelay:J
.field private cycleDelaySeconds:Ljava/lang/String;
.field private initialDelay:J
.field private isPaused:Z
.field private logger:Lcom/adjust/sdk/ILogger;
.field private name:Ljava/lang/String;
.field private scheduler:Ljava/util/concurrent/ScheduledExecutorService;
.field private waitingTask:Ljava/util/concurrent/ScheduledFuture;
# direct methods
.method public constructor <init>(Ljava/lang/Runnable;JJLjava/lang/String;)V
.registers 8
.line 22
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 23
invoke-static {}, Ljava/util/concurrent/Executors;->newSingleThreadScheduledExecutor()Ljava/util/concurrent/ScheduledExecutorService;
move-result-object v0
iput-object v0, p0, Lcom/adjust/sdk/TimerCycle;->scheduler:Ljava/util/concurrent/ScheduledExecutorService;
.line 25
iput-object p6, p0, Lcom/adjust/sdk/TimerCycle;->name:Ljava/lang/String;
.line 26
iput-object p1, p0, Lcom/adjust/sdk/TimerCycle;->command:Ljava/lang/Runnable;
.line 27
iput-wide p2, p0, Lcom/adjust/sdk/TimerCycle;->initialDelay:J
.line 28
iput-wide p4, p0, Lcom/adjust/sdk/TimerCycle;->cycleDelay:J
const/4 p1, 0x1
.line 29
iput-boolean p1, p0, Lcom/adjust/sdk/TimerCycle;->isPaused:Z
.line 30
invoke-static {}, Lcom/adjust/sdk/AdjustFactory;->getLogger()Lcom/adjust/sdk/ILogger;
move-result-object p1
iput-object p1, p0, Lcom/adjust/sdk/TimerCycle;->logger:Lcom/adjust/sdk/ILogger;
.line 32
sget-object p1, Lcom/adjust/sdk/Util;->SecondsDisplayFormat:Ljava/text/DecimalFormat;
long-to-double p2, p4
const-wide p4, 0x408f400000000000L # 1000.0
div-double/2addr p2, p4
invoke-virtual {p1, p2, p3}, Ljava/text/DecimalFormat;->format(D)Ljava/lang/String;
move-result-object p1
iput-object p1, p0, Lcom/adjust/sdk/TimerCycle;->cycleDelaySeconds:Ljava/lang/String;
return-void
.end method
.method static synthetic access$000(Lcom/adjust/sdk/TimerCycle;)Ljava/lang/String;
.registers 1
.line 11
iget-object p0, p0, Lcom/adjust/sdk/TimerCycle;->name:Ljava/lang/String;
return-object p0
.end method
.method static synthetic access$100(Lcom/adjust/sdk/TimerCycle;)Lcom/adjust/sdk/ILogger;
.registers 1
.line 11
iget-object p0, p0, Lcom/adjust/sdk/TimerCycle;->logger:Lcom/adjust/sdk/ILogger;
return-object p0
.end method
.method static synthetic access$200(Lcom/adjust/sdk/TimerCycle;)Ljava/lang/Runnable;
.registers 1
.line 11
iget-object p0, p0, Lcom/adjust/sdk/TimerCycle;->command:Ljava/lang/Runnable;
return-object p0
.end method
# virtual methods
.method public start()V
.registers 13
.line 36
iget-boolean v0, p0, Lcom/adjust/sdk/TimerCycle;->isPaused:Z
const/4 v1, 0x1
const/4 v2, 0x0
if-nez v0, :cond_14
.line 37
iget-object v0, p0, Lcom/adjust/sdk/TimerCycle;->logger:Lcom/adjust/sdk/ILogger;
new-array v1, v1, [Ljava/lang/Object;
iget-object v3, p0, Lcom/adjust/sdk/TimerCycle;->name:Ljava/lang/String;
aput-object v3, v1, v2
const-string v2, "%s is already started"
invoke-interface {v0, v2, v1}, Lcom/adjust/sdk/ILogger;->verbose(Ljava/lang/String;[Ljava/lang/Object;)V
return-void
.line 41
:cond_14
sget-object v0, Lcom/adjust/sdk/Util;->SecondsDisplayFormat:Ljava/text/DecimalFormat;
iget-wide v3, p0, Lcom/adjust/sdk/TimerCycle;->initialDelay:J
long-to-double v3, v3
const-wide v5, 0x408f400000000000L # 1000.0
div-double/2addr v3, v5
invoke-virtual {v0, v3, v4}, Ljava/text/DecimalFormat;->format(D)Ljava/lang/String;
move-result-object v0
.line 43
iget-object v3, p0, Lcom/adjust/sdk/TimerCycle;->logger:Lcom/adjust/sdk/ILogger;
const/4 v4, 0x3
new-array v4, v4, [Ljava/lang/Object;
iget-object v5, p0, Lcom/adjust/sdk/TimerCycle;->name:Ljava/lang/String;
aput-object v5, v4, v2
aput-object v0, v4, v1
const/4 v0, 0x2
iget-object v1, p0, Lcom/adjust/sdk/TimerCycle;->cycleDelaySeconds:Ljava/lang/String;
aput-object v1, v4, v0
const-string v0, "%s starting in %s seconds and cycle every %s seconds"
invoke-interface {v3, v0, v4}, Lcom/adjust/sdk/ILogger;->verbose(Ljava/lang/String;[Ljava/lang/Object;)V
.line 45
iget-object v5, p0, Lcom/adjust/sdk/TimerCycle;->scheduler:Ljava/util/concurrent/ScheduledExecutorService;
new-instance v6, Lcom/adjust/sdk/TimerCycle$1;
invoke-direct {v6, p0}, Lcom/adjust/sdk/TimerCycle$1;-><init>(Lcom/adjust/sdk/TimerCycle;)V
iget-wide v7, p0, Lcom/adjust/sdk/TimerCycle;->initialDelay:J
iget-wide v9, p0, Lcom/adjust/sdk/TimerCycle;->cycleDelay:J
sget-object v11, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
invoke-interface/range {v5 .. v11}, Ljava/util/concurrent/ScheduledExecutorService;->scheduleWithFixedDelay(Ljava/lang/Runnable;JJLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;
move-result-object v0
iput-object v0, p0, Lcom/adjust/sdk/TimerCycle;->waitingTask:Ljava/util/concurrent/ScheduledFuture;
.line 53
iput-boolean v2, p0, Lcom/adjust/sdk/TimerCycle;->isPaused:Z
return-void
.end method
.method public suspend()V
.registers 8
.line 57
iget-boolean v0, p0, Lcom/adjust/sdk/TimerCycle;->isPaused:Z
const/4 v1, 0x1
const/4 v2, 0x0
if-eqz v0, :cond_14
.line 58
iget-object v0, p0, Lcom/adjust/sdk/TimerCycle;->logger:Lcom/adjust/sdk/ILogger;
new-array v1, v1, [Ljava/lang/Object;
iget-object v3, p0, Lcom/adjust/sdk/TimerCycle;->name:Ljava/lang/String;
aput-object v3, v1, v2
const-string v2, "%s is already suspended"
invoke-interface {v0, v2, v1}, Lcom/adjust/sdk/ILogger;->verbose(Ljava/lang/String;[Ljava/lang/Object;)V
return-void
.line 63
:cond_14
iget-object v0, p0, Lcom/adjust/sdk/TimerCycle;->waitingTask:Ljava/util/concurrent/ScheduledFuture;
sget-object v3, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;
invoke-interface {v0, v3}, Ljava/util/concurrent/ScheduledFuture;->getDelay(Ljava/util/concurrent/TimeUnit;)J
move-result-wide v3
iput-wide v3, p0, Lcom/adjust/sdk/TimerCycle;->initialDelay:J
.line 66
iget-object v0, p0, Lcom/adjust/sdk/TimerCycle;->waitingTask:Ljava/util/concurrent/ScheduledFuture;
invoke-interface {v0, v2}, Ljava/util/concurrent/ScheduledFuture;->cancel(Z)Z
const/4 v0, 0x0
.line 67
iput-object v0, p0, Lcom/adjust/sdk/TimerCycle;->waitingTask:Ljava/util/concurrent/ScheduledFuture;
.line 69
sget-object v0, Lcom/adjust/sdk/Util;->SecondsDisplayFormat:Ljava/text/DecimalFormat;
iget-wide v3, p0, Lcom/adjust/sdk/TimerCycle;->initialDelay:J
long-to-double v3, v3
const-wide v5, 0x408f400000000000L # 1000.0
div-double/2addr v3, v5
invoke-virtual {v0, v3, v4}, Ljava/text/DecimalFormat;->format(D)Ljava/lang/String;
move-result-object v0
.line 71
iget-object v3, p0, Lcom/adjust/sdk/TimerCycle;->logger:Lcom/adjust/sdk/ILogger;
const/4 v4, 0x2
new-array v4, v4, [Ljava/lang/Object;
iget-object v5, p0, Lcom/adjust/sdk/TimerCycle;->name:Ljava/lang/String;
aput-object v5, v4, v2
aput-object v0, v4, v1
const-string v0, "%s suspended with %s seconds left"
invoke-interface {v3, v0, v4}, Lcom/adjust/sdk/ILogger;->verbose(Ljava/lang/String;[Ljava/lang/Object;)V
.line 73
iput-boolean v1, p0, Lcom/adjust/sdk/TimerCycle;->isPaused:Z
return-void
.end method