318 lines
		
	
	
		
			8.8 KiB
		
	
	
	
		
			Smali
		
	
	
	
	
	
			
		
		
	
	
			318 lines
		
	
	
		
			8.8 KiB
		
	
	
	
		
			Smali
		
	
	
	
	
	
| .class final Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;
 | |
| .super Ljava/lang/Object;
 | |
| .source "LinkedHashTreeMap.java"
 | |
| 
 | |
| 
 | |
| # annotations
 | |
| .annotation system Ldalvik/annotation/EnclosingClass;
 | |
|     value = Lcom/google/gson/internal/LinkedHashTreeMap;
 | |
| .end annotation
 | |
| 
 | |
| .annotation system Ldalvik/annotation/InnerClass;
 | |
|     accessFlags = 0x19
 | |
|     name = "AvlBuilder"
 | |
| .end annotation
 | |
| 
 | |
| .annotation system Ldalvik/annotation/Signature;
 | |
|     value = {
 | |
|         "<K:",
 | |
|         "Ljava/lang/Object;",
 | |
|         "V:",
 | |
|         "Ljava/lang/Object;",
 | |
|         ">",
 | |
|         "Ljava/lang/Object;"
 | |
|     }
 | |
| .end annotation
 | |
| 
 | |
| 
 | |
| # instance fields
 | |
| .field private leavesSkipped:I
 | |
| 
 | |
| .field private leavesToSkip:I
 | |
| 
 | |
| .field private size:I
 | |
| 
 | |
| .field private stack:Lcom/google/gson/internal/LinkedHashTreeMap$Node;
 | |
|     .annotation system Ldalvik/annotation/Signature;
 | |
|         value = {
 | |
|             "Lcom/google/gson/internal/LinkedHashTreeMap$Node<",
 | |
|             "TK;TV;>;"
 | |
|         }
 | |
|     .end annotation
 | |
| .end field
 | |
| 
 | |
| 
 | |
| # direct methods
 | |
| .method public constructor <init>()V
 | |
|     .locals 0
 | |
| 
 | |
|     .line 1
 | |
|     invoke-direct {p0}, Ljava/lang/Object;-><init>()V
 | |
| 
 | |
|     return-void
 | |
| .end method
 | |
| 
 | |
| 
 | |
| # virtual methods
 | |
| .method public add(Lcom/google/gson/internal/LinkedHashTreeMap$Node;)V
 | |
|     .locals 5
 | |
|     .annotation system Ldalvik/annotation/Signature;
 | |
|         value = {
 | |
|             "(",
 | |
|             "Lcom/google/gson/internal/LinkedHashTreeMap$Node<",
 | |
|             "TK;TV;>;)V"
 | |
|         }
 | |
|     .end annotation
 | |
| 
 | |
|     const/4 v0, 0x0
 | |
| 
 | |
|     .line 1
 | |
|     iput-object v0, p1, Lcom/google/gson/internal/LinkedHashTreeMap$Node;->right:Lcom/google/gson/internal/LinkedHashTreeMap$Node;
 | |
| 
 | |
|     iput-object v0, p1, Lcom/google/gson/internal/LinkedHashTreeMap$Node;->parent:Lcom/google/gson/internal/LinkedHashTreeMap$Node;
 | |
| 
 | |
|     iput-object v0, p1, Lcom/google/gson/internal/LinkedHashTreeMap$Node;->left:Lcom/google/gson/internal/LinkedHashTreeMap$Node;
 | |
| 
 | |
|     const/4 v0, 0x1
 | |
| 
 | |
|     .line 2
 | |
|     iput v0, p1, Lcom/google/gson/internal/LinkedHashTreeMap$Node;->height:I
 | |
| 
 | |
|     .line 3
 | |
|     iget v1, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->leavesToSkip:I
 | |
| 
 | |
|     if-lez v1, :cond_0
 | |
| 
 | |
|     iget v2, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->size:I
 | |
| 
 | |
|     and-int/lit8 v3, v2, 0x1
 | |
| 
 | |
|     if-nez v3, :cond_0
 | |
| 
 | |
|     add-int/2addr v2, v0
 | |
| 
 | |
|     .line 4
 | |
|     iput v2, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->size:I
 | |
| 
 | |
|     sub-int/2addr v1, v0
 | |
| 
 | |
|     .line 5
 | |
|     iput v1, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->leavesToSkip:I
 | |
| 
 | |
|     .line 6
 | |
|     iget v1, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->leavesSkipped:I
 | |
| 
 | |
|     add-int/2addr v1, v0
 | |
| 
 | |
|     iput v1, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->leavesSkipped:I
 | |
| 
 | |
|     .line 7
 | |
|     :cond_0
 | |
|     iget-object v1, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->stack:Lcom/google/gson/internal/LinkedHashTreeMap$Node;
 | |
| 
 | |
|     iput-object v1, p1, Lcom/google/gson/internal/LinkedHashTreeMap$Node;->parent:Lcom/google/gson/internal/LinkedHashTreeMap$Node;
 | |
| 
 | |
|     .line 8
 | |
|     iput-object p1, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->stack:Lcom/google/gson/internal/LinkedHashTreeMap$Node;
 | |
| 
 | |
|     .line 9
 | |
|     iget p1, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->size:I
 | |
| 
 | |
|     add-int/2addr p1, v0
 | |
| 
 | |
|     iput p1, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->size:I
 | |
| 
 | |
|     .line 10
 | |
|     iget v1, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->leavesToSkip:I
 | |
| 
 | |
|     if-lez v1, :cond_1
 | |
| 
 | |
|     and-int/lit8 v2, p1, 0x1
 | |
| 
 | |
|     if-nez v2, :cond_1
 | |
| 
 | |
|     add-int/2addr p1, v0
 | |
| 
 | |
|     .line 11
 | |
|     iput p1, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->size:I
 | |
| 
 | |
|     sub-int/2addr v1, v0
 | |
| 
 | |
|     .line 12
 | |
|     iput v1, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->leavesToSkip:I
 | |
| 
 | |
|     .line 13
 | |
|     iget p1, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->leavesSkipped:I
 | |
| 
 | |
|     add-int/2addr p1, v0
 | |
| 
 | |
|     iput p1, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->leavesSkipped:I
 | |
| 
 | |
|     :cond_1
 | |
|     const/4 p1, 0x4
 | |
| 
 | |
|     .line 14
 | |
|     :goto_0
 | |
|     iget v1, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->size:I
 | |
| 
 | |
|     add-int/lit8 v2, p1, -0x1
 | |
| 
 | |
|     and-int/2addr v1, v2
 | |
| 
 | |
|     if-ne v1, v2, :cond_5
 | |
| 
 | |
|     .line 15
 | |
|     iget v1, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->leavesSkipped:I
 | |
| 
 | |
|     if-nez v1, :cond_2
 | |
| 
 | |
|     .line 16
 | |
|     iget-object v1, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->stack:Lcom/google/gson/internal/LinkedHashTreeMap$Node;
 | |
| 
 | |
|     .line 17
 | |
|     iget-object v2, v1, Lcom/google/gson/internal/LinkedHashTreeMap$Node;->parent:Lcom/google/gson/internal/LinkedHashTreeMap$Node;
 | |
| 
 | |
|     .line 18
 | |
|     iget-object v3, v2, Lcom/google/gson/internal/LinkedHashTreeMap$Node;->parent:Lcom/google/gson/internal/LinkedHashTreeMap$Node;
 | |
| 
 | |
|     .line 19
 | |
|     iget-object v4, v3, Lcom/google/gson/internal/LinkedHashTreeMap$Node;->parent:Lcom/google/gson/internal/LinkedHashTreeMap$Node;
 | |
| 
 | |
|     iput-object v4, v2, Lcom/google/gson/internal/LinkedHashTreeMap$Node;->parent:Lcom/google/gson/internal/LinkedHashTreeMap$Node;
 | |
| 
 | |
|     .line 20
 | |
|     iput-object v2, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->stack:Lcom/google/gson/internal/LinkedHashTreeMap$Node;
 | |
| 
 | |
|     .line 21
 | |
|     iput-object v3, v2, Lcom/google/gson/internal/LinkedHashTreeMap$Node;->left:Lcom/google/gson/internal/LinkedHashTreeMap$Node;
 | |
| 
 | |
|     .line 22
 | |
|     iput-object v1, v2, Lcom/google/gson/internal/LinkedHashTreeMap$Node;->right:Lcom/google/gson/internal/LinkedHashTreeMap$Node;
 | |
| 
 | |
|     .line 23
 | |
|     iget v4, v1, Lcom/google/gson/internal/LinkedHashTreeMap$Node;->height:I
 | |
| 
 | |
|     add-int/2addr v4, v0
 | |
| 
 | |
|     iput v4, v2, Lcom/google/gson/internal/LinkedHashTreeMap$Node;->height:I
 | |
| 
 | |
|     .line 24
 | |
|     iput-object v2, v3, Lcom/google/gson/internal/LinkedHashTreeMap$Node;->parent:Lcom/google/gson/internal/LinkedHashTreeMap$Node;
 | |
| 
 | |
|     .line 25
 | |
|     iput-object v2, v1, Lcom/google/gson/internal/LinkedHashTreeMap$Node;->parent:Lcom/google/gson/internal/LinkedHashTreeMap$Node;
 | |
| 
 | |
|     goto :goto_1
 | |
| 
 | |
|     :cond_2
 | |
|     const/4 v2, 0x0
 | |
| 
 | |
|     if-ne v1, v0, :cond_3
 | |
| 
 | |
|     .line 26
 | |
|     iget-object v1, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->stack:Lcom/google/gson/internal/LinkedHashTreeMap$Node;
 | |
| 
 | |
|     .line 27
 | |
|     iget-object v3, v1, Lcom/google/gson/internal/LinkedHashTreeMap$Node;->parent:Lcom/google/gson/internal/LinkedHashTreeMap$Node;
 | |
| 
 | |
|     .line 28
 | |
|     iput-object v3, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->stack:Lcom/google/gson/internal/LinkedHashTreeMap$Node;
 | |
| 
 | |
|     .line 29
 | |
|     iput-object v1, v3, Lcom/google/gson/internal/LinkedHashTreeMap$Node;->right:Lcom/google/gson/internal/LinkedHashTreeMap$Node;
 | |
| 
 | |
|     .line 30
 | |
|     iget v4, v1, Lcom/google/gson/internal/LinkedHashTreeMap$Node;->height:I
 | |
| 
 | |
|     add-int/2addr v4, v0
 | |
| 
 | |
|     iput v4, v3, Lcom/google/gson/internal/LinkedHashTreeMap$Node;->height:I
 | |
| 
 | |
|     .line 31
 | |
|     iput-object v3, v1, Lcom/google/gson/internal/LinkedHashTreeMap$Node;->parent:Lcom/google/gson/internal/LinkedHashTreeMap$Node;
 | |
| 
 | |
|     .line 32
 | |
|     iput v2, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->leavesSkipped:I
 | |
| 
 | |
|     goto :goto_1
 | |
| 
 | |
|     :cond_3
 | |
|     const/4 v3, 0x2
 | |
| 
 | |
|     if-ne v1, v3, :cond_4
 | |
| 
 | |
|     .line 33
 | |
|     iput v2, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->leavesSkipped:I
 | |
| 
 | |
|     :cond_4
 | |
|     :goto_1
 | |
|     mul-int/lit8 p1, p1, 0x2
 | |
| 
 | |
|     goto :goto_0
 | |
| 
 | |
|     :cond_5
 | |
|     return-void
 | |
| .end method
 | |
| 
 | |
| .method public reset(I)V
 | |
|     .locals 1
 | |
| 
 | |
|     .line 1
 | |
|     invoke-static {p1}, Ljava/lang/Integer;->highestOneBit(I)I
 | |
| 
 | |
|     move-result v0
 | |
| 
 | |
|     mul-int/lit8 v0, v0, 0x2
 | |
| 
 | |
|     add-int/lit8 v0, v0, -0x1
 | |
| 
 | |
|     sub-int/2addr v0, p1
 | |
| 
 | |
|     .line 2
 | |
|     iput v0, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->leavesToSkip:I
 | |
| 
 | |
|     const/4 p1, 0x0
 | |
| 
 | |
|     .line 3
 | |
|     iput p1, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->size:I
 | |
| 
 | |
|     .line 4
 | |
|     iput p1, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->leavesSkipped:I
 | |
| 
 | |
|     const/4 p1, 0x0
 | |
| 
 | |
|     .line 5
 | |
|     iput-object p1, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->stack:Lcom/google/gson/internal/LinkedHashTreeMap$Node;
 | |
| 
 | |
|     return-void
 | |
| .end method
 | |
| 
 | |
| .method public root()Lcom/google/gson/internal/LinkedHashTreeMap$Node;
 | |
|     .locals 2
 | |
|     .annotation system Ldalvik/annotation/Signature;
 | |
|         value = {
 | |
|             "()",
 | |
|             "Lcom/google/gson/internal/LinkedHashTreeMap$Node<",
 | |
|             "TK;TV;>;"
 | |
|         }
 | |
|     .end annotation
 | |
| 
 | |
|     .line 1
 | |
|     iget-object v0, p0, Lcom/google/gson/internal/LinkedHashTreeMap$AvlBuilder;->stack:Lcom/google/gson/internal/LinkedHashTreeMap$Node;
 | |
| 
 | |
|     .line 2
 | |
|     iget-object v1, v0, Lcom/google/gson/internal/LinkedHashTreeMap$Node;->parent:Lcom/google/gson/internal/LinkedHashTreeMap$Node;
 | |
| 
 | |
|     if-nez v1, :cond_0
 | |
| 
 | |
|     return-object v0
 | |
| 
 | |
|     .line 3
 | |
|     :cond_0
 | |
|     new-instance v0, Ljava/lang/IllegalStateException;
 | |
| 
 | |
|     invoke-direct {v0}, Ljava/lang/IllegalStateException;-><init>()V
 | |
| 
 | |
|     throw v0
 | |
| .end method
 |