DAUExecutorScheduled.smali

.class public Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;
.super Ljava/lang/Object;
.source "SourceFile"


# static fields
.field private static final DAU_SCHEDULE_INTERVAL:J = 0xdbba0L

.field private static final G_TAG:Ljava/lang/String; = "BLiveStatisSDK"

.field private static final TAG:Ljava/lang/String; = "BLiveStatisSDK"


# instance fields
.field private dauFuture:Ljava/util/concurrent/ScheduledFuture;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/concurrent/ScheduledFuture<",
            "*>;"
        }
    .end annotation
.end field

.field private isOnScheduled:Z

.field private final mClient:Lsg/bigo/sdk/blivestat/StatClient;

.field private mContext:Landroid/content/Context;

.field private mLastScheduledTs:J

.field private final scheduleRunnable:Ljava/lang/Runnable;

.field private scheduler:Ljava/util/concurrent/ScheduledExecutorService;


# direct methods
.method public constructor <init>(Lsg/bigo/sdk/blivestat/StatClient;)V
    .registers 4

    .line 37
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V

    const/4 v0, 0x0

    .line 33
    iput-boolean v0, p0, Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;->isOnScheduled:Z

    const-wide/16 v0, 0x0

    .line 64
    iput-wide v0, p0, Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;->mLastScheduledTs:J

    .line 78
    new-instance v0, Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled$1;

    invoke-direct {v0, p0}, Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled$1;-><init>(Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;)V

    iput-object v0, p0, Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;->scheduleRunnable:Ljava/lang/Runnable;

    .line 38
    iput-object p1, p0, Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;->mClient:Lsg/bigo/sdk/blivestat/StatClient;

    const/4 p1, 0x1

    .line 39
    invoke-static {p1}, Ljava/util/concurrent/Executors;->newScheduledThreadPool(I)Ljava/util/concurrent/ScheduledExecutorService;

    move-result-object p1

    iput-object p1, p0, Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;->scheduler:Ljava/util/concurrent/ScheduledExecutorService;

    return-void
.end method

.method static synthetic access$000(Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;)Landroid/content/Context;
    .registers 1

    .line 25
    iget-object p0, p0, Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;->mContext:Landroid/content/Context;

    return-object p0
.end method

.method static synthetic access$002(Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;Landroid/content/Context;)Landroid/content/Context;
    .registers 2

    .line 25
    iput-object p1, p0, Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;->mContext:Landroid/content/Context;

    return-object p1
.end method

.method static synthetic access$100(Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;)Lsg/bigo/sdk/blivestat/StatClient;
    .registers 1

    .line 25
    iget-object p0, p0, Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;->mClient:Lsg/bigo/sdk/blivestat/StatClient;

    return-object p0
.end method

.method static synthetic access$202(Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;J)J
    .registers 3

    .line 25
    iput-wide p1, p0, Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;->mLastScheduledTs:J

    return-wide p1
.end method

.method private scheduleWithDelay(Landroid/content/Context;Ljava/lang/Runnable;JJLjava/util/concurrent/TimeUnit;)V
    .registers 16

    .line 50
    iget-boolean v0, p0, Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;->isOnScheduled:Z

    if-eqz v0, :cond_5

    return-void

    .line 54
    :cond_5
    :try_start_5
    iget-object v1, p0, Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;->scheduler:Ljava/util/concurrent/ScheduledExecutorService;

    move-object v2, p2

    move-wide v3, p3

    move-wide v5, p5

    move-object v7, p7

    invoke-interface/range {v1 .. v7}, Ljava/util/concurrent/ScheduledExecutorService;->scheduleWithFixedDelay(Ljava/lang/Runnable;JJLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;

    move-result-object p2

    iput-object p2, p0, Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;->dauFuture:Ljava/util/concurrent/ScheduledFuture;

    .line 55
    iput-object p1, p0, Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;->mContext:Landroid/content/Context;

    const/4 p1, 0x1

    .line 56
    iput-boolean p1, p0, Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;->isOnScheduled:Z

    const-string p1, "dau scheduleWithDelay done"

    .line 57
    invoke-static {p1}, Lsg/bigo/sdk/blivestat/log/InternalLog;->i(Ljava/lang/String;)V
    :try_end_1b
    .catch Ljava/lang/Exception; {:try_start_5 .. :try_end_1b} :catch_1c

    return-void

    :catch_1c
    move-exception p1

    .line 59
    new-instance p2, Ljava/lang/StringBuilder;

    const-string p3, "dau scheduleWithDelay failure :"

    invoke-direct {p2, p3}, Ljava/lang/StringBuilder;-><init>(Ljava/lang/String;)V

    invoke-virtual {p1}, Ljava/lang/Exception;->toString()Ljava/lang/String;

    move-result-object p1

    invoke-virtual {p2, p1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;

    invoke-virtual {p2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;

    move-result-object p1

    const-string p2, "BLiveStatisSDK"

    invoke-static {p2, p1}, Lsg/bigo/sdk/blivestat/log/StatLog;->e(Ljava/lang/String;Ljava/lang/String;)V

    .line 60
    invoke-virtual {p0}, Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;->closeNow()V

    return-void
.end method


# virtual methods
.method public closeNow()V
    .registers 3

    const-string v0, "remove schedule"

    .line 95
    invoke-static {v0}, Lsg/bigo/sdk/blivestat/log/InternalLog;->i(Ljava/lang/String;)V

    .line 97
    iget-object v0, p0, Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;->dauFuture:Ljava/util/concurrent/ScheduledFuture;

    const/4 v1, 0x0

    if-eqz v0, :cond_d

    .line 98
    invoke-interface {v0, v1}, Ljava/util/concurrent/ScheduledFuture;->cancel(Z)Z

    .line 100
    :cond_d
    iput-boolean v1, p0, Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;->isOnScheduled:Z

    const/4 v0, 0x0

    .line 101
    iput-object v0, p0, Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;->dauFuture:Ljava/util/concurrent/ScheduledFuture;

    .line 102
    iput-object v0, p0, Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;->mContext:Landroid/content/Context;

    const-string v0, "BLiveStatisSDK"

    const-string v1, "DAUExecutorScheduled closeNow Call"

    .line 103
    invoke-static {v0, v1}, Lsg/bigo/sdk/blivestat/log/StatLog;->e(Ljava/lang/String;Ljava/lang/String;)V

    return-void
.end method

.method public defaultScheduleWithFixedDelay(Landroid/content/Context;)V
    .registers 14

    .line 68
    iget-wide v0, p0, Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;->mLastScheduledTs:J

    const-wide/16 v2, 0x0

    cmp-long v4, v0, v2

    if-eqz v4, :cond_18

    .line 69
    invoke-static {}, Landroid/os/SystemClock;->elapsedRealtime()J

    move-result-wide v0

    iget-wide v4, p0, Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;->mLastScheduledTs:J

    sub-long/2addr v0, v4

    const-wide/32 v4, 0xdbba0

    cmp-long v6, v0, v4

    if-gez v6, :cond_18

    sub-long v2, v4, v0

    :cond_18
    move-wide v7, v2

    .line 75
    iget-object v6, p0, Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;->scheduleRunnable:Ljava/lang/Runnable;

    const-wide/32 v9, 0xdbba0

    sget-object v11, Ljava/util/concurrent/TimeUnit;->MILLISECONDS:Ljava/util/concurrent/TimeUnit;

    move-object v4, p0

    move-object v5, p1

    invoke-direct/range {v4 .. v11}, Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;->scheduleWithDelay(Landroid/content/Context;Ljava/lang/Runnable;JJLjava/util/concurrent/TimeUnit;)V

    return-void
.end method

.method public isOnScheduled()Z
    .registers 2

    .line 91
    iget-boolean v0, p0, Lsg/bigo/sdk/blivestat/info/basestat/DAUExecutorScheduled;->isOnScheduled:Z

    return v0
.end method