QueueFile.smali
.class Lcom/google/firebase/crashlytics/internal/log/QueueFile;
.super Ljava/lang/Object;
.source "QueueFile.java"
# interfaces
.implements Ljava/io/Closeable;
# annotations
.annotation system Ldalvik/annotation/MemberClasses;
value = {
Lcom/google/firebase/crashlytics/internal/log/QueueFile$ElementReader;,
Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;,
Lcom/google/firebase/crashlytics/internal/log/QueueFile$ElementInputStream;
}
.end annotation
# static fields
.field static final HEADER_LENGTH:I = 0x10
.field private static final INITIAL_LENGTH:I = 0x1000
.field private static final LOGGER:Ljava/util/logging/Logger;
# instance fields
.field private final buffer:[B
.field private elementCount:I
.field fileLength:I
.field private first:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
.field private last:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
.field private final raf:Ljava/io/RandomAccessFile;
# direct methods
.method static constructor <clinit>()V
.registers 1
.line 61
const-class v0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;
invoke-virtual {v0}, Ljava/lang/Class;->getName()Ljava/lang/String;
move-result-object v0
invoke-static {v0}, Ljava/util/logging/Logger;->getLogger(Ljava/lang/String;)Ljava/util/logging/Logger;
move-result-object v0
sput-object v0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->LOGGER:Ljava/util/logging/Logger;
return-void
.end method
.method public constructor <init>(Ljava/io/File;)V
.registers 3
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 115
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
const/16 v0, 0x10
new-array v0, v0, [B
.line 109
iput-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->buffer:[B
.line 116
invoke-virtual {p1}, Ljava/io/File;->exists()Z
move-result v0
if-nez v0, :cond_12
.line 117
invoke-static {p1}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->initialize(Ljava/io/File;)V
.line 119
:cond_12
invoke-static {p1}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->open(Ljava/io/File;)Ljava/io/RandomAccessFile;
move-result-object p1
iput-object p1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
.line 120
invoke-direct {p0}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->readHeader()V
return-void
.end method
.method constructor <init>(Ljava/io/RandomAccessFile;)V
.registers 3
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 124
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
const/16 v0, 0x10
new-array v0, v0, [B
.line 109
iput-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->buffer:[B
.line 125
iput-object p1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
.line 126
invoke-direct {p0}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->readHeader()V
return-void
.end method
.method static synthetic access$100(Lcom/google/firebase/crashlytics/internal/log/QueueFile;I)I
.registers 2
.line 60
invoke-direct {p0, p1}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->wrapPosition(I)I
move-result p0
return p0
.end method
.method static synthetic access$200(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
.registers 2
.line 60
invoke-static {p0, p1}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->nonNull(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
move-result-object p0
return-object p0
.end method
.method static synthetic access$300(Lcom/google/firebase/crashlytics/internal/log/QueueFile;I[BII)V
.registers 5
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 60
invoke-direct {p0, p1, p2, p3, p4}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->ringRead(I[BII)V
return-void
.end method
.method static synthetic access$400(Lcom/google/firebase/crashlytics/internal/log/QueueFile;)Ljava/io/RandomAccessFile;
.registers 1
.line 60
iget-object p0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
return-object p0
.end method
.method private expandIfNecessary(I)V
.registers 12
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
add-int/lit8 p1, p1, 0x4
.line 366
invoke-direct {p0}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->remainingBytes()I
move-result v0
if-lt v0, p1, :cond_9
return-void
.line 372
:cond_9
iget v1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->fileLength:I
:cond_b
add-int/2addr v0, v1
shl-int/lit8 v1, v1, 0x1
if-lt v0, p1, :cond_b
.line 381
invoke-direct {p0, v1}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->setLength(I)V
.line 384
iget-object p1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->last:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget p1, p1, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->position:I
add-int/lit8 p1, p1, 0x4
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->last:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget v0, v0, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->length:I
add-int/2addr p1, v0
invoke-direct {p0, p1}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->wrapPosition(I)I
move-result p1
.line 387
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->first:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget v0, v0, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->position:I
if-ge p1, v0, :cond_4c
.line 388
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
invoke-virtual {v0}, Ljava/io/RandomAccessFile;->getChannel()Ljava/nio/channels/FileChannel;
move-result-object v7
.line 389
iget v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->fileLength:I
int-to-long v2, v0
invoke-virtual {v7, v2, v3}, Ljava/nio/channels/FileChannel;->position(J)Ljava/nio/channels/FileChannel;
add-int/lit8 p1, p1, -0x4
const-wide/16 v3, 0x10
int-to-long v8, p1
move-object v2, v7
move-wide v5, v8
.line 391
invoke-virtual/range {v2 .. v7}, Ljava/nio/channels/FileChannel;->transferTo(JJLjava/nio/channels/WritableByteChannel;)J
move-result-wide v2
cmp-long p1, v2, v8
if-nez p1, :cond_44
goto :goto_4c
.line 392
:cond_44
new-instance p1, Ljava/lang/AssertionError;
const-string v0, "Copied insufficient number of bytes!"
invoke-direct {p1, v0}, Ljava/lang/AssertionError;-><init>(Ljava/lang/Object;)V
throw p1
.line 397
:cond_4c
:goto_4c
iget-object p1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->last:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget p1, p1, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->position:I
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->first:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget v0, v0, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->position:I
if-ge p1, v0, :cond_74
.line 398
iget p1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->fileLength:I
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->last:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget v0, v0, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->position:I
add-int/2addr p1, v0
add-int/lit8 p1, p1, -0x10
.line 399
iget v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->elementCount:I
iget-object v2, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->first:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget v2, v2, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->position:I
invoke-direct {p0, v1, v0, v2, p1}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->writeHeader(IIII)V
.line 400
new-instance v0, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget-object v2, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->last:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget v2, v2, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->length:I
invoke-direct {v0, p1, v2}, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;-><init>(II)V
iput-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->last:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
goto :goto_81
.line 402
:cond_74
iget p1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->elementCount:I
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->first:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget v0, v0, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->position:I
iget-object v2, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->last:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget v2, v2, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->position:I
invoke-direct {p0, v1, p1, v0, v2}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->writeHeader(IIII)V
.line 405
:goto_81
iput v1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->fileLength:I
return-void
.end method
.method private static initialize(Ljava/io/File;)V
.registers 7
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 201
new-instance v0, Ljava/io/File;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
invoke-virtual {p0}, Ljava/io/File;->getPath()Ljava/lang/String;
move-result-object v2
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const-string v2, ".tmp"
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Ljava/io/File;-><init>(Ljava/lang/String;)V
.line 202
invoke-static {v0}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->open(Ljava/io/File;)Ljava/io/RandomAccessFile;
move-result-object v1
const-wide/16 v2, 0x1000
.line 204
:try_start_20
invoke-virtual {v1, v2, v3}, Ljava/io/RandomAccessFile;->setLength(J)V
const-wide/16 v2, 0x0
.line 205
invoke-virtual {v1, v2, v3}, Ljava/io/RandomAccessFile;->seek(J)V
const/16 v2, 0x10
new-array v2, v2, [B
const/4 v3, 0x4
new-array v3, v3, [I
const/16 v4, 0x1000
const/4 v5, 0x0
aput v4, v3, v5
const/4 v4, 0x1
aput v5, v3, v4
const/4 v4, 0x2
aput v5, v3, v4
const/4 v4, 0x3
aput v5, v3, v4
.line 207
invoke-static {v2, v3}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->writeInts([B[I)V
.line 208
invoke-virtual {v1, v2}, Ljava/io/RandomAccessFile;->write([B)V
:try_end_43
.catchall {:try_start_20 .. :try_end_43} :catchall_55
.line 210
invoke-virtual {v1}, Ljava/io/RandomAccessFile;->close()V
.line 214
invoke-virtual {v0, p0}, Ljava/io/File;->renameTo(Ljava/io/File;)Z
move-result p0
if-eqz p0, :cond_4d
return-void
.line 215
:cond_4d
new-instance p0, Ljava/io/IOException;
const-string v0, "Rename failed!"
invoke-direct {p0, v0}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw p0
:catchall_55
move-exception p0
.line 210
invoke-virtual {v1}, Ljava/io/RandomAccessFile;->close()V
.line 211
throw p0
.end method
.method private static nonNull(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
.registers 2
.annotation system Ldalvik/annotation/Signature;
value = {
"<T:",
"Ljava/lang/Object;",
">(TT;",
"Ljava/lang/String;",
")TT;"
}
.end annotation
if-eqz p0, :cond_3
return-object p0
.line 453
:cond_3
new-instance p0, Ljava/lang/NullPointerException;
invoke-direct {p0, p1}, Ljava/lang/NullPointerException;-><init>(Ljava/lang/String;)V
throw p0
.end method
.method private static open(Ljava/io/File;)Ljava/io/RandomAccessFile;
.registers 3
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/FileNotFoundException;
}
.end annotation
.line 221
new-instance v0, Ljava/io/RandomAccessFile;
const-string v1, "rwd"
invoke-direct {v0, p0, v1}, Ljava/io/RandomAccessFile;-><init>(Ljava/io/File;Ljava/lang/String;)V
return-object v0
.end method
.method private readElement(I)Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
.registers 5
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
if-nez p1, :cond_5
.line 192
sget-object p1, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->NULL:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
return-object p1
.line 194
:cond_5
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
int-to-long v1, p1
invoke-virtual {v0, v1, v2}, Ljava/io/RandomAccessFile;->seek(J)V
.line 195
new-instance v0, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget-object v1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
invoke-virtual {v1}, Ljava/io/RandomAccessFile;->readInt()I
move-result v1
invoke-direct {v0, p1, v1}, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;-><init>(II)V
return-object v0
.end method
.method private readHeader()V
.registers 6
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 162
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
const-wide/16 v1, 0x0
invoke-virtual {v0, v1, v2}, Ljava/io/RandomAccessFile;->seek(J)V
.line 163
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
iget-object v1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->buffer:[B
invoke-virtual {v0, v1}, Ljava/io/RandomAccessFile;->readFully([B)V
.line 164
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->buffer:[B
const/4 v1, 0x0
invoke-static {v0, v1}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->readInt([BI)I
move-result v0
iput v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->fileLength:I
int-to-long v0, v0
.line 165
iget-object v2, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
invoke-virtual {v2}, Ljava/io/RandomAccessFile;->length()J
move-result-wide v2
cmp-long v4, v0, v2
if-gtz v4, :cond_48
.line 169
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->buffer:[B
const/4 v1, 0x4
invoke-static {v0, v1}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->readInt([BI)I
move-result v0
iput v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->elementCount:I
.line 170
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->buffer:[B
const/16 v1, 0x8
invoke-static {v0, v1}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->readInt([BI)I
move-result v0
.line 171
iget-object v1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->buffer:[B
const/16 v2, 0xc
invoke-static {v1, v2}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->readInt([BI)I
move-result v1
.line 172
invoke-direct {p0, v0}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->readElement(I)Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
move-result-object v0
iput-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->first:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
.line 173
invoke-direct {p0, v1}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->readElement(I)Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
move-result-object v0
iput-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->last:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
return-void
.line 166
:cond_48
new-instance v0, Ljava/io/IOException;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "File is truncated. Expected length: "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v2, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->fileLength:I
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v2, ", Actual length: "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v2, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
.line 167
invoke-virtual {v2}, Ljava/io/RandomAccessFile;->length()J
move-result-wide v2
invoke-virtual {v1, v2, v3}, Ljava/lang/StringBuilder;->append(J)Ljava/lang/StringBuilder;
invoke-virtual {v1}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v1
invoke-direct {v0, v1}, Ljava/io/IOException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method private static readInt([BI)I
.registers 4
.line 154
aget-byte v0, p0, p1
and-int/lit16 v0, v0, 0xff
shl-int/lit8 v0, v0, 0x18
add-int/lit8 v1, p1, 0x1
aget-byte v1, p0, v1
and-int/lit16 v1, v1, 0xff
shl-int/lit8 v1, v1, 0x10
add-int/2addr v0, v1
add-int/lit8 v1, p1, 0x2
aget-byte v1, p0, v1
and-int/lit16 v1, v1, 0xff
shl-int/lit8 v1, v1, 0x8
add-int/2addr v0, v1
add-int/lit8 p1, p1, 0x3
aget-byte p0, p0, p1
and-int/lit16 p0, p0, 0xff
add-int/2addr v0, p0
return v0
.end method
.method private remainingBytes()I
.registers 3
.line 351
iget v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->fileLength:I
invoke-virtual {p0}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->usedBytes()I
move-result v1
sub-int/2addr v0, v1
return v0
.end method
.method private ringRead(I[BII)V
.registers 9
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 261
invoke-direct {p0, p1}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->wrapPosition(I)I
move-result p1
add-int v0, p1, p4
.line 262
iget v1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->fileLength:I
if-gt v0, v1, :cond_16
.line 263
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
int-to-long v1, p1
invoke-virtual {v0, v1, v2}, Ljava/io/RandomAccessFile;->seek(J)V
.line 264
iget-object p1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
invoke-virtual {p1, p2, p3, p4}, Ljava/io/RandomAccessFile;->readFully([BII)V
goto :goto_30
:cond_16
sub-int/2addr v1, p1
.line 269
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
int-to-long v2, p1
invoke-virtual {v0, v2, v3}, Ljava/io/RandomAccessFile;->seek(J)V
.line 270
iget-object p1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
invoke-virtual {p1, p2, p3, v1}, Ljava/io/RandomAccessFile;->readFully([BII)V
.line 271
iget-object p1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
const-wide/16 v2, 0x10
invoke-virtual {p1, v2, v3}, Ljava/io/RandomAccessFile;->seek(J)V
.line 272
iget-object p1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
add-int/2addr p3, v1
sub-int/2addr p4, v1
invoke-virtual {p1, p2, p3, p4}, Ljava/io/RandomAccessFile;->readFully([BII)V
:goto_30
return-void
.end method
.method private ringWrite(I[BII)V
.registers 9
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 238
invoke-direct {p0, p1}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->wrapPosition(I)I
move-result p1
add-int v0, p1, p4
.line 239
iget v1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->fileLength:I
if-gt v0, v1, :cond_16
.line 240
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
int-to-long v1, p1
invoke-virtual {v0, v1, v2}, Ljava/io/RandomAccessFile;->seek(J)V
.line 241
iget-object p1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
invoke-virtual {p1, p2, p3, p4}, Ljava/io/RandomAccessFile;->write([BII)V
goto :goto_30
:cond_16
sub-int/2addr v1, p1
.line 246
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
int-to-long v2, p1
invoke-virtual {v0, v2, v3}, Ljava/io/RandomAccessFile;->seek(J)V
.line 247
iget-object p1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
invoke-virtual {p1, p2, p3, v1}, Ljava/io/RandomAccessFile;->write([BII)V
.line 248
iget-object p1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
const-wide/16 v2, 0x10
invoke-virtual {p1, v2, v3}, Ljava/io/RandomAccessFile;->seek(J)V
.line 249
iget-object p1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
add-int/2addr p3, v1
sub-int/2addr p4, v1
invoke-virtual {p1, p2, p3, p4}, Ljava/io/RandomAccessFile;->write([BII)V
:goto_30
return-void
.end method
.method private setLength(I)V
.registers 5
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 411
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
int-to-long v1, p1
invoke-virtual {v0, v1, v2}, Ljava/io/RandomAccessFile;->setLength(J)V
.line 412
iget-object p1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
invoke-virtual {p1}, Ljava/io/RandomAccessFile;->getChannel()Ljava/nio/channels/FileChannel;
move-result-object p1
const/4 v0, 0x1
invoke-virtual {p1, v0}, Ljava/nio/channels/FileChannel;->force(Z)V
return-void
.end method
.method private wrapPosition(I)I
.registers 3
.line 226
iget v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->fileLength:I
if-ge p1, v0, :cond_5
goto :goto_8
:cond_5
add-int/lit8 p1, p1, 0x10
sub-int/2addr p1, v0
:goto_8
return p1
.end method
.method private writeHeader(IIII)V
.registers 8
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 184
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->buffer:[B
const/4 v1, 0x4
new-array v1, v1, [I
const/4 v2, 0x0
aput p1, v1, v2
const/4 p1, 0x1
aput p2, v1, p1
const/4 p1, 0x2
aput p3, v1, p1
const/4 p1, 0x3
aput p4, v1, p1
invoke-static {v0, v1}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->writeInts([B[I)V
.line 185
iget-object p1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
const-wide/16 p2, 0x0
invoke-virtual {p1, p2, p3}, Ljava/io/RandomAccessFile;->seek(J)V
.line 186
iget-object p1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
iget-object p2, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->buffer:[B
invoke-virtual {p1, p2}, Ljava/io/RandomAccessFile;->write([B)V
return-void
.end method
.method private static writeInt([BII)V
.registers 5
shr-int/lit8 v0, p2, 0x18
int-to-byte v0, v0
.line 134
aput-byte v0, p0, p1
add-int/lit8 v0, p1, 0x1
shr-int/lit8 v1, p2, 0x10
int-to-byte v1, v1
.line 135
aput-byte v1, p0, v0
add-int/lit8 v0, p1, 0x2
shr-int/lit8 v1, p2, 0x8
int-to-byte v1, v1
.line 136
aput-byte v1, p0, v0
add-int/lit8 p1, p1, 0x3
int-to-byte p2, p2
.line 137
aput-byte p2, p0, p1
return-void
.end method
.method private static varargs writeInts([B[I)V
.registers 6
.line 146
array-length v0, p1
const/4 v1, 0x0
const/4 v2, 0x0
:goto_3
if-ge v1, v0, :cond_f
aget v3, p1, v1
.line 147
invoke-static {p0, v2, v3}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->writeInt([BII)V
add-int/lit8 v2, v2, 0x4
add-int/lit8 v1, v1, 0x1
goto :goto_3
:cond_f
return-void
.end method
# virtual methods
.method public add([B)V
.registers 4
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
.line 282
array-length v0, p1
const/4 v1, 0x0
invoke-virtual {p0, p1, v1, v0}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->add([BII)V
return-void
.end method
.method public declared-synchronized add([BII)V
.registers 10
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
monitor-enter p0
:try_start_1
const-string v0, "buffer"
.line 295
invoke-static {p1, v0}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->nonNull(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
or-int v0, p2, p3
if-ltz v0, :cond_63
.line 296
array-length v0, p1
sub-int/2addr v0, p2
if-gt p3, v0, :cond_63
.line 300
invoke-direct {p0, p3}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->expandIfNecessary(I)V
.line 303
invoke-virtual {p0}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->isEmpty()Z
move-result v0
const/4 v1, 0x4
if-eqz v0, :cond_1b
const/16 v2, 0x10
goto :goto_29
.line 307
:cond_1b
iget-object v2, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->last:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget v2, v2, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->position:I
add-int/2addr v2, v1
iget-object v3, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->last:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget v3, v3, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->length:I
add-int/2addr v2, v3
invoke-direct {p0, v2}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->wrapPosition(I)I
move-result v2
.line 308
:goto_29
new-instance v3, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
invoke-direct {v3, v2, p3}, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;-><init>(II)V
.line 311
iget-object v2, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->buffer:[B
const/4 v4, 0x0
invoke-static {v2, v4, p3}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->writeInt([BII)V
.line 312
iget v2, v3, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->position:I
iget-object v5, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->buffer:[B
invoke-direct {p0, v2, v5, v4, v1}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->ringWrite(I[BII)V
.line 315
iget v2, v3, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->position:I
add-int/2addr v2, v1
invoke-direct {p0, v2, p1, p2, p3}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->ringWrite(I[BII)V
if-eqz v0, :cond_46
.line 318
iget p1, v3, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->position:I
goto :goto_4a
:cond_46
iget-object p1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->first:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget p1, p1, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->position:I
.line 319
:goto_4a
iget p2, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->fileLength:I
iget p3, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->elementCount:I
add-int/lit8 p3, p3, 0x1
iget v1, v3, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->position:I
invoke-direct {p0, p2, p3, p1, v1}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->writeHeader(IIII)V
.line 320
iput-object v3, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->last:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
.line 321
iget p1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->elementCount:I
add-int/lit8 p1, p1, 0x1
iput p1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->elementCount:I
if-eqz v0, :cond_61
.line 323
iput-object v3, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->first:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
:try_end_61
.catchall {:try_start_1 .. :try_end_61} :catchall_69
.line 325
:cond_61
monitor-exit p0
return-void
.line 297
:cond_63
:try_start_63
new-instance p1, Ljava/lang/IndexOutOfBoundsException;
invoke-direct {p1}, Ljava/lang/IndexOutOfBoundsException;-><init>()V
throw p1
:try_end_69
.catchall {:try_start_63 .. :try_end_69} :catchall_69
:catchall_69
move-exception p1
monitor-exit p0
throw p1
.end method
.method public declared-synchronized clear()V
.registers 3
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
monitor-enter p0
const/4 v0, 0x0
const/16 v1, 0x1000
.line 529
:try_start_4
invoke-direct {p0, v1, v0, v0, v0}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->writeHeader(IIII)V
.line 530
iput v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->elementCount:I
.line 531
sget-object v0, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->NULL:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iput-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->first:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
.line 532
sget-object v0, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->NULL:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iput-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->last:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
.line 533
iget v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->fileLength:I
if-le v0, v1, :cond_18
invoke-direct {p0, v1}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->setLength(I)V
.line 534
:cond_18
iput v1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->fileLength:I
:try_end_1a
.catchall {:try_start_4 .. :try_end_1a} :catchall_1c
.line 535
monitor-exit p0
return-void
:catchall_1c
move-exception v0
monitor-exit p0
throw v0
.end method
.method public declared-synchronized close()V
.registers 2
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
monitor-enter p0
.line 539
:try_start_1
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->raf:Ljava/io/RandomAccessFile;
invoke-virtual {v0}, Ljava/io/RandomAccessFile;->close()V
:try_end_6
.catchall {:try_start_1 .. :try_end_6} :catchall_8
.line 540
monitor-exit p0
return-void
:catchall_8
move-exception v0
monitor-exit p0
throw v0
.end method
.method public declared-synchronized forEach(Lcom/google/firebase/crashlytics/internal/log/QueueFile$ElementReader;)V
.registers 6
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
monitor-enter p0
.line 438
:try_start_1
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->first:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget v0, v0, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->position:I
const/4 v1, 0x0
.line 439
:goto_6
iget v2, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->elementCount:I
if-ge v1, v2, :cond_27
.line 440
invoke-direct {p0, v0}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->readElement(I)Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
move-result-object v0
.line 441
new-instance v2, Lcom/google/firebase/crashlytics/internal/log/QueueFile$ElementInputStream;
const/4 v3, 0x0
invoke-direct {v2, p0, v0, v3}, Lcom/google/firebase/crashlytics/internal/log/QueueFile$ElementInputStream;-><init>(Lcom/google/firebase/crashlytics/internal/log/QueueFile;Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;Lcom/google/firebase/crashlytics/internal/log/QueueFile$1;)V
iget v3, v0, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->length:I
invoke-interface {p1, v2, v3}, Lcom/google/firebase/crashlytics/internal/log/QueueFile$ElementReader;->read(Ljava/io/InputStream;I)V
.line 442
iget v2, v0, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->position:I
add-int/lit8 v2, v2, 0x4
iget v0, v0, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->length:I
add-int/2addr v2, v0
invoke-direct {p0, v2}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->wrapPosition(I)I
move-result v0
:try_end_24
.catchall {:try_start_1 .. :try_end_24} :catchall_29
add-int/lit8 v1, v1, 0x1
goto :goto_6
.line 444
:cond_27
monitor-exit p0
return-void
:catchall_29
move-exception p1
monitor-exit p0
throw p1
.end method
.method public hasSpaceFor(II)Z
.registers 4
.line 547
invoke-virtual {p0}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->usedBytes()I
move-result v0
add-int/lit8 v0, v0, 0x4
add-int/2addr v0, p1
if-gt v0, p2, :cond_b
const/4 p1, 0x1
goto :goto_c
:cond_b
const/4 p1, 0x0
:goto_c
return p1
.end method
.method public declared-synchronized isEmpty()Z
.registers 2
monitor-enter p0
.line 356
:try_start_1
iget v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->elementCount:I
:try_end_3
.catchall {:try_start_1 .. :try_end_3} :catchall_a
if-nez v0, :cond_7
const/4 v0, 0x1
goto :goto_8
:cond_7
const/4 v0, 0x0
:goto_8
monitor-exit p0
return v0
:catchall_a
move-exception v0
monitor-exit p0
throw v0
.end method
.method public declared-synchronized peek(Lcom/google/firebase/crashlytics/internal/log/QueueFile$ElementReader;)V
.registers 5
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
monitor-enter p0
.line 428
:try_start_1
iget v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->elementCount:I
if-lez v0, :cond_14
.line 429
new-instance v0, Lcom/google/firebase/crashlytics/internal/log/QueueFile$ElementInputStream;
iget-object v1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->first:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
const/4 v2, 0x0
invoke-direct {v0, p0, v1, v2}, Lcom/google/firebase/crashlytics/internal/log/QueueFile$ElementInputStream;-><init>(Lcom/google/firebase/crashlytics/internal/log/QueueFile;Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;Lcom/google/firebase/crashlytics/internal/log/QueueFile$1;)V
iget-object v1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->first:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget v1, v1, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->length:I
invoke-interface {p1, v0, v1}, Lcom/google/firebase/crashlytics/internal/log/QueueFile$ElementReader;->read(Ljava/io/InputStream;I)V
:try_end_14
.catchall {:try_start_1 .. :try_end_14} :catchall_16
.line 431
:cond_14
monitor-exit p0
return-void
:catchall_16
move-exception p1
monitor-exit p0
throw p1
.end method
.method public declared-synchronized peek()[B
.registers 5
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
monitor-enter p0
.line 417
:try_start_1
invoke-virtual {p0}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->isEmpty()Z
move-result v0
:try_end_5
.catchall {:try_start_1 .. :try_end_5} :catchall_1c
if-eqz v0, :cond_a
const/4 v0, 0x0
.line 418
monitor-exit p0
return-object v0
.line 420
:cond_a
:try_start_a
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->first:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget v0, v0, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->length:I
.line 421
new-array v1, v0, [B
.line 422
iget-object v2, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->first:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget v2, v2, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->position:I
add-int/lit8 v2, v2, 0x4
const/4 v3, 0x0
invoke-direct {p0, v2, v1, v3, v0}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->ringRead(I[BII)V
:try_end_1a
.catchall {:try_start_a .. :try_end_1a} :catchall_1c
.line 423
monitor-exit p0
return-object v1
:catchall_1c
move-exception v0
monitor-exit p0
throw v0
.end method
.method public declared-synchronized remove()V
.registers 7
.annotation system Ldalvik/annotation/Throws;
value = {
Ljava/io/IOException;
}
.end annotation
monitor-enter p0
.line 511
:try_start_1
invoke-virtual {p0}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->isEmpty()Z
move-result v0
if-nez v0, :cond_45
.line 514
iget v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->elementCount:I
const/4 v1, 0x1
if-ne v0, v1, :cond_10
.line 515
invoke-virtual {p0}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->clear()V
goto :goto_43
.line 518
:cond_10
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->first:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget v0, v0, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->position:I
const/4 v2, 0x4
add-int/2addr v0, v2
iget-object v3, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->first:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget v3, v3, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->length:I
add-int/2addr v0, v3
invoke-direct {p0, v0}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->wrapPosition(I)I
move-result v0
.line 519
iget-object v3, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->buffer:[B
const/4 v4, 0x0
invoke-direct {p0, v0, v3, v4, v2}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->ringRead(I[BII)V
.line 520
iget-object v2, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->buffer:[B
invoke-static {v2, v4}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->readInt([BI)I
move-result v2
.line 521
iget v3, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->fileLength:I
iget v4, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->elementCount:I
sub-int/2addr v4, v1
iget-object v5, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->last:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget v5, v5, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->position:I
invoke-direct {p0, v3, v4, v0, v5}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->writeHeader(IIII)V
.line 522
iget v3, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->elementCount:I
sub-int/2addr v3, v1
iput v3, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->elementCount:I
.line 523
new-instance v1, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
invoke-direct {v1, v0, v2}, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;-><init>(II)V
iput-object v1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->first:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
:try_end_43
.catchall {:try_start_1 .. :try_end_43} :catchall_4b
.line 525
:goto_43
monitor-exit p0
return-void
.line 512
:cond_45
:try_start_45
new-instance v0, Ljava/util/NoSuchElementException;
invoke-direct {v0}, Ljava/util/NoSuchElementException;-><init>()V
throw v0
:try_end_4b
.catchall {:try_start_45 .. :try_end_4b} :catchall_4b
:catchall_4b
move-exception v0
monitor-exit p0
throw v0
.end method
.method public declared-synchronized size()I
.registers 2
monitor-enter p0
.line 502
:try_start_1
iget v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->elementCount:I
:try_end_3
.catchall {:try_start_1 .. :try_end_3} :catchall_5
monitor-exit p0
return v0
:catchall_5
move-exception v0
monitor-exit p0
throw v0
.end method
.method public toString()Ljava/lang/String;
.registers 6
.line 552
new-instance v0, Ljava/lang/StringBuilder;
invoke-direct {v0}, Ljava/lang/StringBuilder;-><init>()V
.line 553
invoke-virtual {p0}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v1
invoke-virtual {v1}, Ljava/lang/Class;->getSimpleName()Ljava/lang/String;
move-result-object v1
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
const/16 v1, 0x5b
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(C)Ljava/lang/StringBuilder;
const-string v1, "fileLength="
.line 554
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->fileLength:I
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v1, ", size="
.line 555
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget v1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->elementCount:I
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(I)Ljava/lang/StringBuilder;
const-string v1, ", first="
.line 556
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->first:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
const-string v1, ", last="
.line 557
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
iget-object v1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->last:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/Object;)Ljava/lang/StringBuilder;
const-string v1, ", element lengths=["
.line 558
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 560
:try_start_42
new-instance v1, Lcom/google/firebase/crashlytics/internal/log/QueueFile$1;
invoke-direct {v1, p0, v0}, Lcom/google/firebase/crashlytics/internal/log/QueueFile$1;-><init>(Lcom/google/firebase/crashlytics/internal/log/QueueFile;Ljava/lang/StringBuilder;)V
invoke-virtual {p0, v1}, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->forEach(Lcom/google/firebase/crashlytics/internal/log/QueueFile$ElementReader;)V
:try_end_4a
.catch Ljava/io/IOException; {:try_start_42 .. :try_end_4a} :catch_4b
goto :goto_55
:catch_4b
move-exception v1
.line 575
sget-object v2, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->LOGGER:Ljava/util/logging/Logger;
sget-object v3, Ljava/util/logging/Level;->WARNING:Ljava/util/logging/Level;
const-string v4, "read error"
invoke-virtual {v2, v3, v4, v1}, Ljava/util/logging/Logger;->log(Ljava/util/logging/Level;Ljava/lang/String;Ljava/lang/Throwable;)V
:goto_55
const-string v1, "]]"
.line 577
invoke-virtual {v0, v1}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
.line 578
invoke-virtual {v0}, Ljava/lang/StringBuilder;->toString()Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public usedBytes()I
.registers 4
.line 329
iget v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->elementCount:I
const/16 v1, 0x10
if-nez v0, :cond_7
return v1
.line 333
:cond_7
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->last:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget v0, v0, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->position:I
iget-object v2, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->first:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget v2, v2, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->position:I
if-lt v0, v2, :cond_23
.line 335
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->last:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget v0, v0, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->position:I
iget-object v2, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->first:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget v2, v2, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->position:I
sub-int/2addr v0, v2
add-int/lit8 v0, v0, 0x4
iget-object v2, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->last:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget v2, v2, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->length:I
add-int/2addr v0, v2
add-int/2addr v0, v1
return v0
.line 341
:cond_23
iget-object v0, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->last:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget v0, v0, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->position:I
add-int/lit8 v0, v0, 0x4
iget-object v1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->last:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget v1, v1, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->length:I
add-int/2addr v0, v1
iget v1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->fileLength:I
add-int/2addr v0, v1
iget-object v1, p0, Lcom/google/firebase/crashlytics/internal/log/QueueFile;->first:Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;
iget v1, v1, Lcom/google/firebase/crashlytics/internal/log/QueueFile$Element;->position:I
sub-int/2addr v0, v1
return v0
.end method