HttpDnsClient$AsyncHttpTask.smali
.class Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;
.super Ljava/lang/Object;
.source "HttpDnsClient.java"
# interfaces
.implements Ljava/lang/Runnable;
# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
value = Lio/rong/imlib/httpdns/HttpDnsClient;
.end annotation
.annotation system Ldalvik/annotation/InnerClass;
accessFlags = 0x2
name = "AsyncHttpTask"
.end annotation
# instance fields
.field private hostsOrTag:Ljava/lang/String;
.field private httpDnsCompletion:Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpDnsCompletion;
.field private needRetryBySignExpired:Z
.field private requestParamType:Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;
.field final synthetic this$0:Lio/rong/imlib/httpdns/HttpDnsClient;
# direct methods
.method constructor <init>(Lio/rong/imlib/httpdns/HttpDnsClient;Ljava/lang/String;Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpDnsCompletion;)V
.registers 5
.line 1
iput-object p1, p0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->this$0:Lio/rong/imlib/httpdns/HttpDnsClient;
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 2
iput-object p2, p0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->hostsOrTag:Ljava/lang/String;
.line 3
iput-object p3, p0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->requestParamType:Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;
.line 4
iput-object p4, p0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->httpDnsCompletion:Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpDnsCompletion;
const/4 p1, 0x0
.line 5
iput-boolean p1, p0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->needRetryBySignExpired:Z
return-void
.end method
.method private getHttpDnsUrl(Ljava/lang/String;Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;)Ljava/lang/String;
.registers 19
move-object/from16 v0, p0
move-object/from16 v1, p1
.line 1
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v2
const-wide/16 v4, 0x3e8
div-long/2addr v2, v4
const-wide/16 v4, 0x12c
add-long/2addr v2, v4
iget-object v4, v0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->this$0:Lio/rong/imlib/httpdns/HttpDnsClient;
# getter for: Lio/rong/imlib/httpdns/HttpDnsClient;->repairLocalClock:J
invoke-static {v4}, Lio/rong/imlib/httpdns/HttpDnsClient;->access$500(Lio/rong/imlib/httpdns/HttpDnsClient;)J
move-result-wide v4
add-long/2addr v2, v4
.line 2
iget-object v4, v0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->this$0:Lio/rong/imlib/httpdns/HttpDnsClient;
# invokes: Lio/rong/imlib/httpdns/HttpDnsClient;->calcSign(Ljava/lang/String;J)Ljava/lang/String;
invoke-static {v4, v1, v2, v3}, Lio/rong/imlib/httpdns/HttpDnsClient;->access$600(Lio/rong/imlib/httpdns/HttpDnsClient;Ljava/lang/String;J)Ljava/lang/String;
move-result-object v4
if-nez v4, :cond_1f
const/4 v1, 0x0
return-object v1
.line 3
:cond_1f
iget-object v5, v0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->this$0:Lio/rong/imlib/httpdns/HttpDnsClient;
# getter for: Lio/rong/imlib/httpdns/HttpDnsClient;->defaultServerIp:Ljava/lang/String;
invoke-static {v5}, Lio/rong/imlib/httpdns/HttpDnsClient;->access$700(Lio/rong/imlib/httpdns/HttpDnsClient;)Ljava/lang/String;
move-result-object v5
const/4 v6, 0x1
.line 4
new-array v7, v6, [Ljava/lang/Object;
iget-object v8, v0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->this$0:Lio/rong/imlib/httpdns/HttpDnsClient;
# getter for: Lio/rong/imlib/httpdns/HttpDnsClient;->defaultServerIp:Ljava/lang/String;
invoke-static {v8}, Lio/rong/imlib/httpdns/HttpDnsClient;->access$700(Lio/rong/imlib/httpdns/HttpDnsClient;)Ljava/lang/String;
move-result-object v8
const/4 v9, 0x0
aput-object v8, v7, v9
const-string v8, "Using BGPServerIp(%s)"
invoke-static {v8, v7}, Lio/rong/imlib/httpdns/Logger;->printLog(Ljava/lang/String;[Ljava/lang/Object;)V
.line 5
sget-object v7, Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;->TAG_OF_HOSTS:Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;
move-object/from16 v8, p2
invoke-virtual {v8, v7}, Ljava/lang/Enum;->equals(Ljava/lang/Object;)Z
move-result v7
const-string v8, "android"
const-string v11, "1.3"
const/4 v12, 0x5
const/4 v13, 0x4
const/4 v14, 0x3
const/4 v15, 0x2
const/4 v10, 0x7
if-eqz v7, :cond_6b
.line 6
new-array v7, v10, [Ljava/lang/Object;
aput-object v5, v7, v9
iget-object v5, v0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->this$0:Lio/rong/imlib/httpdns/HttpDnsClient;
.line 7
# getter for: Lio/rong/imlib/httpdns/HttpDnsClient;->accountID:Ljava/lang/String;
invoke-static {v5}, Lio/rong/imlib/httpdns/HttpDnsClient;->access$800(Lio/rong/imlib/httpdns/HttpDnsClient;)Ljava/lang/String;
move-result-object v5
aput-object v5, v7, v6
aput-object v1, v7, v15
aput-object v4, v7, v14
invoke-static {v2, v3}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v1
aput-object v1, v7, v13
aput-object v11, v7, v12
const/4 v1, 0x6
aput-object v8, v7, v1
const-string v1, "%s/v4/resolve?account_id=%s&tag=%s&sign=%s&t=%d&sdk_ver=%s&os_type=%s&alt_server_ip=true"
.line 8
invoke-static {v1, v7}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
goto :goto_8c
.line 9
:cond_6b
new-array v7, v10, [Ljava/lang/Object;
aput-object v5, v7, v9
iget-object v5, v0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->this$0:Lio/rong/imlib/httpdns/HttpDnsClient;
.line 10
# getter for: Lio/rong/imlib/httpdns/HttpDnsClient;->accountID:Ljava/lang/String;
invoke-static {v5}, Lio/rong/imlib/httpdns/HttpDnsClient;->access$800(Lio/rong/imlib/httpdns/HttpDnsClient;)Ljava/lang/String;
move-result-object v5
aput-object v5, v7, v6
aput-object v1, v7, v15
aput-object v4, v7, v14
invoke-static {v2, v3}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v1
aput-object v1, v7, v13
aput-object v11, v7, v12
const/4 v1, 0x6
aput-object v8, v7, v1
const-string v1, "%s/v4/resolve?account_id=%s&dn=%s&sign=%s&t=%d&sdk_ver=%s&os_type=%s&alt_server_ip=true"
.line 11
invoke-static {v1, v7}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
.line 12
:goto_8c
iget-object v2, v0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->this$0:Lio/rong/imlib/httpdns/HttpDnsClient;
# getter for: Lio/rong/imlib/httpdns/HttpDnsClient;->isHttps:Z
invoke-static {v2}, Lio/rong/imlib/httpdns/HttpDnsClient;->access$900(Lio/rong/imlib/httpdns/HttpDnsClient;)Z
move-result v2
if-eqz v2, :cond_9f
.line 13
new-array v2, v6, [Ljava/lang/Object;
aput-object v1, v2, v9
const-string v1, "https://%s"
invoke-static {v1, v2}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
goto :goto_a9
.line 14
:cond_9f
new-array v2, v6, [Ljava/lang/Object;
aput-object v1, v2, v9
const-string v1, "http://%s"
invoke-static {v1, v2}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v1
:goto_a9
return-object v1
.end method
.method private httpGet(Ljava/lang/String;)V
.registers 19
move-object/from16 v1, p0
const-string v2, "HttpDnsClient"
const-string v3, "error|duration"
.line 1
new-instance v4, Ljava/util/HashMap;
invoke-direct {v4}, Ljava/util/HashMap;-><init>()V
const/4 v5, 0x3
const/4 v6, -0x1
const/4 v7, 0x0
const/4 v8, 0x0
const/4 v9, 0x2
const/4 v10, 0x1
.line 2
:try_start_11
new-instance v0, Ljava/net/URL;
move-object/from16 v13, p1
invoke-direct {v0, v13}, Ljava/net/URL;-><init>(Ljava/lang/String;)V
.line 3
iget-object v13, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->this$0:Lio/rong/imlib/httpdns/HttpDnsClient;
# getter for: Lio/rong/imlib/httpdns/HttpDnsClient;->isHttps:Z
invoke-static {v13}, Lio/rong/imlib/httpdns/HttpDnsClient;->access$900(Lio/rong/imlib/httpdns/HttpDnsClient;)Z
move-result v13
if-eqz v13, :cond_35
.line 4
invoke-virtual {v0}, Ljava/net/URL;->openConnection()Ljava/net/URLConnection;
move-result-object v0
check-cast v0, Ljavax/net/ssl/HttpsURLConnection;
const-string v13, "Host"
const-string v14, "httpdns.baidubce.com"
.line 5
invoke-virtual {v0, v13, v14}, Ljavax/net/ssl/HttpsURLConnection;->setRequestProperty(Ljava/lang/String;Ljava/lang/String;)V
.line 6
# getter for: Lio/rong/imlib/httpdns/HttpDnsClient;->httpDnsHostnameVerifier:Lio/rong/imlib/httpdns/HttpDnsClient$HttpDnsHostnameVerifier;
invoke-static {}, Lio/rong/imlib/httpdns/HttpDnsClient;->access$1000()Lio/rong/imlib/httpdns/HttpDnsClient$HttpDnsHostnameVerifier;
move-result-object v13
invoke-virtual {v0, v13}, Ljavax/net/ssl/HttpsURLConnection;->setHostnameVerifier(Ljavax/net/ssl/HostnameVerifier;)V
goto :goto_3b
.line 7
:cond_35
invoke-virtual {v0}, Ljava/net/URL;->openConnection()Ljava/net/URLConnection;
move-result-object v0
check-cast v0, Ljava/net/HttpURLConnection;
:try_end_3b
.catch Ljava/io/IOException; {:try_start_11 .. :try_end_3b} :catch_192
.catch Ljava/lang/ArrayIndexOutOfBoundsException; {:try_start_11 .. :try_end_3b} :catch_17c
.catch Ljava/lang/IllegalStateException; {:try_start_11 .. :try_end_3b} :catch_166
.catchall {:try_start_11 .. :try_end_3b} :catchall_162
:goto_3b
move-object v13, v0
:try_start_3c
const-string v0, "GET"
.line 8
invoke-virtual {v13, v0}, Ljava/net/HttpURLConnection;->setRequestMethod(Ljava/lang/String;)V
const/16 v0, 0xbb8
.line 9
invoke-virtual {v13, v0}, Ljava/net/HttpURLConnection;->setReadTimeout(I)V
.line 10
invoke-virtual {v13, v0}, Ljava/net/HttpURLConnection;->setConnectTimeout(I)V
const-string v0, "connection"
const-string v14, "Keep-Alive"
.line 11
invoke-virtual {v13, v0, v14}, Ljava/net/HttpURLConnection;->setRequestProperty(Ljava/lang/String;Ljava/lang/String;)V
const-string v0, "Accept-Encoding"
const-string v14, "gzip, deflate"
.line 12
invoke-virtual {v13, v0, v14}, Ljava/net/HttpURLConnection;->setRequestProperty(Ljava/lang/String;Ljava/lang/String;)V
.line 13
sget-object v0, Lio/rong/common/fwlog/FwLog$LogTag;->L_DOH_T:Lio/rong/common/fwlog/FwLog$LogTag;
invoke-virtual {v0}, Lio/rong/common/fwlog/FwLog$LogTag;->getTag()Ljava/lang/String;
move-result-object v0
const-string v14, "nav"
new-array v15, v10, [Ljava/lang/Object;
iget-object v11, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->hostsOrTag:Ljava/lang/String;
aput-object v11, v15, v8
invoke-static {v5, v10, v0, v14, v15}, Lio/rong/common/fwlog/FwLog;->write(IILjava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
.line 14
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v11
:try_end_6c
.catch Ljava/io/IOException; {:try_start_3c .. :try_end_6c} :catch_160
.catch Ljava/lang/ArrayIndexOutOfBoundsException; {:try_start_3c .. :try_end_6c} :catch_15e
.catch Ljava/lang/IllegalStateException; {:try_start_3c .. :try_end_6c} :catch_15c
.catchall {:try_start_3c .. :try_end_6c} :catchall_241
.line 15
:try_start_6c
invoke-virtual {v13}, Ljava/net/HttpURLConnection;->connect()V
.line 16
invoke-virtual {v13}, Ljava/net/HttpURLConnection;->getResponseCode()I
move-result v0
const/16 v14, 0x190
if-lt v0, v14, :cond_7c
.line 17
invoke-virtual {v13}, Ljava/net/HttpURLConnection;->getErrorStream()Ljava/io/InputStream;
move-result-object v14
goto :goto_80
.line 18
:cond_7c
invoke-virtual {v13}, Ljava/net/HttpURLConnection;->getInputStream()Ljava/io/InputStream;
move-result-object v14
:goto_80
if-eqz v14, :cond_133
.line 19
iget-object v15, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->this$0:Lio/rong/imlib/httpdns/HttpDnsClient;
# invokes: Lio/rong/imlib/httpdns/HttpDnsClient;->getStringFromInputStream(Ljava/io/InputStream;Ljava/net/HttpURLConnection;)Ljava/lang/String;
invoke-static {v15, v14, v13}, Lio/rong/imlib/httpdns/HttpDnsClient;->access$1100(Lio/rong/imlib/httpdns/HttpDnsClient;Ljava/io/InputStream;Ljava/net/HttpURLConnection;)Ljava/lang/String;
move-result-object v14
if-nez v14, :cond_ca
const-string v0, "HttpDns request failed for %s(%s), get empty response data"
.line 20
new-array v14, v9, [Ljava/lang/Object;
iget-object v15, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->requestParamType:Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;
.line 21
invoke-virtual {v15}, Ljava/lang/Enum;->toString()Ljava/lang/String;
move-result-object v15
aput-object v15, v14, v8
iget-object v15, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->hostsOrTag:Ljava/lang/String;
aput-object v15, v14, v10
.line 22
invoke-static {v0, v14}, Lio/rong/imlib/httpdns/Logger;->printLog(Ljava/lang/String;[Ljava/lang/Object;)V
.line 23
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v14
sub-long/2addr v14, v11
.line 24
sget-object v0, Lio/rong/common/fwlog/FwLog$LogTag;->L_DOH_R:Lio/rong/common/fwlog/FwLog$LogTag;
invoke-virtual {v0}, Lio/rong/common/fwlog/FwLog$LogTag;->getTag()Ljava/lang/String;
move-result-object v0
new-array v5, v9, [Ljava/lang/Object;
const/16 v16, 0x65
invoke-static/range {v16 .. v16}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v16
aput-object v16, v5, v8
invoke-static {v14, v15}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v14
aput-object v14, v5, v10
invoke-static {v9, v10, v0, v3, v5}, Lio/rong/common/fwlog/FwLog;->write(IILjava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
.line 25
iget-object v0, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->httpDnsCompletion:Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpDnsCompletion;
iget-object v5, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->requestParamType:Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;
iget-object v14, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->hostsOrTag:Ljava/lang/String;
invoke-interface {v0, v6, v5, v7, v14}, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpDnsCompletion;->callback(ILio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;Ljava/util/Map;Ljava/lang/String;)V
:try_end_c4
.catch Ljava/io/IOException; {:try_start_6c .. :try_end_c4} :catch_15a
.catch Ljava/lang/ArrayIndexOutOfBoundsException; {:try_start_6c .. :try_end_c4} :catch_158
.catch Ljava/lang/IllegalStateException; {:try_start_6c .. :try_end_c4} :catch_156
.catchall {:try_start_6c .. :try_end_c4} :catchall_241
if-eqz v13, :cond_c9
.line 26
invoke-virtual {v13}, Ljava/net/HttpURLConnection;->disconnect()V
:cond_c9
return-void
.line 27
:cond_ca
:try_start_ca
iget-object v5, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->this$0:Lio/rong/imlib/httpdns/HttpDnsClient;
iget-object v15, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->hostsOrTag:Ljava/lang/String;
iget-object v6, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->requestParamType:Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;
# invokes: Lio/rong/imlib/httpdns/HttpDnsClient;->checkRspMsg(Ljava/lang/String;Ljava/lang/String;Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;)Ljava/util/Map;
invoke-static {v5, v14, v15, v6}, Lio/rong/imlib/httpdns/HttpDnsClient;->access$1200(Lio/rong/imlib/httpdns/HttpDnsClient;Ljava/lang/String;Ljava/lang/String;Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;)Ljava/util/Map;
move-result-object v5
const-string v6, "isSignExpired"
.line 28
invoke-interface {v5, v6}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v6
invoke-static {v10}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
move-result-object v15
invoke-virtual {v6, v15}, Ljava/lang/Object;->equals(Ljava/lang/Object;)Z
move-result v6
if-eqz v6, :cond_10a
.line 29
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v5
sub-long/2addr v5, v11
.line 30
sget-object v0, Lio/rong/common/fwlog/FwLog$LogTag;->L_DOH_R:Lio/rong/common/fwlog/FwLog$LogTag;
invoke-virtual {v0}, Lio/rong/common/fwlog/FwLog$LogTag;->getTag()Ljava/lang/String;
move-result-object v0
new-array v14, v9, [Ljava/lang/Object;
const/16 v15, 0x66
invoke-static {v15}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v15
aput-object v15, v14, v8
invoke-static {v5, v6}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v5
aput-object v5, v14, v10
invoke-static {v9, v10, v0, v3, v14}, Lio/rong/common/fwlog/FwLog;->write(IILjava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
.line 31
iput-boolean v10, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->needRetryBySignExpired:Z
:try_end_104
.catch Ljava/io/IOException; {:try_start_ca .. :try_end_104} :catch_15a
.catch Ljava/lang/ArrayIndexOutOfBoundsException; {:try_start_ca .. :try_end_104} :catch_158
.catch Ljava/lang/IllegalStateException; {:try_start_ca .. :try_end_104} :catch_156
.catchall {:try_start_ca .. :try_end_104} :catchall_241
if-eqz v13, :cond_109
.line 32
invoke-virtual {v13}, Ljava/net/HttpURLConnection;->disconnect()V
:cond_109
return-void
:cond_10a
:try_start_10a
const-string v6, "isMsgOK"
.line 33
invoke-interface {v5, v6}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v5
invoke-static {v10}, Ljava/lang/Boolean;->valueOf(Z)Ljava/lang/Boolean;
move-result-object v6
invoke-virtual {v5, v6}, Ljava/lang/Object;->equals(Ljava/lang/Object;)Z
move-result v5
if-eqz v5, :cond_128
const/16 v5, 0xc8
if-ne v0, v5, :cond_128
.line 34
iget-object v0, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->this$0:Lio/rong/imlib/httpdns/HttpDnsClient;
iget-object v5, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->hostsOrTag:Ljava/lang/String;
# invokes: Lio/rong/imlib/httpdns/HttpDnsClient;->parseRspData(Ljava/lang/String;Ljava/lang/String;)Ljava/util/Map;
invoke-static {v0, v14, v5}, Lio/rong/imlib/httpdns/HttpDnsClient;->access$1300(Lio/rong/imlib/httpdns/HttpDnsClient;Ljava/lang/String;Ljava/lang/String;)Ljava/util/Map;
move-result-object v0
move-object v4, v0
goto :goto_150
.line 35
:cond_128
iget-object v0, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->httpDnsCompletion:Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpDnsCompletion;
iget-object v5, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->requestParamType:Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;
iget-object v6, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->hostsOrTag:Ljava/lang/String;
const/4 v14, -0x1
invoke-interface {v0, v14, v5, v7, v6}, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpDnsCompletion;->callback(ILio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;Ljava/util/Map;Ljava/lang/String;)V
goto :goto_150
:cond_133
const-string v0, "HttpDns request failed for %s(%s), get null response stream"
.line 36
new-array v5, v9, [Ljava/lang/Object;
iget-object v6, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->requestParamType:Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;
.line 37
invoke-virtual {v6}, Ljava/lang/Enum;->toString()Ljava/lang/String;
move-result-object v6
aput-object v6, v5, v8
iget-object v6, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->hostsOrTag:Ljava/lang/String;
aput-object v6, v5, v10
.line 38
invoke-static {v0, v5}, Lio/rong/imlib/httpdns/Logger;->printLog(Ljava/lang/String;[Ljava/lang/Object;)V
.line 39
iget-object v0, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->httpDnsCompletion:Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpDnsCompletion;
iget-object v5, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->requestParamType:Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;
iget-object v6, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->hostsOrTag:Ljava/lang/String;
const/4 v14, -0x1
invoke-interface {v0, v14, v5, v7, v6}, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpDnsCompletion;->callback(ILio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;Ljava/util/Map;Ljava/lang/String;)V
:try_end_150
.catch Ljava/io/IOException; {:try_start_10a .. :try_end_150} :catch_15a
.catch Ljava/lang/ArrayIndexOutOfBoundsException; {:try_start_10a .. :try_end_150} :catch_158
.catch Ljava/lang/IllegalStateException; {:try_start_10a .. :try_end_150} :catch_156
.catchall {:try_start_10a .. :try_end_150} :catchall_241
:goto_150
if-eqz v13, :cond_1a8
.line 40
:goto_152
invoke-virtual {v13}, Ljava/net/HttpURLConnection;->disconnect()V
goto :goto_1a8
:catch_156
move-exception v0
goto :goto_16a
:catch_158
move-exception v0
goto :goto_180
:catch_15a
move-exception v0
goto :goto_196
:catch_15c
move-exception v0
goto :goto_168
:catch_15e
move-exception v0
goto :goto_17e
:catch_160
move-exception v0
goto :goto_194
:catchall_162
move-exception v0
move-object v13, v7
goto/16 :goto_242
:catch_166
move-exception v0
move-object v13, v7
:goto_168
const-wide/16 v11, 0x0
:goto_16a
:try_start_16a
const-string v5, "httpGet IllegalStateException"
.line 41
invoke-static {v2, v5, v0}, Lio/rong/common/rlog/RLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
.line 42
iget-object v0, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->httpDnsCompletion:Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpDnsCompletion;
iget-object v2, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->requestParamType:Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;
iget-object v5, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->hostsOrTag:Ljava/lang/String;
const/4 v6, -0x1
invoke-interface {v0, v6, v2, v7, v5}, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpDnsCompletion;->callback(ILio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;Ljava/util/Map;Ljava/lang/String;)V
if-eqz v13, :cond_1a8
goto :goto_152
:catch_17c
move-exception v0
move-object v13, v7
:goto_17e
const-wide/16 v11, 0x0
:goto_180
const-string v5, "httpGet ArrayIndexOutOfBoundsException"
.line 43
invoke-static {v2, v5, v0}, Lio/rong/common/rlog/RLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
.line 44
iget-object v0, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->httpDnsCompletion:Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpDnsCompletion;
iget-object v2, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->requestParamType:Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;
iget-object v5, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->hostsOrTag:Ljava/lang/String;
const/4 v6, -0x1
invoke-interface {v0, v6, v2, v7, v5}, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpDnsCompletion;->callback(ILio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;Ljava/util/Map;Ljava/lang/String;)V
if-eqz v13, :cond_1a8
goto :goto_152
:catch_192
move-exception v0
move-object v13, v7
:goto_194
const-wide/16 v11, 0x0
:goto_196
const-string v5, "httpGet IOException"
.line 45
invoke-static {v2, v5, v0}, Lio/rong/common/rlog/RLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I
.line 46
iget-object v0, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->httpDnsCompletion:Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpDnsCompletion;
iget-object v2, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->requestParamType:Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;
iget-object v5, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->hostsOrTag:Ljava/lang/String;
const/4 v6, -0x1
invoke-interface {v0, v6, v2, v7, v5}, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpDnsCompletion;->callback(ILio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;Ljava/util/Map;Ljava/lang/String;)V
:try_end_1a5
.catchall {:try_start_16a .. :try_end_1a5} :catchall_241
if-eqz v13, :cond_1a8
goto :goto_152
.line 47
:cond_1a8
:goto_1a8
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v5
sub-long/2addr v5, v11
const/16 v0, 0x67
if-eqz v4, :cond_21f
.line 48
invoke-interface {v4}, Ljava/util/Map;->isEmpty()Z
move-result v2
if-nez v2, :cond_21f
iget-object v2, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->hostsOrTag:Ljava/lang/String;
invoke-interface {v4, v2}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v2
if-nez v2, :cond_1c0
goto :goto_21f
.line 49
:cond_1c0
iget-object v2, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->hostsOrTag:Ljava/lang/String;
invoke-interface {v4, v2}, Ljava/util/Map;->get(Ljava/lang/Object;)Ljava/lang/Object;
move-result-object v2
check-cast v2, Lio/rong/imlib/httpdns/HttpDnsClient$Result;
invoke-virtual {v2}, Lio/rong/imlib/httpdns/HttpDnsClient$Result;->getIpv4List()Ljava/util/ArrayList;
move-result-object v2
if-eqz v2, :cond_1fd
.line 50
invoke-virtual {v2}, Ljava/util/ArrayList;->isEmpty()Z
move-result v7
if-eqz v7, :cond_1d5
goto :goto_1fd
.line 51
:cond_1d5
sget-object v0, Lio/rong/common/fwlog/FwLog$LogTag;->L_DOH_R:Lio/rong/common/fwlog/FwLog$LogTag;
invoke-virtual {v0}, Lio/rong/common/fwlog/FwLog$LogTag;->getTag()Ljava/lang/String;
move-result-object v0
const/4 v3, 0x3
new-array v7, v3, [Ljava/lang/Object;
iget-object v11, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->hostsOrTag:Ljava/lang/String;
aput-object v11, v7, v8
invoke-virtual {v2, v8}, Ljava/util/ArrayList;->get(I)Ljava/lang/Object;
move-result-object v2
aput-object v2, v7, v10
invoke-static {v5, v6}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v2
aput-object v2, v7, v9
const-string v2, "nav|ip|duration"
invoke-static {v3, v10, v0, v2, v7}, Lio/rong/common/fwlog/FwLog;->write(IILjava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
.line 52
iget-object v0, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->httpDnsCompletion:Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpDnsCompletion;
iget-object v2, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->requestParamType:Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;
iget-object v3, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->hostsOrTag:Ljava/lang/String;
invoke-interface {v0, v8, v2, v4, v3}, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpDnsCompletion;->callback(ILio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;Ljava/util/Map;Ljava/lang/String;)V
goto :goto_240
.line 53
:cond_1fd
:goto_1fd
sget-object v2, Lio/rong/common/fwlog/FwLog$LogTag;->L_DOH_R:Lio/rong/common/fwlog/FwLog$LogTag;
invoke-virtual {v2}, Lio/rong/common/fwlog/FwLog$LogTag;->getTag()Ljava/lang/String;
move-result-object v2
new-array v7, v9, [Ljava/lang/Object;
invoke-static {v0}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v0
aput-object v0, v7, v8
invoke-static {v5, v6}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v0
aput-object v0, v7, v10
invoke-static {v9, v10, v2, v3, v7}, Lio/rong/common/fwlog/FwLog;->write(IILjava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
.line 54
iget-object v0, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->httpDnsCompletion:Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpDnsCompletion;
iget-object v2, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->requestParamType:Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;
iget-object v3, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->hostsOrTag:Ljava/lang/String;
const/4 v5, -0x1
invoke-interface {v0, v5, v2, v4, v3}, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpDnsCompletion;->callback(ILio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;Ljava/util/Map;Ljava/lang/String;)V
return-void
.line 55
:cond_21f
:goto_21f
sget-object v2, Lio/rong/common/fwlog/FwLog$LogTag;->L_DOH_R:Lio/rong/common/fwlog/FwLog$LogTag;
invoke-virtual {v2}, Lio/rong/common/fwlog/FwLog$LogTag;->getTag()Ljava/lang/String;
move-result-object v2
new-array v4, v9, [Ljava/lang/Object;
invoke-static {v0}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v0
aput-object v0, v4, v8
invoke-static {v5, v6}, Ljava/lang/Long;->valueOf(J)Ljava/lang/Long;
move-result-object v0
aput-object v0, v4, v10
invoke-static {v9, v10, v2, v3, v4}, Lio/rong/common/fwlog/FwLog;->write(IILjava/lang/String;Ljava/lang/String;[Ljava/lang/Object;)V
.line 56
iget-object v0, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->httpDnsCompletion:Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpDnsCompletion;
iget-object v2, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->requestParamType:Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;
iget-object v3, v1, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->hostsOrTag:Ljava/lang/String;
const/4 v4, -0x1
invoke-interface {v0, v4, v2, v7, v3}, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpDnsCompletion;->callback(ILio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;Ljava/util/Map;Ljava/lang/String;)V
:goto_240
return-void
:catchall_241
move-exception v0
:goto_242
if-eqz v13, :cond_247
.line 57
invoke-virtual {v13}, Ljava/net/HttpURLConnection;->disconnect()V
:cond_247
goto :goto_249
:goto_248
throw v0
:goto_249
goto :goto_248
.end method
.method private startResolveRequest()V
.registers 6
.line 1
iget-object v0, p0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->hostsOrTag:Ljava/lang/String;
iget-object v1, p0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->requestParamType:Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;
invoke-direct {p0, v0, v1}, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->getHttpDnsUrl(Ljava/lang/String;Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;)Ljava/lang/String;
move-result-object v0
if-nez v0, :cond_2c
.line 2
iget-object v0, p0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->httpDnsCompletion:Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpDnsCompletion;
const/4 v1, -0x1
iget-object v2, p0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->requestParamType:Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;
const/4 v3, 0x0
iget-object v4, p0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->hostsOrTag:Ljava/lang/String;
invoke-interface {v0, v1, v2, v3, v4}, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpDnsCompletion;->callback(ILio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;Ljava/util/Map;Ljava/lang/String;)V
const/4 v0, 0x2
.line 3
new-array v0, v0, [Ljava/lang/Object;
const/4 v1, 0x0
iget-object v2, p0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->requestParamType:Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;
.line 4
invoke-virtual {v2}, Ljava/lang/Enum;->toString()Ljava/lang/String;
move-result-object v2
aput-object v2, v0, v1
const/4 v1, 0x1
iget-object v2, p0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->hostsOrTag:Ljava/lang/String;
aput-object v2, v0, v1
const-string v1, "Httpdns request failed for %s(%s), get url error"
.line 5
invoke-static {v1, v0}, Lio/rong/imlib/httpdns/Logger;->printLog(Ljava/lang/String;[Ljava/lang/Object;)V
return-void
.line 6
:cond_2c
invoke-direct {p0, v0}, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->httpGet(Ljava/lang/String;)V
return-void
.end method
# virtual methods
.method public run()V
.registers 8
.line 1
invoke-direct {p0}, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->startResolveRequest()V
.line 2
iget-boolean v0, p0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->needRetryBySignExpired:Z
const/4 v1, 0x0
if-eqz v0, :cond_20
const/4 v0, 0x2
.line 3
new-array v0, v0, [Ljava/lang/Object;
iget-object v2, p0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->requestParamType:Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;
invoke-virtual {v2}, Ljava/lang/Enum;->toString()Ljava/lang/String;
move-result-object v2
aput-object v2, v0, v1
iget-object v2, p0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->hostsOrTag:Ljava/lang/String;
const/4 v3, 0x1
aput-object v2, v0, v3
const-string v2, "Retry for %s(%s)."
invoke-static {v2, v0}, Lio/rong/imlib/httpdns/Logger;->printLog(Ljava/lang/String;[Ljava/lang/Object;)V
.line 4
invoke-direct {p0}, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->startResolveRequest()V
.line 5
:cond_20
iget-object v0, p0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->this$0:Lio/rong/imlib/httpdns/HttpDnsClient;
# getter for: Lio/rong/imlib/httpdns/HttpDnsClient;->hostToResolveLock:Ljava/lang/Object;
invoke-static {v0}, Lio/rong/imlib/httpdns/HttpDnsClient;->access$100(Lio/rong/imlib/httpdns/HttpDnsClient;)Ljava/lang/Object;
move-result-object v0
monitor-enter v0
.line 6
:try_start_27
iget-object v2, p0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->requestParamType:Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;
sget-object v3, Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;->TAG_OF_HOSTS:Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;
invoke-virtual {v2, v3}, Ljava/lang/Enum;->equals(Ljava/lang/Object;)Z
move-result v2
if-nez v2, :cond_4b
.line 7
iget-object v2, p0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->hostsOrTag:Ljava/lang/String;
const-string v3, ","
invoke-virtual {v2, v3}, Ljava/lang/String;->split(Ljava/lang/String;)[Ljava/lang/String;
move-result-object v2
.line 8
array-length v3, v2
const/4 v4, 0x0
:goto_3b
if-ge v4, v3, :cond_4b
aget-object v5, v2, v4
.line 9
iget-object v6, p0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->this$0:Lio/rong/imlib/httpdns/HttpDnsClient;
# getter for: Lio/rong/imlib/httpdns/HttpDnsClient;->hostsToResolve:Ljava/util/HashSet;
invoke-static {v6}, Lio/rong/imlib/httpdns/HttpDnsClient;->access$200(Lio/rong/imlib/httpdns/HttpDnsClient;)Ljava/util/HashSet;
move-result-object v6
invoke-virtual {v6, v5}, Ljava/util/HashSet;->remove(Ljava/lang/Object;)Z
add-int/lit8 v4, v4, 0x1
goto :goto_3b
.line 10
:cond_4b
monitor-exit v0
:try_end_4c
.catchall {:try_start_27 .. :try_end_4c} :catchall_7b
.line 11
iget-object v0, p0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->this$0:Lio/rong/imlib/httpdns/HttpDnsClient;
# getter for: Lio/rong/imlib/httpdns/HttpDnsClient;->hostsExpiredLock:Ljava/lang/Object;
invoke-static {v0}, Lio/rong/imlib/httpdns/HttpDnsClient;->access$300(Lio/rong/imlib/httpdns/HttpDnsClient;)Ljava/lang/Object;
move-result-object v2
monitor-enter v2
.line 12
:try_start_53
iget-object v0, p0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->requestParamType:Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;
sget-object v3, Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;->DNLIST_HOSTS:Lio/rong/imlib/httpdns/HttpDnsClient$RequestParamType;
invoke-virtual {v0, v3}, Ljava/lang/Enum;->equals(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_76
.line 13
iget-object v0, p0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->hostsOrTag:Ljava/lang/String;
const-string v3, ","
invoke-virtual {v0, v3}, Ljava/lang/String;->split(Ljava/lang/String;)[Ljava/lang/String;
move-result-object v0
.line 14
array-length v3, v0
:goto_66
if-ge v1, v3, :cond_76
aget-object v4, v0, v1
.line 15
iget-object v5, p0, Lio/rong/imlib/httpdns/HttpDnsClient$AsyncHttpTask;->this$0:Lio/rong/imlib/httpdns/HttpDnsClient;
# getter for: Lio/rong/imlib/httpdns/HttpDnsClient;->hostsExpired:Ljava/util/ArrayList;
invoke-static {v5}, Lio/rong/imlib/httpdns/HttpDnsClient;->access$400(Lio/rong/imlib/httpdns/HttpDnsClient;)Ljava/util/ArrayList;
move-result-object v5
invoke-virtual {v5, v4}, Ljava/util/ArrayList;->remove(Ljava/lang/Object;)Z
add-int/lit8 v1, v1, 0x1
goto :goto_66
.line 16
:cond_76
monitor-exit v2
return-void
:catchall_78
move-exception v0
monitor-exit v2
:try_end_7a
.catchall {:try_start_53 .. :try_end_7a} :catchall_78
throw v0
:catchall_7b
move-exception v1
.line 17
:try_start_7c
monitor-exit v0
:try_end_7d
.catchall {:try_start_7c .. :try_end_7d} :catchall_7b
goto :goto_7f
:goto_7e
throw v1
:goto_7f
goto :goto_7e
.end method