ByteString$e.smali
.class public final Lcom/google/protobuf/ByteString$e;
.super Ljava/io/OutputStream;
.source "ByteString.java"
# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
value = Lcom/google/protobuf/ByteString;
.end annotation
.annotation system Ldalvik/annotation/InnerClass;
accessFlags = 0x19
name = "e"
.end annotation
# static fields
.field private static final a:[B
# instance fields
.field private final b:I
.field private final c:Ljava/util/ArrayList;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/ArrayList<",
"Lcom/google/protobuf/ByteString;",
">;"
}
.end annotation
.end field
.field private d:I
.field private e:[B
.field private f:I
# direct methods
.method static constructor <clinit>()V
.registers 1
const/4 v0, 0x0
.line 1
new-array v0, v0, [B
sput-object v0, Lcom/google/protobuf/ByteString$e;->a:[B
return-void
.end method
.method constructor <init>(I)V
.registers 3
.line 1
invoke-direct {p0}, Ljava/io/OutputStream;-><init>()V
if-ltz p1, :cond_13
.line 2
iput p1, p0, Lcom/google/protobuf/ByteString$e;->b:I
.line 3
new-instance v0, Ljava/util/ArrayList;
invoke-direct {v0}, Ljava/util/ArrayList;-><init>()V
iput-object v0, p0, Lcom/google/protobuf/ByteString$e;->c:Ljava/util/ArrayList;
.line 4
new-array p1, p1, [B
iput-object p1, p0, Lcom/google/protobuf/ByteString$e;->e:[B
return-void
.line 5
:cond_13
new-instance p1, Ljava/lang/IllegalArgumentException;
const-string v0, "Buffer size < 0"
invoke-direct {p1, v0}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw p1
.end method
.method private a(I)V
.registers 5
.line 1
iget-object v0, p0, Lcom/google/protobuf/ByteString$e;->c:Ljava/util/ArrayList;
new-instance v1, Lcom/google/protobuf/ByteString$LiteralByteString;
iget-object v2, p0, Lcom/google/protobuf/ByteString$e;->e:[B
invoke-direct {v1, v2}, Lcom/google/protobuf/ByteString$LiteralByteString;-><init>([B)V
invoke-virtual {v0, v1}, Ljava/util/ArrayList;->add(Ljava/lang/Object;)Z
.line 2
iget v0, p0, Lcom/google/protobuf/ByteString$e;->d:I
iget-object v1, p0, Lcom/google/protobuf/ByteString$e;->e:[B
array-length v1, v1
add-int/2addr v0, v1
iput v0, p0, Lcom/google/protobuf/ByteString$e;->d:I
.line 3
iget v0, p0, Lcom/google/protobuf/ByteString$e;->b:I
iget v1, p0, Lcom/google/protobuf/ByteString$e;->d:I
ushr-int/lit8 v1, v1, 0x1
.line 4
invoke-static {p1, v1}, Ljava/lang/Math;->max(II)I
move-result p1
.line 5
invoke-static {v0, p1}, Ljava/lang/Math;->max(II)I
move-result p1
.line 6
new-array p1, p1, [B
iput-object p1, p0, Lcom/google/protobuf/ByteString$e;->e:[B
const/4 p1, 0x0
.line 7
iput p1, p0, Lcom/google/protobuf/ByteString$e;->f:I
return-void
.end method
# virtual methods
.method public declared-synchronized size()I
.registers 3
monitor-enter p0
.line 1
:try_start_1
iget v0, p0, Lcom/google/protobuf/ByteString$e;->d:I
iget v1, p0, Lcom/google/protobuf/ByteString$e;->f:I
:try_end_5
.catchall {:try_start_1 .. :try_end_5} :catchall_8
add-int/2addr v0, v1
monitor-exit p0
return v0
:catchall_8
move-exception v0
monitor-exit p0
throw v0
.end method
.method public toString()Ljava/lang/String;
.registers 4
const/4 v0, 0x2
.line 1
new-array v0, v0, [Ljava/lang/Object;
.line 2
invoke-static {p0}, Ljava/lang/System;->identityHashCode(Ljava/lang/Object;)I
move-result v1
invoke-static {v1}, Ljava/lang/Integer;->toHexString(I)Ljava/lang/String;
move-result-object v1
const/4 v2, 0x0
aput-object v1, v0, v2
invoke-virtual {p0}, Lcom/google/protobuf/ByteString$e;->size()I
move-result v1
invoke-static {v1}, Ljava/lang/Integer;->valueOf(I)Ljava/lang/Integer;
move-result-object v1
const/4 v2, 0x1
aput-object v1, v0, v2
const-string v1, "<ByteString.Output@%s size=%d>"
.line 3
invoke-static {v1, v0}, Ljava/lang/String;->format(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public declared-synchronized write(I)V
.registers 5
monitor-enter p0
.line 1
:try_start_1
iget v0, p0, Lcom/google/protobuf/ByteString$e;->f:I
iget-object v1, p0, Lcom/google/protobuf/ByteString$e;->e:[B
array-length v1, v1
if-ne v0, v1, :cond_c
const/4 v0, 0x1
.line 2
invoke-direct {p0, v0}, Lcom/google/protobuf/ByteString$e;->a(I)V
.line 3
:cond_c
iget-object v0, p0, Lcom/google/protobuf/ByteString$e;->e:[B
iget v1, p0, Lcom/google/protobuf/ByteString$e;->f:I
add-int/lit8 v2, v1, 0x1
iput v2, p0, Lcom/google/protobuf/ByteString$e;->f:I
int-to-byte p1, p1
aput-byte p1, v0, v1
:try_end_17
.catchall {:try_start_1 .. :try_end_17} :catchall_19
.line 4
monitor-exit p0
return-void
:catchall_19
move-exception p1
monitor-exit p0
throw p1
.end method
.method public declared-synchronized write([BII)V
.registers 7
monitor-enter p0
.line 5
:try_start_1
iget-object v0, p0, Lcom/google/protobuf/ByteString$e;->e:[B
array-length v0, v0
iget v1, p0, Lcom/google/protobuf/ByteString$e;->f:I
sub-int/2addr v0, v1
if-gt p3, v0, :cond_16
.line 6
iget-object v0, p0, Lcom/google/protobuf/ByteString$e;->e:[B
iget v1, p0, Lcom/google/protobuf/ByteString$e;->f:I
invoke-static {p1, p2, v0, v1, p3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 7
iget p1, p0, Lcom/google/protobuf/ByteString$e;->f:I
add-int/2addr p1, p3
iput p1, p0, Lcom/google/protobuf/ByteString$e;->f:I
goto :goto_30
.line 8
:cond_16
iget-object v0, p0, Lcom/google/protobuf/ByteString$e;->e:[B
array-length v0, v0
iget v1, p0, Lcom/google/protobuf/ByteString$e;->f:I
sub-int/2addr v0, v1
.line 9
iget-object v1, p0, Lcom/google/protobuf/ByteString$e;->e:[B
iget v2, p0, Lcom/google/protobuf/ByteString$e;->f:I
invoke-static {p1, p2, v1, v2, v0}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
add-int/2addr p2, v0
sub-int/2addr p3, v0
.line 10
invoke-direct {p0, p3}, Lcom/google/protobuf/ByteString$e;->a(I)V
.line 11
iget-object v0, p0, Lcom/google/protobuf/ByteString$e;->e:[B
const/4 v1, 0x0
invoke-static {p1, p2, v0, v1, p3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
.line 12
iput p3, p0, Lcom/google/protobuf/ByteString$e;->f:I
:try_end_30
.catchall {:try_start_1 .. :try_end_30} :catchall_32
.line 13
:goto_30
monitor-exit p0
return-void
:catchall_32
move-exception p1
monitor-exit p0
throw p1
.end method