FullUploadLogTask$1.smali

.class Lio/rong/rtlog/upload/FullUploadLogTask$1;
.super Lio/rong/rtlog/RtFullListener;
.source "FullUploadLogTask.java"


# annotations
.annotation system Ldalvik/annotation/EnclosingMethod;
    value = Lio/rong/rtlog/upload/FullUploadLogTask;->getLogFile()Ljava/lang/String;
.end annotation

.annotation system Ldalvik/annotation/InnerClass;
    accessFlags = 0x0
    name = null
.end annotation


# instance fields
.field final synthetic this$0:Lio/rong/rtlog/upload/FullUploadLogTask;

.field final synthetic val$fileWriteLength:Ljava/util/concurrent/atomic/AtomicLong;

.field final synthetic val$logFileInputRef:Ljava/io/FileOutputStream;

.field final synthetic val$logReadLatch:Ljava/util/concurrent/CountDownLatch;


# direct methods
.method constructor <init>(Lio/rong/rtlog/upload/FullUploadLogTask;Ljava/io/FileOutputStream;Ljava/util/concurrent/atomic/AtomicLong;Ljava/util/concurrent/CountDownLatch;)V
    .registers 5

    .line 1
    iput-object p1, p0, Lio/rong/rtlog/upload/FullUploadLogTask$1;->this$0:Lio/rong/rtlog/upload/FullUploadLogTask;

    iput-object p2, p0, Lio/rong/rtlog/upload/FullUploadLogTask$1;->val$logFileInputRef:Ljava/io/FileOutputStream;

    iput-object p3, p0, Lio/rong/rtlog/upload/FullUploadLogTask$1;->val$fileWriteLength:Ljava/util/concurrent/atomic/AtomicLong;

    iput-object p4, p0, Lio/rong/rtlog/upload/FullUploadLogTask$1;->val$logReadLatch:Ljava/util/concurrent/CountDownLatch;

    invoke-direct {p0}, Lio/rong/rtlog/RtFullListener;-><init>()V

    return-void
.end method


# virtual methods
.method public NotifyFull()V
    .registers 6

    .line 1
    invoke-virtual {p0}, Lio/rong/rtlog/RtFullListener;->getByteBuffer()Ljava/nio/ByteBuffer;

    move-result-object v0

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

    .line 3
    invoke-virtual {v0}, Ljava/nio/ByteBuffer;->remaining()I

    move-result v1

    .line 4
    new-array v1, v1, [B

    .line 5
    invoke-virtual {v0, v1}, Ljava/nio/ByteBuffer;->get([B)Ljava/nio/ByteBuffer;

    .line 6
    invoke-virtual {v0}, Ljava/nio/ByteBuffer;->clear()Ljava/nio/Buffer;

    .line 7
    new-instance v2, Ljava/lang/StringBuilder;

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

    new-instance v3, Ljava/lang/String;

    invoke-direct {v3, v1}, Ljava/lang/String;-><init>([B)V

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

    move-result-object v1

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

    const-string v1, "\r\n"

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

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

    move-result-object v1

    .line 8
    :try_start_2d
    iget-object v2, p0, Lio/rong/rtlog/upload/FullUploadLogTask$1;->val$logFileInputRef:Ljava/io/FileOutputStream;

    invoke-virtual {v1}, Ljava/lang/String;->getBytes()[B

    move-result-object v3

    invoke-virtual {v2, v3}, Ljava/io/FileOutputStream;->write([B)V
    :try_end_36
    .catch Ljava/io/IOException; {:try_start_2d .. :try_end_36} :catch_37

    goto :goto_41

    :catch_37
    move-exception v2

    .line 9
    # getter for: Lio/rong/rtlog/upload/FullUploadLogTask;->TAG:Ljava/lang/String;
    invoke-static {}, Lio/rong/rtlog/upload/FullUploadLogTask;->access$000()Ljava/lang/String;

    move-result-object v3

    const-string v4, "getLogFile write log error"

    invoke-static {v3, v4, v2}, Lio/rong/common/rlog/RLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I

    .line 10
    :goto_41
    invoke-virtual {v0}, Ljava/nio/ByteBuffer;->clear()Ljava/nio/Buffer;

    .line 11
    iget-object v0, p0, Lio/rong/rtlog/upload/FullUploadLogTask$1;->val$fileWriteLength:Ljava/util/concurrent/atomic/AtomicLong;

    invoke-virtual {v1}, Ljava/lang/String;->length()I

    move-result v1

    int-to-long v1, v1

    invoke-virtual {v0, v1, v2}, Ljava/util/concurrent/atomic/AtomicLong;->getAndAdd(J)J

    return-void
.end method

.method public NotifyFullEnd(I)V
    .registers 6

    .line 1
    # getter for: Lio/rong/rtlog/upload/FullUploadLogTask;->TAG:Ljava/lang/String;
    invoke-static {}, Lio/rong/rtlog/upload/FullUploadLogTask;->access$000()Ljava/lang/String;

    move-result-object v0

    new-instance v1, Ljava/lang/StringBuilder;

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

    const-string v2, "getLogFile NotifyFullEnd result:"

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

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

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

    move-result-object p1

    invoke-static {v0, p1}, Lio/rong/common/rlog/RLog;->d(Ljava/lang/String;Ljava/lang/String;)I

    .line 2
    iget-object p1, p0, Lio/rong/rtlog/upload/FullUploadLogTask$1;->val$fileWriteLength:Ljava/util/concurrent/atomic/AtomicLong;

    invoke-virtual {p1}, Ljava/util/concurrent/atomic/AtomicLong;->get()J

    move-result-wide v0

    const-wide/16 v2, 0x0

    cmp-long p1, v0, v2

    if-nez p1, :cond_3a

    .line 3
    :try_start_24
    iget-object p1, p0, Lio/rong/rtlog/upload/FullUploadLogTask$1;->val$logFileInputRef:Ljava/io/FileOutputStream;

    const-string v0, "no data"

    invoke-virtual {v0}, Ljava/lang/String;->getBytes()[B

    move-result-object v0

    invoke-virtual {p1, v0}, Ljava/io/FileOutputStream;->write([B)V
    :try_end_2f
    .catch Ljava/io/IOException; {:try_start_24 .. :try_end_2f} :catch_30

    goto :goto_3a

    :catch_30
    move-exception p1

    .line 4
    # getter for: Lio/rong/rtlog/upload/FullUploadLogTask;->TAG:Ljava/lang/String;
    invoke-static {}, Lio/rong/rtlog/upload/FullUploadLogTask;->access$000()Ljava/lang/String;

    move-result-object v0

    const-string v1, "getLogFile write no data error"

    invoke-static {v0, v1, p1}, Lio/rong/common/rlog/RLog;->e(Ljava/lang/String;Ljava/lang/String;Ljava/lang/Throwable;)I

    .line 5
    :cond_3a
    :goto_3a
    iget-object p1, p0, Lio/rong/rtlog/upload/FullUploadLogTask$1;->val$logReadLatch:Ljava/util/concurrent/CountDownLatch;

    invoke-virtual {p1}, Ljava/util/concurrent/CountDownLatch;->countDown()V

    return-void
.end method