d.smali

.class public final Lsg/bigo/sdk/network/extra/d;
.super Ljava/lang/Object;
.source "SourceFile"

# interfaces
.implements Lsg/bigo/svcapi/IReconnectScheduler;


# instance fields
.field private a:Landroid/content/Context;

.field private b:J

.field private c:Ljava/lang/Runnable;


# direct methods
.method public constructor <init>(Landroid/content/Context;)V
    .registers 4

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

    const-wide/16 v0, 0x0

    .line 28
    iput-wide v0, p0, Lsg/bigo/sdk/network/extra/d;->b:J

    .line 153
    new-instance v0, Lsg/bigo/sdk/network/extra/d$1;

    invoke-direct {v0, p0}, Lsg/bigo/sdk/network/extra/d$1;-><init>(Lsg/bigo/sdk/network/extra/d;)V

    iput-object v0, p0, Lsg/bigo/sdk/network/extra/d;->c:Ljava/lang/Runnable;

    .line 31
    iput-object p1, p0, Lsg/bigo/sdk/network/extra/d;->a:Landroid/content/Context;

    return-void
.end method

.method static synthetic a(Lsg/bigo/sdk/network/extra/d;)Landroid/content/Context;
    .registers 1

    .line 16
    iget-object p0, p0, Lsg/bigo/sdk/network/extra/d;->a:Landroid/content/Context;

    return-object p0
.end method

.method private a(J)V
    .registers 5

    .line 145
    invoke-static {}, Lsg/bigo/svcapi/util/Daemon;->handler()Landroid/os/Handler;

    move-result-object v0

    iget-object v1, p0, Lsg/bigo/sdk/network/extra/d;->c:Ljava/lang/Runnable;

    invoke-virtual {v0, v1, p1, p2}, Landroid/os/Handler;->postDelayed(Ljava/lang/Runnable;J)Z

    .line 146
    invoke-static {p1, p2}, Ljava/lang/String;->valueOf(J)Ljava/lang/String;

    move-result-object p1

    const-string p2, "schedule short in interval="

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

    move-result-object p1

    const-string p2, "ReconnectScheduler"

    invoke-static {p2, p1}, Lsg/bigo/log/Log;->i(Ljava/lang/String;Ljava/lang/String;)I

    return-void
.end method


# virtual methods
.method public final declared-synchronized reset()V
    .registers 7

    monitor-enter p0

    .line 1150
    :try_start_1
    invoke-static {}, Lsg/bigo/svcapi/util/Daemon;->handler()Landroid/os/Handler;

    move-result-object v0

    iget-object v1, p0, Lsg/bigo/sdk/network/extra/d;->c:Ljava/lang/Runnable;

    invoke-virtual {v0, v1}, Landroid/os/Handler;->removeCallbacks(Ljava/lang/Runnable;)V

    .line 2055
    invoke-static {}, Lsg/bigo/sdk/network/extra/c;->a()Ljava/lang/Class;

    move-result-object v0

    if-eqz v0, :cond_87

    .line 2059
    iget-object v1, p0, Lsg/bigo/sdk/network/extra/d;->a:Landroid/content/Context;

    const-string v2, "alarm"

    invoke-virtual {v1, v2}, Landroid/content/Context;->getSystemService(Ljava/lang/String;)Ljava/lang/Object;

    move-result-object v1

    check-cast v1, Landroid/app/AlarmManager;

    if-nez v1, :cond_25

    const-string v0, "ReconnectScheduler"

    const-string v1, "cancelAlarm get AlarmManager failed"

    .line 2061
    invoke-static {v0, v1}, Lsg/bigo/log/TraceLog;->e(Ljava/lang/String;Ljava/lang/String;)I
    :try_end_23
    .catchall {:try_start_1 .. :try_end_23} :catchall_89

    .line 2062
    monitor-exit p0

    return-void

    .line 2065
    :cond_25
    :try_start_25
    new-instance v2, Landroid/content/Intent;

    iget-object v3, p0, Lsg/bigo/sdk/network/extra/d;->a:Landroid/content/Context;

    invoke-direct {v2, v3, v0}, Landroid/content/Intent;-><init>(Landroid/content/Context;Ljava/lang/Class;)V

    .line 2066
    sget-object v3, Lsg/bigo/sdk/network/extra/c;->b:Ljava/lang/String;

    invoke-virtual {v2, v3}, Landroid/content/Intent;->setAction(Ljava/lang/String;)Landroid/content/Intent;

    .line 2067
    iget-object v3, p0, Lsg/bigo/sdk/network/extra/d;->a:Landroid/content/Context;

    const/4 v4, 0x0

    invoke-static {v3, v4, v2, v4}, Landroid/app/PendingIntent;->getService(Landroid/content/Context;ILandroid/content/Intent;I)Landroid/app/PendingIntent;

    move-result-object v2
    :try_end_38
    .catchall {:try_start_25 .. :try_end_38} :catchall_89

    if-eqz v2, :cond_4e

    .line 2071
    :try_start_3a
    invoke-virtual {v1, v2}, Landroid/app/AlarmManager;->cancel(Landroid/app/PendingIntent;)V

    const-string v2, "ReconnectScheduler"

    const-string v3, "cancel ACTION_RECONNECT alarm"

    .line 2072
    invoke-static {v2, v3}, Lsg/bigo/log/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
    :try_end_44
    .catch Ljava/lang/Exception; {:try_start_3a .. :try_end_44} :catch_45
    .catchall {:try_start_3a .. :try_end_44} :catchall_89

    goto :goto_55

    :catch_45
    move-exception v2

    :try_start_46
    const-string v3, "ReconnectScheduler"

    const-string v5, "cancel ACTION_RECONNECT_WAKEUP alarm error."

    .line 2074
    invoke-static {v3, v5, v2}, Lsg/bigo/log/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I

    goto :goto_55

    :cond_4e
    const-string v2, "ReconnectScheduler"

    const-string v3, "cancelAlarm get PendingIntent failed 1"

    .line 2078
    invoke-static {v2, v3}, Lsg/bigo/log/Log;->e(Ljava/lang/String;Ljava/lang/String;)I

    .line 2081
    :goto_55
    new-instance v2, Landroid/content/Intent;

    iget-object v3, p0, Lsg/bigo/sdk/network/extra/d;->a:Landroid/content/Context;

    invoke-direct {v2, v3, v0}, Landroid/content/Intent;-><init>(Landroid/content/Context;Ljava/lang/Class;)V

    .line 2082
    sget-object v0, Lsg/bigo/sdk/network/extra/c;->c:Ljava/lang/String;

    invoke-virtual {v2, v0}, Landroid/content/Intent;->setAction(Ljava/lang/String;)Landroid/content/Intent;

    .line 2083
    iget-object v0, p0, Lsg/bigo/sdk/network/extra/d;->a:Landroid/content/Context;

    const/4 v3, 0x1

    invoke-static {v0, v3, v2, v4}, Landroid/app/PendingIntent;->getService(Landroid/content/Context;ILandroid/content/Intent;I)Landroid/app/PendingIntent;

    move-result-object v0
    :try_end_68
    .catchall {:try_start_46 .. :try_end_68} :catchall_89

    if-eqz v0, :cond_80

    .line 2087
    :try_start_6a
    invoke-virtual {v1, v0}, Landroid/app/AlarmManager;->cancel(Landroid/app/PendingIntent;)V

    const-string v0, "ReconnectScheduler"

    const-string v1, "cancel ACTION_RECONNECT_WAKEUP alarm"

    .line 2088
    invoke-static {v0, v1}, Lsg/bigo/log/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
    :try_end_74
    .catch Ljava/lang/Exception; {:try_start_6a .. :try_end_74} :catch_76
    .catchall {:try_start_6a .. :try_end_74} :catchall_89

    .line 2091
    monitor-exit p0

    return-void

    :catch_76
    move-exception v0

    :try_start_77
    const-string v1, "ReconnectScheduler"

    const-string v2, "cancel ACTION_RECONNECT_WAKEUP alarm error."

    .line 2090
    invoke-static {v1, v2, v0}, Lsg/bigo/log/Log;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
    :try_end_7e
    .catchall {:try_start_77 .. :try_end_7e} :catchall_89

    .line 2091
    monitor-exit p0

    return-void

    :cond_80
    :try_start_80
    const-string v0, "ReconnectScheduler"

    const-string v1, "cancelAlarm get PendingIntent failed 2"

    .line 2094
    invoke-static {v0, v1}, Lsg/bigo/log/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
    :try_end_87
    .catchall {:try_start_80 .. :try_end_87} :catchall_89

    .line 38
    :cond_87
    monitor-exit p0

    return-void

    :catchall_89
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method public final declared-synchronized scheduleNext(ZZ)V
    .registers 12

    monitor-enter p0

    .line 42
    :try_start_1
    new-instance v0, Ljava/lang/StringBuilder;

    const-string v1, "scheduleNext -> active="

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

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

    const-string v1, ", fastOnly="

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

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

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

    move-result-wide v0

    if-nez p2, :cond_db

    .line 44
    iget-wide v2, p0, Lsg/bigo/sdk/network/extra/d;->b:J

    sub-long v2, v0, v2

    const-wide/16 v4, 0x7530

    cmp-long p2, v2, v4

    if-lez p2, :cond_25

    goto/16 :goto_db

    :cond_25
    if-eqz p1, :cond_2e

    const-wide/16 p1, 0xfa0

    .line 48
    invoke-direct {p0, p1, p2}, Lsg/bigo/sdk/network/extra/d;->a(J)V
    :try_end_2c
    .catchall {:try_start_1 .. :try_end_2c} :catchall_e4

    monitor-exit p0

    return-void

    .line 2099
    :cond_2e
    :try_start_2e
    invoke-static {}, Lsg/bigo/sdk/network/extra/c;->a()Ljava/lang/Class;

    move-result-object p1

    if-eqz p1, :cond_d9

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

    move-result-wide v0

    .line 2104
    iget-object p2, p0, Lsg/bigo/sdk/network/extra/d;->a:Landroid/content/Context;

    const-string v2, "alarm"

    invoke-virtual {p2, v2}, Landroid/content/Context;->getSystemService(Ljava/lang/String;)Ljava/lang/Object;

    move-result-object p2

    check-cast p2, Landroid/app/AlarmManager;

    if-nez p2, :cond_4d

    const-string p1, "ReconnectScheduler"

    const-string p2, "scheduleAlarm get AlarmManager failed"

    .line 2106
    invoke-static {p1, p2}, Lsg/bigo/log/TraceLog;->e(Ljava/lang/String;Ljava/lang/String;)I
    :try_end_4b
    .catchall {:try_start_2e .. :try_end_4b} :catchall_e4

    .line 2107
    monitor-exit p0

    return-void

    .line 2110
    :cond_4d
    :try_start_4d
    new-instance v2, Landroid/content/Intent;

    iget-object v3, p0, Lsg/bigo/sdk/network/extra/d;->a:Landroid/content/Context;

    invoke-direct {v2, v3, p1}, Landroid/content/Intent;-><init>(Landroid/content/Context;Ljava/lang/Class;)V

    .line 2111
    sget-object v3, Lsg/bigo/sdk/network/extra/c;->b:Ljava/lang/String;

    invoke-virtual {v2, v3}, Landroid/content/Intent;->setAction(Ljava/lang/String;)Landroid/content/Intent;

    .line 2112
    iget-object v3, p0, Lsg/bigo/sdk/network/extra/d;->a:Landroid/content/Context;

    const/4 v4, 0x0

    invoke-static {v3, v4, v2, v4}, Landroid/app/PendingIntent;->getService(Landroid/content/Context;ILandroid/content/Intent;I)Landroid/app/PendingIntent;

    move-result-object v2
    :try_end_60
    .catchall {:try_start_4d .. :try_end_60} :catchall_e4

    const-wide/32 v5, 0x249f0

    if-eqz v2, :cond_8d

    const/4 v3, 0x3

    add-long v7, v0, v5

    .line 2116
    :try_start_68
    invoke-virtual {p2, v3, v7, v8, v2}, Landroid/app/AlarmManager;->set(IJLandroid/app/PendingIntent;)V

    const-string v2, "ReconnectScheduler"

    .line 2117
    new-instance v3, Ljava/lang/StringBuilder;

    const-string v7, "schedule ACTION_RECONNECT alarm time="

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

    invoke-virtual {v3, v0, v1}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

    const-string v7, ", interval=150000"

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

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

    move-result-object v3

    invoke-static {v2, v3}, Lsg/bigo/log/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
    :try_end_83
    .catch Ljava/lang/Exception; {:try_start_68 .. :try_end_83} :catch_84
    .catchall {:try_start_68 .. :try_end_83} :catchall_e4

    goto :goto_94

    :catch_84
    move-exception v2

    :try_start_85
    const-string v3, "ReconnectScheduler"

    const-string v7, "alarmMgr#set error."

    .line 2119
    invoke-static {v3, v7, v2}, Lsg/bigo/log/TraceLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I

    goto :goto_94

    :cond_8d
    const-string v2, "ReconnectScheduler"

    const-string v3, "scheduleAlarm get PendingIntent failed 1"

    .line 2123
    invoke-static {v2, v3}, Lsg/bigo/log/Log;->e(Ljava/lang/String;Ljava/lang/String;)I

    .line 2127
    :goto_94
    new-instance v2, Landroid/content/Intent;

    iget-object v3, p0, Lsg/bigo/sdk/network/extra/d;->a:Landroid/content/Context;

    invoke-direct {v2, v3, p1}, Landroid/content/Intent;-><init>(Landroid/content/Context;Ljava/lang/Class;)V

    .line 2128
    sget-object p1, Lsg/bigo/sdk/network/extra/c;->c:Ljava/lang/String;

    invoke-virtual {v2, p1}, Landroid/content/Intent;->setAction(Ljava/lang/String;)Landroid/content/Intent;

    .line 2129
    iget-object p1, p0, Lsg/bigo/sdk/network/extra/d;->a:Landroid/content/Context;

    const/4 v3, 0x1

    invoke-static {p1, v3, v2, v4}, Landroid/app/PendingIntent;->getService(Landroid/content/Context;ILandroid/content/Intent;I)Landroid/app/PendingIntent;

    move-result-object p1
    :try_end_a7
    .catchall {:try_start_85 .. :try_end_a7} :catchall_e4

    if-eqz p1, :cond_d2

    const/4 v2, 0x2

    add-long/2addr v5, v0

    .line 2133
    :try_start_ab
    invoke-virtual {p2, v2, v5, v6, p1}, Landroid/app/AlarmManager;->set(IJLandroid/app/PendingIntent;)V

    const-string p1, "ReconnectScheduler"

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

    const-string v2, "schedule ACTION_RECONNECT_WAKEUP alert time="

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

    invoke-virtual {p2, v0, v1}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;

    const-string v0, ", interval=150000"

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

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

    move-result-object p2

    invoke-static {p1, p2}, Lsg/bigo/log/Log;->i(Ljava/lang/String;Ljava/lang/String;)I
    :try_end_c6
    .catch Ljava/lang/Exception; {:try_start_ab .. :try_end_c6} :catch_c8
    .catchall {:try_start_ab .. :try_end_c6} :catchall_e4

    .line 2137
    monitor-exit p0

    return-void

    :catch_c8
    move-exception p1

    :try_start_c9
    const-string p2, "ReconnectScheduler"

    const-string v0, "alarmMgr#set error."

    .line 2136
    invoke-static {p2, v0, p1}, Lsg/bigo/log/TraceLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
    :try_end_d0
    .catchall {:try_start_c9 .. :try_end_d0} :catchall_e4

    .line 2137
    monitor-exit p0

    return-void

    :cond_d2
    :try_start_d2
    const-string p1, "ReconnectScheduler"

    const-string p2, "scheduleAlarm get PendingIntent failed 2"

    .line 2140
    invoke-static {p1, p2}, Lsg/bigo/log/Log;->e(Ljava/lang/String;Ljava/lang/String;)I
    :try_end_d9
    .catchall {:try_start_d2 .. :try_end_d9} :catchall_e4

    .line 52
    :cond_d9
    monitor-exit p0

    return-void

    :cond_db
    :goto_db
    const-wide/16 p1, 0x64

    .line 45
    :try_start_dd
    invoke-direct {p0, p1, p2}, Lsg/bigo/sdk/network/extra/d;->a(J)V

    .line 46
    iput-wide v0, p0, Lsg/bigo/sdk/network/extra/d;->b:J
    :try_end_e2
    .catchall {:try_start_dd .. :try_end_e2} :catchall_e4

    monitor-exit p0

    return-void

    :catchall_e4
    move-exception p1

    monitor-exit p0

    throw p1
.end method