RopeByteString$Balancer.smali
.class Lcom/google/protobuf/RopeByteString$Balancer;
.super Ljava/lang/Object;
.source "RopeByteString.java"
# annotations
.annotation system Ldalvik/annotation/EnclosingClass;
value = Lcom/google/protobuf/RopeByteString;
.end annotation
.annotation system Ldalvik/annotation/InnerClass;
accessFlags = 0xa
name = "Balancer"
.end annotation
# instance fields
.field private final prefixesStack:Ljava/util/Stack;
.annotation system Ldalvik/annotation/Signature;
value = {
"Ljava/util/Stack",
"<",
"Lcom/google/protobuf/ByteString;",
">;"
}
.end annotation
.end field
# direct methods
.method private constructor <init>()V
.registers 2
.prologue
.line 565
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
.line 569
new-instance v0, Ljava/util/Stack;
invoke-direct {v0}, Ljava/util/Stack;-><init>()V
iput-object v0, p0, Lcom/google/protobuf/RopeByteString$Balancer;->prefixesStack:Ljava/util/Stack;
return-void
.end method
.method synthetic constructor <init>(Lcom/google/protobuf/RopeByteString$1;)V
.registers 2
.prologue
.line 565
invoke-direct {p0}, Lcom/google/protobuf/RopeByteString$Balancer;-><init>()V
return-void
.end method
.method static synthetic access$100(Lcom/google/protobuf/RopeByteString$Balancer;Lcom/google/protobuf/ByteString;Lcom/google/protobuf/ByteString;)Lcom/google/protobuf/ByteString;
.registers 4
.prologue
.line 565
invoke-direct {p0, p1, p2}, Lcom/google/protobuf/RopeByteString$Balancer;->balance(Lcom/google/protobuf/ByteString;Lcom/google/protobuf/ByteString;)Lcom/google/protobuf/ByteString;
move-result-object v0
return-object v0
.end method
.method private balance(Lcom/google/protobuf/ByteString;Lcom/google/protobuf/ByteString;)Lcom/google/protobuf/ByteString;
.registers 7
.prologue
.line 572
invoke-direct {p0, p1}, Lcom/google/protobuf/RopeByteString$Balancer;->doBalance(Lcom/google/protobuf/ByteString;)V
.line 573
invoke-direct {p0, p2}, Lcom/google/protobuf/RopeByteString$Balancer;->doBalance(Lcom/google/protobuf/ByteString;)V
.line 576
iget-object v0, p0, Lcom/google/protobuf/RopeByteString$Balancer;->prefixesStack:Ljava/util/Stack;
invoke-virtual {v0}, Ljava/util/Stack;->pop()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/google/protobuf/ByteString;
move-object v1, v0
.line 577
:goto_f
iget-object v0, p0, Lcom/google/protobuf/RopeByteString$Balancer;->prefixesStack:Ljava/util/Stack;
invoke-virtual {v0}, Ljava/util/Stack;->isEmpty()Z
move-result v0
if-nez v0, :cond_27
.line 578
iget-object v0, p0, Lcom/google/protobuf/RopeByteString$Balancer;->prefixesStack:Ljava/util/Stack;
invoke-virtual {v0}, Ljava/util/Stack;->pop()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/google/protobuf/ByteString;
.line 579
new-instance v2, Lcom/google/protobuf/RopeByteString;
const/4 v3, 0x0
invoke-direct {v2, v0, v1, v3}, Lcom/google/protobuf/RopeByteString;-><init>(Lcom/google/protobuf/ByteString;Lcom/google/protobuf/ByteString;Lcom/google/protobuf/RopeByteString$1;)V
move-object v1, v2
.line 580
goto :goto_f
.line 583
:cond_27
return-object v1
.end method
.method private doBalance(Lcom/google/protobuf/ByteString;)V
.registers 5
.prologue
.line 591
invoke-virtual {p1}, Lcom/google/protobuf/ByteString;->isBalanced()Z
move-result v0
if-eqz v0, :cond_a
.line 592
invoke-direct {p0, p1}, Lcom/google/protobuf/RopeByteString$Balancer;->insert(Lcom/google/protobuf/ByteString;)V
.line 602
:goto_9
return-void
.line 593
:cond_a
instance-of v0, p1, Lcom/google/protobuf/RopeByteString;
if-eqz v0, :cond_1f
.line 594
check-cast p1, Lcom/google/protobuf/RopeByteString;
.line 595
# getter for: Lcom/google/protobuf/RopeByteString;->left:Lcom/google/protobuf/ByteString;
invoke-static {p1}, Lcom/google/protobuf/RopeByteString;->access$400(Lcom/google/protobuf/RopeByteString;)Lcom/google/protobuf/ByteString;
move-result-object v0
invoke-direct {p0, v0}, Lcom/google/protobuf/RopeByteString$Balancer;->doBalance(Lcom/google/protobuf/ByteString;)V
.line 596
# getter for: Lcom/google/protobuf/RopeByteString;->right:Lcom/google/protobuf/ByteString;
invoke-static {p1}, Lcom/google/protobuf/RopeByteString;->access$500(Lcom/google/protobuf/RopeByteString;)Lcom/google/protobuf/ByteString;
move-result-object v0
invoke-direct {p0, v0}, Lcom/google/protobuf/RopeByteString$Balancer;->doBalance(Lcom/google/protobuf/ByteString;)V
goto :goto_9
.line 598
:cond_1f
new-instance v0, Ljava/lang/IllegalArgumentException;
new-instance v1, Ljava/lang/StringBuilder;
invoke-direct {v1}, Ljava/lang/StringBuilder;-><init>()V
const-string v2, "Has a new type of ByteString been created? Found "
invoke-virtual {v1, v2}, Ljava/lang/StringBuilder;->append(Ljava/lang/String;)Ljava/lang/StringBuilder;
move-result-object v1
.line 600
invoke-virtual {p1}, Ljava/lang/Object;->getClass()Ljava/lang/Class;
move-result-object v2
invoke-virtual {v1, v2}, 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-direct {v0, v1}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
throw v0
.end method
.method private getDepthBinForLength(I)I
.registers 3
.prologue
.line 658
# getter for: Lcom/google/protobuf/RopeByteString;->minLengthByDepth:[I
invoke-static {}, Lcom/google/protobuf/RopeByteString;->access$600()[I
move-result-object v0
invoke-static {v0, p1}, Ljava/util/Arrays;->binarySearch([II)I
move-result v0
.line 659
if-gez v0, :cond_f
.line 662
add-int/lit8 v0, v0, 0x1
neg-int v0, v0
.line 663
add-int/lit8 v0, v0, -0x1
.line 666
:cond_f
return v0
.end method
.method private insert(Lcom/google/protobuf/ByteString;)V
.registers 7
.prologue
const/4 v4, 0x0
.line 619
invoke-virtual {p1}, Lcom/google/protobuf/ByteString;->size()I
move-result v0
invoke-direct {p0, v0}, Lcom/google/protobuf/RopeByteString$Balancer;->getDepthBinForLength(I)I
move-result v1
.line 620
# getter for: Lcom/google/protobuf/RopeByteString;->minLengthByDepth:[I
invoke-static {}, Lcom/google/protobuf/RopeByteString;->access$600()[I
move-result-object v0
add-int/lit8 v2, v1, 0x1
aget v2, v0, v2
.line 626
iget-object v0, p0, Lcom/google/protobuf/RopeByteString$Balancer;->prefixesStack:Ljava/util/Stack;
invoke-virtual {v0}, Ljava/util/Stack;->isEmpty()Z
move-result v0
if-nez v0, :cond_27
iget-object v0, p0, Lcom/google/protobuf/RopeByteString$Balancer;->prefixesStack:Ljava/util/Stack;
invoke-virtual {v0}, Ljava/util/Stack;->peek()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/google/protobuf/ByteString;
invoke-virtual {v0}, Lcom/google/protobuf/ByteString;->size()I
move-result v0
if-lt v0, v2, :cond_2d
.line 627
:cond_27
iget-object v0, p0, Lcom/google/protobuf/RopeByteString$Balancer;->prefixesStack:Ljava/util/Stack;
invoke-virtual {v0, p1}, Ljava/util/Stack;->push(Ljava/lang/Object;)Ljava/lang/Object;
.line 655
:goto_2c
return-void
.line 629
:cond_2d
# getter for: Lcom/google/protobuf/RopeByteString;->minLengthByDepth:[I
invoke-static {}, Lcom/google/protobuf/RopeByteString;->access$600()[I
move-result-object v0
aget v3, v0, v1
.line 632
iget-object v0, p0, Lcom/google/protobuf/RopeByteString$Balancer;->prefixesStack:Ljava/util/Stack;
invoke-virtual {v0}, Ljava/util/Stack;->pop()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/google/protobuf/ByteString;
move-object v1, v0
.line 633
:goto_3c
iget-object v0, p0, Lcom/google/protobuf/RopeByteString$Balancer;->prefixesStack:Ljava/util/Stack;
invoke-virtual {v0}, Ljava/util/Stack;->isEmpty()Z
move-result v0
if-nez v0, :cond_61
iget-object v0, p0, Lcom/google/protobuf/RopeByteString$Balancer;->prefixesStack:Ljava/util/Stack;
.line 634
invoke-virtual {v0}, Ljava/util/Stack;->peek()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/google/protobuf/ByteString;
invoke-virtual {v0}, Lcom/google/protobuf/ByteString;->size()I
move-result v0
if-ge v0, v3, :cond_61
.line 635
iget-object v0, p0, Lcom/google/protobuf/RopeByteString$Balancer;->prefixesStack:Ljava/util/Stack;
invoke-virtual {v0}, Ljava/util/Stack;->pop()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/google/protobuf/ByteString;
.line 636
new-instance v2, Lcom/google/protobuf/RopeByteString;
invoke-direct {v2, v0, v1, v4}, Lcom/google/protobuf/RopeByteString;-><init>(Lcom/google/protobuf/ByteString;Lcom/google/protobuf/ByteString;Lcom/google/protobuf/RopeByteString$1;)V
move-object v1, v2
.line 637
goto :goto_3c
.line 640
:cond_61
new-instance v0, Lcom/google/protobuf/RopeByteString;
invoke-direct {v0, v1, p1, v4}, Lcom/google/protobuf/RopeByteString;-><init>(Lcom/google/protobuf/ByteString;Lcom/google/protobuf/ByteString;Lcom/google/protobuf/RopeByteString$1;)V
move-object v1, v0
.line 643
:goto_67
iget-object v0, p0, Lcom/google/protobuf/RopeByteString$Balancer;->prefixesStack:Ljava/util/Stack;
invoke-virtual {v0}, Ljava/util/Stack;->isEmpty()Z
move-result v0
if-nez v0, :cond_9c
.line 644
invoke-virtual {v1}, Lcom/google/protobuf/ByteString;->size()I
move-result v0
invoke-direct {p0, v0}, Lcom/google/protobuf/RopeByteString$Balancer;->getDepthBinForLength(I)I
move-result v0
.line 645
# getter for: Lcom/google/protobuf/RopeByteString;->minLengthByDepth:[I
invoke-static {}, Lcom/google/protobuf/RopeByteString;->access$600()[I
move-result-object v2
add-int/lit8 v0, v0, 0x1
aget v2, v2, v0
.line 646
iget-object v0, p0, Lcom/google/protobuf/RopeByteString$Balancer;->prefixesStack:Ljava/util/Stack;
invoke-virtual {v0}, Ljava/util/Stack;->peek()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/google/protobuf/ByteString;
invoke-virtual {v0}, Lcom/google/protobuf/ByteString;->size()I
move-result v0
if-ge v0, v2, :cond_9c
.line 647
iget-object v0, p0, Lcom/google/protobuf/RopeByteString$Balancer;->prefixesStack:Ljava/util/Stack;
invoke-virtual {v0}, Ljava/util/Stack;->pop()Ljava/lang/Object;
move-result-object v0
check-cast v0, Lcom/google/protobuf/ByteString;
.line 648
new-instance v2, Lcom/google/protobuf/RopeByteString;
invoke-direct {v2, v0, v1, v4}, Lcom/google/protobuf/RopeByteString;-><init>(Lcom/google/protobuf/ByteString;Lcom/google/protobuf/ByteString;Lcom/google/protobuf/RopeByteString$1;)V
move-object v1, v2
.line 649
goto :goto_67
.line 653
:cond_9c
iget-object v0, p0, Lcom/google/protobuf/RopeByteString$Balancer;->prefixesStack:Ljava/util/Stack;
invoke-virtual {v0, v1}, Ljava/util/Stack;->push(Ljava/lang/Object;)Ljava/lang/Object;
goto :goto_2c
.end method