b.smali
.class public Lcn/jiguang/bh/b;
.super Lcn/jiguang/bh/a;
# instance fields
.field private final g:I
.field private h:Ljava/nio/ByteBuffer;
# direct methods
.method public constructor <init>(II)V
.registers 4
invoke-direct {p0}, Lcn/jiguang/bh/a;-><init>()V
iput p1, p0, Lcn/jiguang/bh/b;->g:I
const/16 v0, 0x2000
invoke-static {v0}, Ljava/nio/ByteBuffer;->allocate(I)Ljava/nio/ByteBuffer;
move-result-object v0
iput-object v0, p0, Lcn/jiguang/bh/b;->h:Ljava/nio/ByteBuffer;
iput p2, p0, Lcn/jiguang/bh/b;->f:I
return-void
.end method
.method private b([B)Z
.registers 7
const/4 v0, 0x0
:try_start_1
invoke-virtual {p0}, Lcn/jiguang/bh/b;->b()Z
move-result v1
if-nez v1, :cond_f
const-string v1, "NioSocketClient"
const-string v2, "send error - connect was invalid"
invoke-static {v1, v2}, Lcn/jiguang/ay/c;->c(Ljava/lang/String;Ljava/lang/String;)V
:goto_e
return v0
:cond_f
if-eqz p1, :cond_14
array-length v1, p1
if-gtz v1, :cond_39
:cond_14
const-string v1, "NioSocketClient"
const-string v2, "send error - invalide buffer"
invoke-static {v1, v2}, Lcn/jiguang/ay/c;->c(Ljava/lang/String;Ljava/lang/String;)V
:try_end_1b
.catch Ljava/lang/Exception; {:try_start_1 .. :try_end_1b} :catch_1c
goto :goto_e
:catch_1c
move-exception v1
const-string v2, "NioSocketClient"
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "send data error:"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v2, v1}, Lcn/jiguang/ay/c;->h(Ljava/lang/String;Ljava/lang/String;)V
invoke-virtual {p0}, Lcn/jiguang/bh/b;->close()V
goto :goto_e
:cond_39
:try_start_39
iget-object v1, p0, Lcn/jiguang/bh/b;->b:Ljava/nio/channels/SocketChannel;
invoke-static {p1}, Ljava/nio/ByteBuffer;->wrap([B)Ljava/nio/ByteBuffer;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/nio/channels/SocketChannel;->write(Ljava/nio/ByteBuffer;)I
move-result v1
if-lez v1, :cond_5f
const-string v2, "NioSocketClient"
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "isWritable has send len:"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v2, v1}, Lcn/jiguang/ay/c;->a(Ljava/lang/String;Ljava/lang/String;)V
:cond_5d
const/4 v0, 0x1
goto :goto_e
:cond_5f
if-gez v1, :cond_5d
const-string v2, "NioSocketClient"
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "isWritable error:"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v2, v1}, Lcn/jiguang/ay/c;->a(Ljava/lang/String;Ljava/lang/String;)V
:try_end_79
.catch Ljava/lang/Exception; {:try_start_39 .. :try_end_79} :catch_1c
goto :goto_e
.end method
# virtual methods
.method public declared-synchronized a(Ljava/lang/String;I)I
.registers 13
const/4 v2, 0x0
const/16 v1, -0x3df
const/16 v0, -0x3e2
monitor-enter p0
:try_start_6
invoke-super {p0, p1, p2}, Lcn/jiguang/bh/a;->a(Ljava/lang/String;I)I
:try_end_9
.catchall {:try_start_6 .. :try_end_9} :catchall_9b
:try_start_9
invoke-static {}, Ljava/nio/channels/SocketChannel;->open()Ljava/nio/channels/SocketChannel;
move-result-object v3
iput-object v3, p0, Lcn/jiguang/bh/b;->b:Ljava/nio/channels/SocketChannel;
invoke-static {}, Ljava/nio/channels/Selector;->open()Ljava/nio/channels/Selector;
move-result-object v3
iput-object v3, p0, Lcn/jiguang/bh/b;->d:Ljava/nio/channels/Selector;
iget-object v3, p0, Lcn/jiguang/bh/b;->b:Ljava/nio/channels/SocketChannel;
const/4 v4, 0x0
invoke-virtual {v3, v4}, Ljava/nio/channels/SocketChannel;->configureBlocking(Z)Ljava/nio/channels/SelectableChannel;
new-instance v3, Ljava/net/InetSocketAddress;
invoke-direct {v3, p1, p2}, Ljava/net/InetSocketAddress;-><init>(Ljava/lang/String;I)V
iget-object v4, p0, Lcn/jiguang/bh/b;->b:Ljava/nio/channels/SocketChannel;
invoke-virtual {v4, v3}, Ljava/nio/channels/SocketChannel;->connect(Ljava/net/SocketAddress;)Z
const-string v3, "NioSocketClient"
const-string v4, "tcp connecting..."
invoke-static {v3, v4}, Lcn/jiguang/ay/c;->c(Ljava/lang/String;Ljava/lang/String;)V
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v4
:cond_30
iget-object v3, p0, Lcn/jiguang/bh/b;->b:Ljava/nio/channels/SocketChannel;
invoke-virtual {v3}, Ljava/nio/channels/SocketChannel;->finishConnect()Z
move-result v3
if-nez v3, :cond_7d
iget-boolean v3, p0, Lcn/jiguang/bh/b;->e:Z
if-nez v3, :cond_46
const-string v2, "NioSocketClient"
const-string v3, "has close channel when connect..."
invoke-static {v2, v3}, Lcn/jiguang/ay/c;->c(Ljava/lang/String;Ljava/lang/String;)V
:try_end_43
.catch Ljava/lang/Throwable; {:try_start_9 .. :try_end_43} :catch_5a
.catchall {:try_start_9 .. :try_end_43} :catchall_9b
move v0, v1
:cond_44
:goto_44
monitor-exit p0
return v0
:cond_46
const-wide/16 v6, 0xa
:try_start_48
invoke-static {v6, v7}, Ljava/lang/Thread;->sleep(J)V
invoke-static {}, Ljava/lang/System;->currentTimeMillis()J
move-result-wide v6
sub-long/2addr v6, v4
const-wide/16 v8, 0xbb8
cmp-long v3, v6, v8
if-lez v3, :cond_30
invoke-virtual {p0}, Lcn/jiguang/bh/b;->close()V
:try_end_59
.catch Ljava/lang/Throwable; {:try_start_48 .. :try_end_59} :catch_5a
.catchall {:try_start_48 .. :try_end_59} :catchall_9b
goto :goto_44
:catch_5a
move-exception v1
:try_start_5b
const-string v2, "NioSocketClient"
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "tcp connect has failed:"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v3
invoke-static {v2, v3}, Lcn/jiguang/ay/c;->h(Ljava/lang/String;Ljava/lang/String;)V
invoke-virtual {p0}, Lcn/jiguang/bh/b;->close()V
instance-of v1, v1, Ljava/net/SocketTimeoutException;
:try_end_78
.catchall {:try_start_5b .. :try_end_78} :catchall_9b
if-nez v1, :cond_44
const/16 v0, -0x3e8
goto :goto_44
:cond_7d
:try_start_7d
iget-boolean v3, p0, Lcn/jiguang/bh/b;->e:Z
if-nez v3, :cond_8a
const-string v2, "NioSocketClient"
const-string v3, "has close channel when connected..."
invoke-static {v2, v3}, Lcn/jiguang/ay/c;->c(Ljava/lang/String;Ljava/lang/String;)V
move v0, v1
goto :goto_44
:cond_8a
const-string v1, "NioSocketClient"
const-string v3, "tcp connected"
invoke-static {v1, v3}, Lcn/jiguang/ay/c;->c(Ljava/lang/String;Ljava/lang/String;)V
iget-object v1, p0, Lcn/jiguang/bh/b;->b:Ljava/nio/channels/SocketChannel;
iget-object v3, p0, Lcn/jiguang/bh/b;->d:Ljava/nio/channels/Selector;
const/4 v4, 0x1
invoke-virtual {v1, v3, v4}, Ljava/nio/channels/SocketChannel;->register(Ljava/nio/channels/Selector;I)Ljava/nio/channels/SelectionKey;
:try_end_99
.catch Ljava/lang/Throwable; {:try_start_7d .. :try_end_99} :catch_5a
.catchall {:try_start_7d .. :try_end_99} :catchall_9b
move v0, v2
goto :goto_44
:catchall_9b
move-exception v0
monitor-exit p0
throw v0
.end method
.method public a([B)I
.registers 6
const/16 v0, 0x67
if-nez p1, :cond_c
const-string v1, "NioSocketClient"
const-string v2, "sendData failed, send data was null"
invoke-static {v1, v2}, Lcn/jiguang/ay/c;->c(Ljava/lang/String;Ljava/lang/String;)V
:cond_b
:goto_b
return v0
:cond_c
const-string v1, "NioSocketClient"
new-instance v2, Ljava/lang/StringBuilder;
invoke-direct {v2}, Ljava/lang/StringBuilder;-><init>()V
const-string v3, "send data length:"
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v2
array-length v3, p1
invoke-virtual {v2, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v2
invoke-virtual {v2}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v2
invoke-static {v1, v2}, Lcn/jiguang/ay/c;->c(Ljava/lang/String;Ljava/lang/String;)V
array-length v1, p1
iget v2, p0, Lcn/jiguang/bh/b;->g:I
if-lt v1, v2, :cond_47
const-string v0, "NioSocketClient"
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "sendData failed, data length must less than "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
iget v2, p0, Lcn/jiguang/bh/b;->g:I
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v0, v1}, Lcn/jiguang/ay/c;->c(Ljava/lang/String;Ljava/lang/String;)V
const/16 v0, 0x178a
goto :goto_b
:cond_47
invoke-direct {p0, p1}, Lcn/jiguang/bh/b;->b([B)Z
move-result v1
if-eqz v1, :cond_b
const/4 v0, 0x0
goto :goto_b
.end method
.method public a(I)Ljava/nio/ByteBuffer;
.registers 12
const/high16 v4, 0x100000
const/16 v9, -0x3e2
const/16 v8, -0x3e5
const/4 v3, 0x0
:try_start_7
invoke-virtual {p0}, Lcn/jiguang/bh/b;->b()Z
move-result v0
if-nez v0, :cond_26
new-instance v0, Lcn/jiguang/be/f;
const/16 v1, -0x3df
const-string v2, "recv error,the connect is invalid"
invoke-direct {v0, v1, v2}, Lcn/jiguang/be/f;-><init>(ILjava/lang/String;)V
throw v0
:try_end_17
.catch Ljava/lang/Throwable; {:try_start_7 .. :try_end_17} :catch_17
:catch_17
move-exception v0
instance-of v1, v0, Ljava/net/SocketTimeoutException;
if-eqz v1, :cond_15c
new-instance v1, Lcn/jiguang/be/f;
invoke-virtual {v0}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object v0
invoke-direct {v1, v9, v0}, Lcn/jiguang/be/f;-><init>(ILjava/lang/String;)V
throw v1
:cond_26
:try_start_26
invoke-virtual {p0}, Lcn/jiguang/bh/b;->c()I
move-result v0
if-lez v0, :cond_33
invoke-virtual {p0, v0}, Lcn/jiguang/bh/b;->b(I)Ljava/nio/ByteBuffer;
move-result-object v0
if-eqz v0, :cond_33
:cond_32
return-object v0
:cond_33
move v2, v4
:cond_34
invoke-virtual {p0}, Lcn/jiguang/bh/b;->b()Z
move-result v0
if-eqz v0, :cond_16d
iget v0, p0, Lcn/jiguang/bh/b;->c:I
if-ge v0, v2, :cond_16d
if-lez p1, :cond_77
iget-object v0, p0, Lcn/jiguang/bh/b;->d:Ljava/nio/channels/Selector;
int-to-long v6, p1
invoke-virtual {v0, v6, v7}, Ljava/nio/channels/Selector;->select(J)I
move-result v0
:goto_47
if-nez v0, :cond_7e
const-string v1, "NioSocketClient"
new-instance v5, Ljava/lang/StringBuilder;
invoke-direct {v5}, Ljava/lang/StringBuilder;-><init>()V
const-string v6, "readSelect:"
invoke-virtual {v5, v6}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v5
invoke-virtual {v5, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v0
const-string v5, ",time out:"
invoke-virtual {v0, v5}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0, p1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-static {v1, v0}, Lcn/jiguang/ay/c;->c(Ljava/lang/String;Ljava/lang/String;)V
if-lez p1, :cond_34
new-instance v0, Lcn/jiguang/be/f;
const/16 v1, -0x3e2
const-string v2, "recv time out"
invoke-direct {v0, v1, v2}, Lcn/jiguang/be/f;-><init>(ILjava/lang/String;)V
throw v0
:cond_77
iget-object v0, p0, Lcn/jiguang/bh/b;->d:Ljava/nio/channels/Selector;
invoke-virtual {v0}, Ljava/nio/channels/Selector;->select()I
move-result v0
goto :goto_47
:cond_7e
iget-object v0, p0, Lcn/jiguang/bh/b;->d:Ljava/nio/channels/Selector;
invoke-virtual {v0}, Ljava/nio/channels/Selector;->selectedKeys()Ljava/util/Set;
move-result-object v0
invoke-interface {v0}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v5
:goto_88
invoke-interface {v5}, Ljava/util/Iterator;->hasNext()Z
move-result v0
if-eqz v0, :cond_34
invoke-interface {v5}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v0
check-cast v0, Ljava/nio/channels/SelectionKey;
invoke-virtual {v0}, Ljava/nio/channels/SelectionKey;->channel()Ljava/nio/channels/SelectableChannel;
move-result-object v1
check-cast v1, Ljava/nio/channels/SocketChannel;
invoke-virtual {v0}, Ljava/nio/channels/SelectionKey;->isReadable()Z
move-result v6
if-eqz v6, :cond_154
iget-object v0, p0, Lcn/jiguang/bh/b;->h:Ljava/nio/ByteBuffer;
invoke-virtual {v1, v0}, Ljava/nio/channels/SocketChannel;->read(Ljava/nio/ByteBuffer;)I
move-result v0
if-gez v0, :cond_c3
new-instance v1, Lcn/jiguang/be/f;
const/16 v2, -0x3e4
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "read len < 0:"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-direct {v1, v2, v0}, Lcn/jiguang/be/f;-><init>(ILjava/lang/String;)V
throw v1
:cond_c3
iget-object v1, p0, Lcn/jiguang/bh/b;->h:Ljava/nio/ByteBuffer;
invoke-virtual {v1}, Ljava/nio/ByteBuffer;->flip()Ljava/nio/Buffer;
iget-object v1, p0, Lcn/jiguang/bh/b;->h:Ljava/nio/ByteBuffer;
invoke-virtual {v1}, Ljava/nio/ByteBuffer;->limit()I
move-result v1
iget-object v3, p0, Lcn/jiguang/bh/b;->a:Ljava/nio/ByteBuffer;
invoke-virtual {v3}, Ljava/nio/ByteBuffer;->remaining()I
move-result v3
if-ge v3, v1, :cond_101
new-instance v0, Lcn/jiguang/be/f;
const/16 v2, -0x3e4
new-instance v3, Ljava/lang/StringBuilder;
invoke-direct {v3}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "the total buf remaining less than readLen,remaining:"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
iget-object v4, p0, Lcn/jiguang/bh/b;->a:Ljava/nio/ByteBuffer;
invoke-virtual {v4}, Ljava/nio/ByteBuffer;->remaining()I
move-result v4
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v3
const-string v4, ",readLen:"
invoke-virtual {v3, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v3
invoke-virtual {v3, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v2, v1}, Lcn/jiguang/be/f;-><init>(ILjava/lang/String;)V
throw v0
:cond_101
iget-object v3, p0, Lcn/jiguang/bh/b;->a:Ljava/nio/ByteBuffer;
iget-object v6, p0, Lcn/jiguang/bh/b;->h:Ljava/nio/ByteBuffer;
invoke-virtual {v3, v6}, Ljava/nio/ByteBuffer;->put(Ljava/nio/ByteBuffer;)Ljava/nio/ByteBuffer;
iget v3, p0, Lcn/jiguang/bh/b;->c:I
add-int/2addr v3, v1
iput v3, p0, Lcn/jiguang/bh/b;->c:I
iget-object v3, p0, Lcn/jiguang/bh/b;->h:Ljava/nio/ByteBuffer;
invoke-virtual {v3}, Ljava/nio/ByteBuffer;->compact()Ljava/nio/ByteBuffer;
iget v3, p0, Lcn/jiguang/bh/b;->c:I
iget v6, p0, Lcn/jiguang/bh/b;->f:I
if-ge v3, v6, :cond_14f
const-string v3, "NioSocketClient"
new-instance v6, Ljava/lang/StringBuilder;
invoke-direct {v6}, Ljava/lang/StringBuilder;-><init>()V
const-string v7, "totalbuf can not parse head:"
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
iget v7, p0, Lcn/jiguang/bh/b;->c:I
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v6
const-string v7, ",peerNetData len:"
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
invoke-virtual {v6, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v6
const-string v7, ",read:"
invoke-virtual {v6, v7}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v6
invoke-virtual {v6, v0}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
invoke-static {v3, v0}, Lcn/jiguang/ay/c;->c(Ljava/lang/String;Ljava/lang/String;)V
move v0, v2
:goto_147
move v2, v0
move v0, v1
:goto_149
invoke-interface {v5}, Ljava/util/Iterator;->remove()V
move v3, v0
goto/16 :goto_88
:cond_14f
invoke-virtual {p0}, Lcn/jiguang/bh/b;->c()I
move-result v0
goto :goto_147
:cond_154
invoke-virtual {v0}, Ljava/nio/channels/SelectionKey;->isWritable()Z
:try_end_157
.catch Ljava/lang/Throwable; {:try_start_26 .. :try_end_157} :catch_17
move-result v0
if-eqz v0, :cond_15a
:cond_15a
move v0, v3
goto :goto_149
:cond_15c
instance-of v1, v0, Lcn/jiguang/be/f;
if-eqz v1, :cond_163
check-cast v0, Lcn/jiguang/be/f;
throw v0
:cond_163
new-instance v1, Lcn/jiguang/be/f;
invoke-virtual {v0}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;
move-result-object v0
invoke-direct {v1, v8, v0}, Lcn/jiguang/be/f;-><init>(ILjava/lang/String;)V
throw v1
:cond_16d
if-ne v2, v4, :cond_177
new-instance v0, Lcn/jiguang/be/f;
const-string v1, "recv empty data or tcp has close"
invoke-direct {v0, v8, v1}, Lcn/jiguang/be/f;-><init>(ILjava/lang/String;)V
throw v0
:cond_177
const-string v0, "NioSocketClient"
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v4, "read len:"
invoke-virtual {v1, v4}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v1
const-string v3, ",recvTotalLen:"
invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
iget v3, p0, Lcn/jiguang/bh/b;->c:I
invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v1
const-string v3, ",shouldLen:"
invoke-virtual {v1, v3}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-static {v0, v1}, Lcn/jiguang/ay/c;->c(Ljava/lang/String;Ljava/lang/String;)V
invoke-virtual {p0, v2}, Lcn/jiguang/bh/b;->b(I)Ljava/nio/ByteBuffer;
move-result-object v0
if-nez v0, :cond_32
new-instance v0, Lcn/jiguang/be/f;
const/16 v1, -0x3e9
const-string v2, "parse error"
invoke-direct {v0, v1, v2}, Lcn/jiguang/be/f;-><init>(ILjava/lang/String;)V
throw v0
.end method
.method public close()V
.registers 3
const-string v0, "NioSocketClient"
const-string v1, "close this connect"
invoke-static {v0, v1}, Lcn/jiguang/ay/c;->c(Ljava/lang/String;Ljava/lang/String;)V
invoke-super {p0}, Lcn/jiguang/bh/a;->close()V
iget-object v0, p0, Lcn/jiguang/bh/b;->d:Ljava/nio/channels/Selector;
if-eqz v0, :cond_13
:try_start_e
iget-object v0, p0, Lcn/jiguang/bh/b;->d:Ljava/nio/channels/Selector;
invoke-virtual {v0}, Ljava/nio/channels/Selector;->close()V
:try_end_13
.catch Ljava/io/IOException; {:try_start_e .. :try_end_13} :catch_1c
:cond_13
:goto_13
iget-object v0, p0, Lcn/jiguang/bh/b;->b:Ljava/nio/channels/SocketChannel;
invoke-static {v0}, Lcn/jiguang/f/h;->a(Ljava/io/Closeable;)V
const/4 v0, 0x0
iput-object v0, p0, Lcn/jiguang/bh/b;->b:Ljava/nio/channels/SocketChannel;
return-void
:catch_1c
move-exception v0
goto :goto_13
.end method