.class public final Landroidx/collection/CircularArray; .super Ljava/lang/Object; .source "CircularArray.java" # annotations .annotation system Ldalvik/annotation/Signature; value = { "", "Ljava/lang/Object;" } .end annotation # instance fields .field private mCapacityBitmask:I .field private mElements:[Ljava/lang/Object; .annotation system Ldalvik/annotation/Signature; value = { "[TE;" } .end annotation .end field .field private mHead:I .field private mTail:I # direct methods .method public constructor ()V .registers 2 const/16 v0, 0x8 .line 49 invoke-direct {p0, v0}, Landroidx/collection/CircularArray;->(I)V return-void .end method .method public constructor (I)V .registers 4 .line 58 invoke-direct {p0}, Ljava/lang/Object;->()V const/4 v0, 0x1 if-lt p1, v0, :cond_2a const/high16 v1, 0x40000000 # 2.0f if-gt p1, v1, :cond_22 .line 69 invoke-static {p1}, Ljava/lang/Integer;->bitCount(I)I move-result v1 if-eq v1, v0, :cond_17 add-int/lit8 p1, p1, -0x1 .line 70 invoke-static {p1}, Ljava/lang/Integer;->highestOneBit(I)I move-result p1 shl-int/2addr p1, v0 :cond_17 add-int/lit8 v0, p1, -0x1 .line 75 iput v0, p0, Landroidx/collection/CircularArray;->mCapacityBitmask:I .line 76 new-array p1, p1, [Ljava/lang/Object; check-cast p1, [Ljava/lang/Object; iput-object p1, p0, Landroidx/collection/CircularArray;->mElements:[Ljava/lang/Object; return-void .line 63 :cond_22 new-instance p1, Ljava/lang/IllegalArgumentException; const-string v0, "capacity must be <= 2^30" invoke-direct {p1, v0}, Ljava/lang/IllegalArgumentException;->(Ljava/lang/String;)V throw p1 .line 60 :cond_2a new-instance p1, Ljava/lang/IllegalArgumentException; const-string v0, "capacity must be >= 1" invoke-direct {p1, v0}, Ljava/lang/IllegalArgumentException;->(Ljava/lang/String;)V throw p1 .end method .method private doubleCapacity()V .registers 8 .line 30 iget-object v0, p0, Landroidx/collection/CircularArray;->mElements:[Ljava/lang/Object; array-length v1, v0 .line 31 iget v2, p0, Landroidx/collection/CircularArray;->mHead:I sub-int v3, v1, v2 shl-int/lit8 v4, v1, 0x1 if-ltz v4, :cond_25 .line 36 new-array v5, v4, [Ljava/lang/Object; const/4 v6, 0x0 .line 37 invoke-static {v0, v2, v5, v6, v3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V .line 38 iget-object v0, p0, Landroidx/collection/CircularArray;->mElements:[Ljava/lang/Object; iget v2, p0, Landroidx/collection/CircularArray;->mHead:I invoke-static {v0, v6, v5, v3, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V .line 39 check-cast v5, [Ljava/lang/Object; iput-object v5, p0, Landroidx/collection/CircularArray;->mElements:[Ljava/lang/Object; .line 40 iput v6, p0, Landroidx/collection/CircularArray;->mHead:I .line 41 iput v1, p0, Landroidx/collection/CircularArray;->mTail:I add-int/lit8 v4, v4, -0x1 .line 42 iput v4, p0, Landroidx/collection/CircularArray;->mCapacityBitmask:I return-void .line 34 :cond_25 new-instance v0, Ljava/lang/RuntimeException; const-string v1, "Max array capacity exceeded" invoke-direct {v0, v1}, Ljava/lang/RuntimeException;->(Ljava/lang/String;)V throw v0 .end method # virtual methods .method public addFirst(Ljava/lang/Object;)V .registers 4 .annotation system Ldalvik/annotation/Signature; value = { "(TE;)V" } .end annotation .line 84 iget v0, p0, Landroidx/collection/CircularArray;->mHead:I add-int/lit8 v0, v0, -0x1 iget v1, p0, Landroidx/collection/CircularArray;->mCapacityBitmask:I and-int/2addr v0, v1 iput v0, p0, Landroidx/collection/CircularArray;->mHead:I .line 85 iget-object v1, p0, Landroidx/collection/CircularArray;->mElements:[Ljava/lang/Object; aput-object p1, v1, v0 .line 86 iget p1, p0, Landroidx/collection/CircularArray;->mTail:I if-ne v0, p1, :cond_14 .line 87 invoke-direct {p0}, Landroidx/collection/CircularArray;->doubleCapacity()V :cond_14 return-void .end method .method public addLast(Ljava/lang/Object;)V .registers 4 .annotation system Ldalvik/annotation/Signature; value = { "(TE;)V" } .end annotation .line 96 iget-object v0, p0, Landroidx/collection/CircularArray;->mElements:[Ljava/lang/Object; iget v1, p0, Landroidx/collection/CircularArray;->mTail:I aput-object p1, v0, v1 add-int/lit8 v1, v1, 0x1 .line 97 iget p1, p0, Landroidx/collection/CircularArray;->mCapacityBitmask:I and-int/2addr p1, v1 iput p1, p0, Landroidx/collection/CircularArray;->mTail:I .line 98 iget v0, p0, Landroidx/collection/CircularArray;->mHead:I if-ne p1, v0, :cond_14 .line 99 invoke-direct {p0}, Landroidx/collection/CircularArray;->doubleCapacity()V :cond_14 return-void .end method .method public clear()V .registers 2 .line 138 invoke-virtual {p0}, Landroidx/collection/CircularArray;->size()I move-result v0 invoke-virtual {p0, v0}, Landroidx/collection/CircularArray;->removeFromStart(I)V return-void .end method .method public get(I)Ljava/lang/Object; .registers 4 .annotation system Ldalvik/annotation/Signature; value = { "(I)TE;" } .end annotation if-ltz p1, :cond_13 .line 240 invoke-virtual {p0}, Landroidx/collection/CircularArray;->size()I move-result v0 if-ge p1, v0, :cond_13 .line 243 iget-object v0, p0, Landroidx/collection/CircularArray;->mElements:[Ljava/lang/Object; iget v1, p0, Landroidx/collection/CircularArray;->mHead:I add-int/2addr v1, p1 iget p1, p0, Landroidx/collection/CircularArray;->mCapacityBitmask:I and-int/2addr p1, v1 aget-object p1, v0, p1 return-object p1 .line 241 :cond_13 new-instance p1, Ljava/lang/ArrayIndexOutOfBoundsException; invoke-direct {p1}, Ljava/lang/ArrayIndexOutOfBoundsException;->()V throw p1 .end method .method public getFirst()Ljava/lang/Object; .registers 3 .annotation system Ldalvik/annotation/Signature; value = { "()TE;" } .end annotation .line 215 iget v0, p0, Landroidx/collection/CircularArray;->mHead:I iget v1, p0, Landroidx/collection/CircularArray;->mTail:I if-eq v0, v1, :cond_b .line 218 iget-object v1, p0, Landroidx/collection/CircularArray;->mElements:[Ljava/lang/Object; aget-object v0, v1, v0 return-object v0 .line 216 :cond_b new-instance v0, Ljava/lang/ArrayIndexOutOfBoundsException; invoke-direct {v0}, Ljava/lang/ArrayIndexOutOfBoundsException;->()V throw v0 .end method .method public getLast()Ljava/lang/Object; .registers 4 .annotation system Ldalvik/annotation/Signature; value = { "()TE;" } .end annotation .line 227 iget v0, p0, Landroidx/collection/CircularArray;->mHead:I iget v1, p0, Landroidx/collection/CircularArray;->mTail:I if-eq v0, v1, :cond_10 .line 230 iget-object v0, p0, Landroidx/collection/CircularArray;->mElements:[Ljava/lang/Object; add-int/lit8 v1, v1, -0x1 iget v2, p0, Landroidx/collection/CircularArray;->mCapacityBitmask:I and-int/2addr v1, v2 aget-object v0, v0, v1 return-object v0 .line 228 :cond_10 new-instance v0, Ljava/lang/ArrayIndexOutOfBoundsException; invoke-direct {v0}, Ljava/lang/ArrayIndexOutOfBoundsException;->()V throw v0 .end method .method public isEmpty()Z .registers 3 .line 259 iget v0, p0, Landroidx/collection/CircularArray;->mHead:I iget v1, p0, Landroidx/collection/CircularArray;->mTail:I if-ne v0, v1, :cond_8 const/4 v0, 0x1 goto :goto_9 :cond_8 const/4 v0, 0x0 :goto_9 return v0 .end method .method public popFirst()Ljava/lang/Object; .registers 5 .annotation system Ldalvik/annotation/Signature; value = { "()TE;" } .end annotation .line 109 iget v0, p0, Landroidx/collection/CircularArray;->mHead:I iget v1, p0, Landroidx/collection/CircularArray;->mTail:I if-eq v0, v1, :cond_15 .line 112 iget-object v1, p0, Landroidx/collection/CircularArray;->mElements:[Ljava/lang/Object; aget-object v2, v1, v0 const/4 v3, 0x0 .line 113 aput-object v3, v1, v0 add-int/lit8 v0, v0, 0x1 .line 114 iget v1, p0, Landroidx/collection/CircularArray;->mCapacityBitmask:I and-int/2addr v0, v1 iput v0, p0, Landroidx/collection/CircularArray;->mHead:I return-object v2 .line 110 :cond_15 new-instance v0, Ljava/lang/ArrayIndexOutOfBoundsException; invoke-direct {v0}, Ljava/lang/ArrayIndexOutOfBoundsException;->()V throw v0 .end method .method public popLast()Ljava/lang/Object; .registers 5 .annotation system Ldalvik/annotation/Signature; value = { "()TE;" } .end annotation .line 124 iget v0, p0, Landroidx/collection/CircularArray;->mHead:I iget v1, p0, Landroidx/collection/CircularArray;->mTail:I if-eq v0, v1, :cond_15 add-int/lit8 v1, v1, -0x1 .line 127 iget v0, p0, Landroidx/collection/CircularArray;->mCapacityBitmask:I and-int/2addr v0, v1 .line 128 iget-object v1, p0, Landroidx/collection/CircularArray;->mElements:[Ljava/lang/Object; aget-object v2, v1, v0 const/4 v3, 0x0 .line 129 aput-object v3, v1, v0 .line 130 iput v0, p0, Landroidx/collection/CircularArray;->mTail:I return-object v2 .line 125 :cond_15 new-instance v0, Ljava/lang/ArrayIndexOutOfBoundsException; invoke-direct {v0}, Ljava/lang/ArrayIndexOutOfBoundsException;->()V throw v0 .end method .method public removeFromEnd(I)V .registers 6 if-gtz p1, :cond_3 return-void .line 185 :cond_3 invoke-virtual {p0}, Landroidx/collection/CircularArray;->size()I move-result v0 if-gt p1, v0, :cond_3a .line 189 iget v0, p0, Landroidx/collection/CircularArray;->mTail:I if-ge p1, v0, :cond_f sub-int/2addr v0, p1 goto :goto_10 :cond_f const/4 v0, 0x0 :goto_10 move v1, v0 .line 192 :goto_11 iget v2, p0, Landroidx/collection/CircularArray;->mTail:I const/4 v3, 0x0 if-ge v1, v2, :cond_1d .line 193 iget-object v2, p0, Landroidx/collection/CircularArray;->mElements:[Ljava/lang/Object; aput-object v3, v2, v1 add-int/lit8 v1, v1, 0x1 goto :goto_11 :cond_1d sub-int v0, v2, v0 sub-int/2addr p1, v0 sub-int/2addr v2, v0 .line 197 iput v2, p0, Landroidx/collection/CircularArray;->mTail:I if-lez p1, :cond_39 .line 200 iget-object v0, p0, Landroidx/collection/CircularArray;->mElements:[Ljava/lang/Object; array-length v0, v0 iput v0, p0, Landroidx/collection/CircularArray;->mTail:I sub-int/2addr v0, p1 move p1, v0 .line 202 :goto_2c iget v1, p0, Landroidx/collection/CircularArray;->mTail:I if-ge p1, v1, :cond_37 .line 203 iget-object v1, p0, Landroidx/collection/CircularArray;->mElements:[Ljava/lang/Object; aput-object v3, v1, p1 add-int/lit8 p1, p1, 0x1 goto :goto_2c .line 205 :cond_37 iput v0, p0, Landroidx/collection/CircularArray;->mTail:I :cond_39 return-void .line 186 :cond_3a new-instance p1, Ljava/lang/ArrayIndexOutOfBoundsException; invoke-direct {p1}, Ljava/lang/ArrayIndexOutOfBoundsException;->()V throw p1 .end method .method public removeFromStart(I)V .registers 6 if-gtz p1, :cond_3 return-void .line 152 :cond_3 invoke-virtual {p0}, Landroidx/collection/CircularArray;->size()I move-result v0 if-gt p1, v0, :cond_37 .line 155 iget-object v0, p0, Landroidx/collection/CircularArray;->mElements:[Ljava/lang/Object; array-length v0, v0 .line 156 iget v1, p0, Landroidx/collection/CircularArray;->mHead:I sub-int v2, v0, v1 if-ge p1, v2, :cond_14 add-int v0, v1, p1 :cond_14 :goto_14 const/4 v2, 0x0 if-ge v1, v0, :cond_1e .line 160 iget-object v3, p0, Landroidx/collection/CircularArray;->mElements:[Ljava/lang/Object; aput-object v2, v3, v1 add-int/lit8 v1, v1, 0x1 goto :goto_14 .line 162 :cond_1e iget v1, p0, Landroidx/collection/CircularArray;->mHead:I sub-int/2addr v0, v1 sub-int/2addr p1, v0 add-int/2addr v1, v0 .line 164 iget v0, p0, Landroidx/collection/CircularArray;->mCapacityBitmask:I and-int/2addr v0, v1 iput v0, p0, Landroidx/collection/CircularArray;->mHead:I if-lez p1, :cond_36 const/4 v0, 0x0 :goto_2b if-ge v0, p1, :cond_34 .line 168 iget-object v1, p0, Landroidx/collection/CircularArray;->mElements:[Ljava/lang/Object; aput-object v2, v1, v0 add-int/lit8 v0, v0, 0x1 goto :goto_2b .line 170 :cond_34 iput p1, p0, Landroidx/collection/CircularArray;->mHead:I :cond_36 return-void .line 153 :cond_37 new-instance p1, Ljava/lang/ArrayIndexOutOfBoundsException; invoke-direct {p1}, Ljava/lang/ArrayIndexOutOfBoundsException;->()V throw p1 .end method .method public size()I .registers 3 .line 251 iget v0, p0, Landroidx/collection/CircularArray;->mTail:I iget v1, p0, Landroidx/collection/CircularArray;->mHead:I sub-int/2addr v0, v1 iget v1, p0, Landroidx/collection/CircularArray;->mCapacityBitmask:I and-int/2addr v0, v1 return v0 .end method