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