b.smali

.class public final Lcn/jiguang/an/b;
.super Lcn/jiguang/an/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/an/a;-><init>()V

    iput p1, p0, Lcn/jiguang/an/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/an/b;->h:Ljava/nio/ByteBuffer;

    iput p2, p0, Lcn/jiguang/an/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/an/b;->a()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/ai/a;->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_35

    :cond_14
    const-string v1, "NioSocketClient"

    const-string v2, "send error - invalide buffer"

    invoke-static {v1, v2}, Lcn/jiguang/ai/a;->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;

    const-string v4, "send data error:"

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

    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/ai/a;->h(Ljava/lang/String;Ljava/lang/String;)V

    invoke-virtual {p0}, Lcn/jiguang/an/b;->close()V

    goto :goto_e

    :cond_35
    :try_start_35
    iget-object v1, p0, Lcn/jiguang/an/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_57

    const-string v2, "NioSocketClient"

    new-instance v3, Ljava/lang/StringBuilder;

    const-string v4, "isWritable has send len:"

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

    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/ai/a;->a(Ljava/lang/String;Ljava/lang/String;)V

    :cond_55
    const/4 v0, 0x1

    goto :goto_e

    :cond_57
    if-gez v1, :cond_55

    const-string v2, "NioSocketClient"

    new-instance v3, Ljava/lang/StringBuilder;

    const-string v4, "isWritable error:"

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

    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/ai/a;->a(Ljava/lang/String;Ljava/lang/String;)V
    :try_end_6d
    .catch Ljava/lang/Exception; {:try_start_35 .. :try_end_6d} :catch_1c

    goto :goto_e
.end method


# virtual methods
.method public final declared-synchronized a(Ljava/lang/String;I)I
    .registers 13

    const/4 v2, 0x0

    const/16 v0, -0x3df

    const/16 v1, -0x3e2

    monitor-enter p0

    :try_start_6
    invoke-super {p0, p1, p2}, Lcn/jiguang/an/a;->a(Ljava/lang/String;I)I
    :try_end_9
    .catchall {:try_start_6 .. :try_end_9} :catchall_98

    :try_start_9
    invoke-static {}, Ljava/nio/channels/SocketChannel;->open()Ljava/nio/channels/SocketChannel;

    move-result-object v3

    iput-object v3, p0, Lcn/jiguang/an/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/an/b;->d:Ljava/nio/channels/Selector;

    iget-object v3, p0, Lcn/jiguang/an/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/an/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/ai/a;->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/an/b;->b:Ljava/nio/channels/SocketChannel;

    invoke-virtual {v3}, Ljava/nio/channels/SocketChannel;->finishConnect()Z

    move-result v3

    if-nez v3, :cond_5a

    iget-boolean v3, p0, Lcn/jiguang/an/b;->e:Z

    if-nez v3, :cond_45

    const-string v2, "NioSocketClient"

    const-string v3, "has close channel when connect..."

    invoke-static {v2, v3}, Lcn/jiguang/ai/a;->c(Ljava/lang/String;Ljava/lang/String;)V
    :try_end_43
    .catch Ljava/lang/Throwable; {:try_start_9 .. :try_end_43} :catch_66
    .catchall {:try_start_9 .. :try_end_43} :catchall_98

    :goto_43
    monitor-exit p0

    return v0

    :cond_45
    const-wide/16 v6, 0xa

    :try_start_47
    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/an/b;->close()V

    move v0, v1

    goto :goto_43

    :cond_5a
    iget-boolean v3, p0, Lcn/jiguang/an/b;->e:Z

    if-nez v3, :cond_84

    const-string v2, "NioSocketClient"

    const-string v3, "has close channel when connected..."

    invoke-static {v2, v3}, Lcn/jiguang/ai/a;->c(Ljava/lang/String;Ljava/lang/String;)V
    :try_end_65
    .catch Ljava/lang/Throwable; {:try_start_47 .. :try_end_65} :catch_66
    .catchall {:try_start_47 .. :try_end_65} :catchall_98

    goto :goto_43

    :catch_66
    move-exception v0

    :try_start_67
    const-string v2, "NioSocketClient"

    new-instance v3, Ljava/lang/StringBuilder;

    const-string v4, "tcp connect has failed:"

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

    invoke-virtual {v3, v0}, 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/ai/a;->h(Ljava/lang/String;Ljava/lang/String;)V

    invoke-virtual {p0}, Lcn/jiguang/an/b;->close()V

    instance-of v0, v0, Ljava/net/SocketTimeoutException;
    :try_end_80
    .catchall {:try_start_67 .. :try_end_80} :catchall_98

    if-eqz v0, :cond_95

    move v0, v1

    goto :goto_43

    :cond_84
    :try_start_84
    const-string v0, "NioSocketClient"

    const-string v3, "tcp connected"

    invoke-static {v0, v3}, Lcn/jiguang/ai/a;->c(Ljava/lang/String;Ljava/lang/String;)V

    iget-object v0, p0, Lcn/jiguang/an/b;->b:Ljava/nio/channels/SocketChannel;

    iget-object v3, p0, Lcn/jiguang/an/b;->d:Ljava/nio/channels/Selector;

    const/4 v4, 0x1

    invoke-virtual {v0, v3, v4}, Ljava/nio/channels/SocketChannel;->register(Ljava/nio/channels/Selector;I)Ljava/nio/channels/SelectionKey;
    :try_end_93
    .catch Ljava/lang/Throwable; {:try_start_84 .. :try_end_93} :catch_66
    .catchall {:try_start_84 .. :try_end_93} :catchall_98

    move v0, v2

    goto :goto_43

    :cond_95
    const/16 v0, -0x3e8

    goto :goto_43

    :catchall_98
    move-exception v0

    monitor-exit p0

    throw v0
.end method

.method public final 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/ai/a;->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;

    const-string v3, "send data length:"

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

    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/ai/a;->c(Ljava/lang/String;Ljava/lang/String;)V

    array-length v1, p1

    iget v2, p0, Lcn/jiguang/an/b;->g:I

    if-lt v1, v2, :cond_3f

    const-string v0, "NioSocketClient"

    new-instance v1, Ljava/lang/StringBuilder;

    const-string v2, "sendData failed, data length must less than "

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

    iget v2, p0, Lcn/jiguang/an/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/ai/a;->c(Ljava/lang/String;Ljava/lang/String;)V

    const/16 v0, 0x178a

    goto :goto_b

    :cond_3f
    invoke-direct {p0, p1}, Lcn/jiguang/an/b;->b([B)Z

    move-result v1

    if-eqz v1, :cond_b

    const/4 v0, 0x0

    goto :goto_b
.end method

.method public final a(I)Ljava/nio/ByteBuffer;
    .registers 12

    const/high16 v4, 0x100000

    const/16 v9, -0x3e2

    const/16 v8, -0x3e5

    const/4 v2, 0x0

    :try_start_7
    invoke-virtual {p0}, Lcn/jiguang/an/b;->a()Z

    move-result v0

    if-nez v0, :cond_26

    new-instance v0, Lcn/jiguang/ah/f;

    const/16 v1, -0x3df

    const-string v2, "recv error,the connect is invalid"

    invoke-direct {v0, v1, v2}, Lcn/jiguang/ah/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_149

    new-instance v1, Lcn/jiguang/ah/f;

    invoke-virtual {v0}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;

    move-result-object v0

    invoke-direct {v1, v9, v0}, Lcn/jiguang/ah/f;-><init>(ILjava/lang/String;)V

    throw v1

    :cond_26
    :try_start_26
    invoke-virtual {p0}, Lcn/jiguang/an/b;->b()I

    move-result v0

    if-lez v0, :cond_33

    invoke-virtual {p0, v0}, Lcn/jiguang/an/b;->b(I)Ljava/nio/ByteBuffer;

    move-result-object v0

    if-eqz v0, :cond_33

    :cond_32
    return-object v0

    :cond_33
    move v3, v4

    :cond_34
    invoke-virtual {p0}, Lcn/jiguang/an/b;->a()Z

    move-result v0

    if-eqz v0, :cond_15a

    iget v0, p0, Lcn/jiguang/an/b;->c:I

    if-ge v0, v3, :cond_15a

    if-lez p1, :cond_73

    iget-object v0, p0, Lcn/jiguang/an/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_7a

    const-string v1, "NioSocketClient"

    new-instance v5, Ljava/lang/StringBuilder;

    const-string v6, "readSelect:"

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

    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/ai/a;->c(Ljava/lang/String;Ljava/lang/String;)V

    if-lez p1, :cond_34

    new-instance v0, Lcn/jiguang/ah/f;

    const/16 v1, -0x3e2

    const-string v2, "recv time out"

    invoke-direct {v0, v1, v2}, Lcn/jiguang/ah/f;-><init>(ILjava/lang/String;)V

    throw v0

    :cond_73
    iget-object v0, p0, Lcn/jiguang/an/b;->d:Ljava/nio/channels/Selector;

    invoke-virtual {v0}, Ljava/nio/channels/Selector;->select()I

    move-result v0

    goto :goto_47

    :cond_7a
    iget-object v0, p0, Lcn/jiguang/an/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_84
    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_143

    iget-object v0, p0, Lcn/jiguang/an/b;->h:Ljava/nio/ByteBuffer;

    invoke-virtual {v1, v0}, Ljava/nio/channels/SocketChannel;->read(Ljava/nio/ByteBuffer;)I

    move-result v1

    if-gez v1, :cond_bb

    new-instance v0, Lcn/jiguang/ah/f;

    const/16 v2, -0x3e4

    new-instance v3, Ljava/lang/StringBuilder;

    const-string v4, "read len < 0:"

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

    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/ah/f;-><init>(ILjava/lang/String;)V

    throw v0

    :cond_bb
    iget-object v0, p0, Lcn/jiguang/an/b;->h:Ljava/nio/ByteBuffer;

    invoke-virtual {v0}, Ljava/nio/ByteBuffer;->flip()Ljava/nio/Buffer;

    iget-object v0, p0, Lcn/jiguang/an/b;->h:Ljava/nio/ByteBuffer;

    invoke-virtual {v0}, Ljava/nio/ByteBuffer;->limit()I

    move-result v0

    iget-object v2, p0, Lcn/jiguang/an/b;->a:Ljava/nio/ByteBuffer;

    invoke-virtual {v2}, Ljava/nio/ByteBuffer;->remaining()I

    move-result v2

    if-ge v2, v0, :cond_f5

    new-instance v1, Lcn/jiguang/ah/f;

    const/16 v2, -0x3e4

    new-instance v3, Ljava/lang/StringBuilder;

    const-string v4, "the total buf remaining less than readLen,remaining:"

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

    iget-object v4, p0, Lcn/jiguang/an/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, 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/ah/f;-><init>(ILjava/lang/String;)V

    throw v1

    :cond_f5
    iget-object v2, p0, Lcn/jiguang/an/b;->a:Ljava/nio/ByteBuffer;

    iget-object v6, p0, Lcn/jiguang/an/b;->h:Ljava/nio/ByteBuffer;

    invoke-virtual {v2, v6}, Ljava/nio/ByteBuffer;->put(Ljava/nio/ByteBuffer;)Ljava/nio/ByteBuffer;

    iget v2, p0, Lcn/jiguang/an/b;->c:I

    add-int/2addr v2, v0

    iput v2, p0, Lcn/jiguang/an/b;->c:I

    iget-object v2, p0, Lcn/jiguang/an/b;->h:Ljava/nio/ByteBuffer;

    invoke-virtual {v2}, Ljava/nio/ByteBuffer;->compact()Ljava/nio/ByteBuffer;

    iget v2, p0, Lcn/jiguang/an/b;->c:I

    iget v6, p0, Lcn/jiguang/an/b;->f:I

    if-ge v2, v6, :cond_13e

    const-string v2, "NioSocketClient"

    new-instance v6, Ljava/lang/StringBuilder;

    const-string v7, "totalbuf can not parse head:"

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

    iget v7, p0, Lcn/jiguang/an/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, v0}, 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, 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/ai/a;->c(Ljava/lang/String;Ljava/lang/String;)V

    move v1, v3

    :goto_137
    invoke-interface {v5}, Ljava/util/Iterator;->remove()V

    move v2, v0

    move v3, v1

    goto/16 :goto_84

    :cond_13e
    invoke-virtual {p0}, Lcn/jiguang/an/b;->b()I

    move-result v1

    goto :goto_137

    :cond_143
    invoke-virtual {v0}, Ljava/nio/channels/SelectionKey;->isWritable()Z
    :try_end_146
    .catch Ljava/lang/Throwable; {:try_start_26 .. :try_end_146} :catch_17

    move v0, v2

    move v1, v3

    goto :goto_137

    :cond_149
    instance-of v1, v0, Lcn/jiguang/ah/f;

    if-eqz v1, :cond_150

    check-cast v0, Lcn/jiguang/ah/f;

    throw v0

    :cond_150
    new-instance v1, Lcn/jiguang/ah/f;

    invoke-virtual {v0}, Ljava/lang/Throwable;->getMessage()Ljava/lang/String;

    move-result-object v0

    invoke-direct {v1, v8, v0}, Lcn/jiguang/ah/f;-><init>(ILjava/lang/String;)V

    throw v1

    :cond_15a
    if-ne v3, v4, :cond_164

    new-instance v0, Lcn/jiguang/ah/f;

    const-string v1, "recv empty data or tcp has close"

    invoke-direct {v0, v8, v1}, Lcn/jiguang/ah/f;-><init>(ILjava/lang/String;)V

    throw v0

    :cond_164
    const-string v0, "NioSocketClient"

    new-instance v1, Ljava/lang/StringBuilder;

    const-string v4, "read len:"

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

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

    move-result-object v1

    const-string v2, ",recvTotalLen:"

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

    move-result-object v1

    iget v2, p0, Lcn/jiguang/an/b;->c:I

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

    move-result-object v1

    const-string v2, ",shouldLen:"

    invoke-virtual {v1, v2}, 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

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

    move-result-object v1

    invoke-static {v0, v1}, Lcn/jiguang/ai/a;->c(Ljava/lang/String;Ljava/lang/String;)V

    invoke-virtual {p0, v3}, Lcn/jiguang/an/b;->b(I)Ljava/nio/ByteBuffer;

    move-result-object v0

    if-nez v0, :cond_32

    new-instance v0, Lcn/jiguang/ah/f;

    const/16 v1, -0x3e9

    const-string v2, "parse error"

    invoke-direct {v0, v1, v2}, Lcn/jiguang/ah/f;-><init>(ILjava/lang/String;)V

    throw v0
.end method

.method public final close()V
    .registers 3

    const-string v0, "NioSocketClient"

    const-string v1, "close this connect"

    invoke-static {v0, v1}, Lcn/jiguang/ai/a;->c(Ljava/lang/String;Ljava/lang/String;)V

    invoke-super {p0}, Lcn/jiguang/an/a;->close()V

    iget-object v0, p0, Lcn/jiguang/an/b;->d:Ljava/nio/channels/Selector;

    if-eqz v0, :cond_13

    :try_start_e
    iget-object v0, p0, Lcn/jiguang/an/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/an/b;->b:Ljava/nio/channels/SocketChannel;

    invoke-static {v0}, Lcn/jiguang/ap/k;->a(Ljava/io/Closeable;)V

    const/4 v0, 0x0

    iput-object v0, p0, Lcn/jiguang/an/b;->b:Ljava/nio/channels/SocketChannel;

    return-void

    :catch_1c
    move-exception v0

    goto :goto_13
.end method