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