123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822 |
- .class public final Landroid/support/v4/util/CircularArray;
- .super Ljava/lang/Object;
- .source "CircularArray.java"
- # annotations
- .annotation system Ldalvik/annotation/Signature;
- value = {
- "<E:",
- "Ljava/lang/Object;",
- ">",
- "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 <init>()V
- .locals 1
- .prologue
- .line 47
- .local p0, "this":Landroid/support/v4/util/CircularArray;, "Landroid/support/v4/util/CircularArray<TE;>;"
- const/16 v0, 0x8
- invoke-direct {p0, v0}, Landroid/support/v4/util/CircularArray;-><init>(I)V
- .line 48
- return-void
- .end method
- .method public constructor <init>(I)V
- .locals 3
- .param p1, "minCapacity" # I
- .prologue
- .local p0, "this":Landroid/support/v4/util/CircularArray;, "Landroid/support/v4/util/CircularArray<TE;>;"
- const/4 v2, 0x1
- .line 56
- invoke-direct {p0}, Ljava/lang/Object;-><init>()V
- .line 57
- if-ge p1, v2, :cond_0
- .line 58
- new-instance v1, Ljava/lang/IllegalArgumentException;
- const-string v2, "capacity must be >= 1"
- invoke-direct {v1, v2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
- throw v1
- .line 60
- :cond_0
- const/high16 v1, 0x40000000 # 2.0f
- if-le p1, v1, :cond_1
- .line 61
- new-instance v1, Ljava/lang/IllegalArgumentException;
- const-string v2, "capacity must be <= 2^30"
- invoke-direct {v1, v2}, Ljava/lang/IllegalArgumentException;-><init>(Ljava/lang/String;)V
- throw v1
- .line 67
- :cond_1
- invoke-static {p1}, Ljava/lang/Integer;->bitCount(I)I
- move-result v1
- if-eq v1, v2, :cond_2
- .line 68
- add-int/lit8 v1, p1, -0x1
- invoke-static {v1}, Ljava/lang/Integer;->highestOneBit(I)I
- move-result v1
- shl-int/lit8 v0, v1, 0x1
- .line 73
- .local v0, "arrayCapacity":I
- :goto_0
- add-int/lit8 v1, v0, -0x1
- iput v1, p0, Landroid/support/v4/util/CircularArray;->mCapacityBitmask:I
- .line 74
- new-array v1, v0, [Ljava/lang/Object;
- check-cast v1, [Ljava/lang/Object;
- iput-object v1, p0, Landroid/support/v4/util/CircularArray;->mElements:[Ljava/lang/Object;
- .line 75
- return-void
- .line 70
- .end local v0 # "arrayCapacity":I
- :cond_2
- move v0, p1
- .restart local v0 # "arrayCapacity":I
- goto :goto_0
- .end method
- .method private doubleCapacity()V
- .locals 7
- .prologue
- .local p0, "this":Landroid/support/v4/util/CircularArray;, "Landroid/support/v4/util/CircularArray<TE;>;"
- const/4 v6, 0x0
- .line 28
- iget-object v4, p0, Landroid/support/v4/util/CircularArray;->mElements:[Ljava/lang/Object;
- array-length v1, v4
- .line 29
- .local v1, "n":I
- iget v4, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- sub-int v3, v1, v4
- .line 30
- .local v3, "r":I
- shl-int/lit8 v2, v1, 0x1
- .line 31
- .local v2, "newCapacity":I
- if-gez v2, :cond_0
- .line 32
- new-instance v4, Ljava/lang/RuntimeException;
- const-string v5, "Max array capacity exceeded"
- invoke-direct {v4, v5}, Ljava/lang/RuntimeException;-><init>(Ljava/lang/String;)V
- throw v4
- .line 34
- :cond_0
- new-array v0, v2, [Ljava/lang/Object;
- .line 35
- .local v0, "a":[Ljava/lang/Object;
- iget-object v4, p0, Landroid/support/v4/util/CircularArray;->mElements:[Ljava/lang/Object;
- iget v5, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- invoke-static {v4, v5, v0, v6, v3}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
- .line 36
- iget-object v4, p0, Landroid/support/v4/util/CircularArray;->mElements:[Ljava/lang/Object;
- iget v5, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- invoke-static {v4, v6, v0, v3, v5}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V
- .line 37
- check-cast v0, [Ljava/lang/Object;
- .end local v0 # "a":[Ljava/lang/Object;
- iput-object v0, p0, Landroid/support/v4/util/CircularArray;->mElements:[Ljava/lang/Object;
- .line 38
- iput v6, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- .line 39
- iput v1, p0, Landroid/support/v4/util/CircularArray;->mTail:I
- .line 40
- add-int/lit8 v4, v2, -0x1
- iput v4, p0, Landroid/support/v4/util/CircularArray;->mCapacityBitmask:I
- .line 41
- return-void
- .end method
- # virtual methods
- .method public addFirst(Ljava/lang/Object;)V
- .locals 2
- .annotation system Ldalvik/annotation/Signature;
- value = {
- "(TE;)V"
- }
- .end annotation
- .prologue
- .line 82
- .local p0, "this":Landroid/support/v4/util/CircularArray;, "Landroid/support/v4/util/CircularArray<TE;>;"
- .local p1, "e":Ljava/lang/Object;, "TE;"
- iget v0, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- add-int/lit8 v0, v0, -0x1
- iget v1, p0, Landroid/support/v4/util/CircularArray;->mCapacityBitmask:I
- and-int/2addr v0, v1
- iput v0, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- .line 83
- iget-object v0, p0, Landroid/support/v4/util/CircularArray;->mElements:[Ljava/lang/Object;
- iget v1, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- aput-object p1, v0, v1
- .line 84
- iget v0, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- iget v1, p0, Landroid/support/v4/util/CircularArray;->mTail:I
- if-ne v0, v1, :cond_0
- .line 85
- invoke-direct {p0}, Landroid/support/v4/util/CircularArray;->doubleCapacity()V
- .line 87
- :cond_0
- return-void
- .end method
- .method public addLast(Ljava/lang/Object;)V
- .locals 2
- .annotation system Ldalvik/annotation/Signature;
- value = {
- "(TE;)V"
- }
- .end annotation
- .prologue
- .line 94
- .local p0, "this":Landroid/support/v4/util/CircularArray;, "Landroid/support/v4/util/CircularArray<TE;>;"
- .local p1, "e":Ljava/lang/Object;, "TE;"
- iget-object v0, p0, Landroid/support/v4/util/CircularArray;->mElements:[Ljava/lang/Object;
- iget v1, p0, Landroid/support/v4/util/CircularArray;->mTail:I
- aput-object p1, v0, v1
- .line 95
- iget v0, p0, Landroid/support/v4/util/CircularArray;->mTail:I
- add-int/lit8 v0, v0, 0x1
- iget v1, p0, Landroid/support/v4/util/CircularArray;->mCapacityBitmask:I
- and-int/2addr v0, v1
- iput v0, p0, Landroid/support/v4/util/CircularArray;->mTail:I
- .line 96
- iget v0, p0, Landroid/support/v4/util/CircularArray;->mTail:I
- iget v1, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- if-ne v0, v1, :cond_0
- .line 97
- invoke-direct {p0}, Landroid/support/v4/util/CircularArray;->doubleCapacity()V
- .line 99
- :cond_0
- return-void
- .end method
- .method public clear()V
- .locals 1
- .prologue
- .line 136
- .local p0, "this":Landroid/support/v4/util/CircularArray;, "Landroid/support/v4/util/CircularArray<TE;>;"
- invoke-virtual {p0}, Landroid/support/v4/util/CircularArray;->size()I
- move-result v0
- invoke-virtual {p0, v0}, Landroid/support/v4/util/CircularArray;->removeFromStart(I)V
- .line 137
- return-void
- .end method
- .method public get(I)Ljava/lang/Object;
- .locals 3
- .param p1, "n" # I
- .annotation system Ldalvik/annotation/Signature;
- value = {
- "(I)TE;"
- }
- .end annotation
- .prologue
- .line 238
- .local p0, "this":Landroid/support/v4/util/CircularArray;, "Landroid/support/v4/util/CircularArray<TE;>;"
- if-ltz p1, :cond_0
- invoke-virtual {p0}, Landroid/support/v4/util/CircularArray;->size()I
- move-result v0
- if-lt p1, v0, :cond_1
- .line 239
- :cond_0
- new-instance v0, Ljava/lang/ArrayIndexOutOfBoundsException;
- invoke-direct {v0}, Ljava/lang/ArrayIndexOutOfBoundsException;-><init>()V
- throw v0
- .line 241
- :cond_1
- iget-object v0, p0, Landroid/support/v4/util/CircularArray;->mElements:[Ljava/lang/Object;
- iget v1, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- add-int/2addr v1, p1
- iget v2, p0, Landroid/support/v4/util/CircularArray;->mCapacityBitmask:I
- and-int/2addr v1, v2
- aget-object v0, v0, v1
- return-object v0
- .end method
- .method public getFirst()Ljava/lang/Object;
- .locals 2
- .annotation system Ldalvik/annotation/Signature;
- value = {
- "()TE;"
- }
- .end annotation
- .prologue
- .line 213
- .local p0, "this":Landroid/support/v4/util/CircularArray;, "Landroid/support/v4/util/CircularArray<TE;>;"
- iget v0, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- iget v1, p0, Landroid/support/v4/util/CircularArray;->mTail:I
- if-ne v0, v1, :cond_0
- .line 214
- new-instance v0, Ljava/lang/ArrayIndexOutOfBoundsException;
- invoke-direct {v0}, Ljava/lang/ArrayIndexOutOfBoundsException;-><init>()V
- throw v0
- .line 216
- :cond_0
- iget-object v0, p0, Landroid/support/v4/util/CircularArray;->mElements:[Ljava/lang/Object;
- iget v1, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- aget-object v0, v0, v1
- return-object v0
- .end method
- .method public getLast()Ljava/lang/Object;
- .locals 3
- .annotation system Ldalvik/annotation/Signature;
- value = {
- "()TE;"
- }
- .end annotation
- .prologue
- .line 225
- .local p0, "this":Landroid/support/v4/util/CircularArray;, "Landroid/support/v4/util/CircularArray<TE;>;"
- iget v0, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- iget v1, p0, Landroid/support/v4/util/CircularArray;->mTail:I
- if-ne v0, v1, :cond_0
- .line 226
- new-instance v0, Ljava/lang/ArrayIndexOutOfBoundsException;
- invoke-direct {v0}, Ljava/lang/ArrayIndexOutOfBoundsException;-><init>()V
- throw v0
- .line 228
- :cond_0
- iget-object v0, p0, Landroid/support/v4/util/CircularArray;->mElements:[Ljava/lang/Object;
- iget v1, p0, Landroid/support/v4/util/CircularArray;->mTail:I
- add-int/lit8 v1, v1, -0x1
- iget v2, p0, Landroid/support/v4/util/CircularArray;->mCapacityBitmask:I
- and-int/2addr v1, v2
- aget-object v0, v0, v1
- return-object v0
- .end method
- .method public isEmpty()Z
- .locals 2
- .prologue
- .line 257
- .local p0, "this":Landroid/support/v4/util/CircularArray;, "Landroid/support/v4/util/CircularArray<TE;>;"
- iget v0, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- iget v1, p0, Landroid/support/v4/util/CircularArray;->mTail:I
- if-ne v0, v1, :cond_0
- const/4 v0, 0x1
- :goto_0
- return v0
- :cond_0
- const/4 v0, 0x0
- goto :goto_0
- .end method
- .method public popFirst()Ljava/lang/Object;
- .locals 4
- .annotation system Ldalvik/annotation/Signature;
- value = {
- "()TE;"
- }
- .end annotation
- .prologue
- .line 107
- .local p0, "this":Landroid/support/v4/util/CircularArray;, "Landroid/support/v4/util/CircularArray<TE;>;"
- iget v1, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- iget v2, p0, Landroid/support/v4/util/CircularArray;->mTail:I
- if-ne v1, v2, :cond_0
- .line 108
- new-instance v1, Ljava/lang/ArrayIndexOutOfBoundsException;
- invoke-direct {v1}, Ljava/lang/ArrayIndexOutOfBoundsException;-><init>()V
- throw v1
- .line 110
- :cond_0
- iget-object v1, p0, Landroid/support/v4/util/CircularArray;->mElements:[Ljava/lang/Object;
- iget v2, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- aget-object v0, v1, v2
- .line 111
- .local v0, "result":Ljava/lang/Object;, "TE;"
- iget-object v1, p0, Landroid/support/v4/util/CircularArray;->mElements:[Ljava/lang/Object;
- iget v2, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- const/4 v3, 0x0
- aput-object v3, v1, v2
- .line 112
- iget v1, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- add-int/lit8 v1, v1, 0x1
- iget v2, p0, Landroid/support/v4/util/CircularArray;->mCapacityBitmask:I
- and-int/2addr v1, v2
- iput v1, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- .line 113
- return-object v0
- .end method
- .method public popLast()Ljava/lang/Object;
- .locals 4
- .annotation system Ldalvik/annotation/Signature;
- value = {
- "()TE;"
- }
- .end annotation
- .prologue
- .line 122
- .local p0, "this":Landroid/support/v4/util/CircularArray;, "Landroid/support/v4/util/CircularArray<TE;>;"
- iget v2, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- iget v3, p0, Landroid/support/v4/util/CircularArray;->mTail:I
- if-ne v2, v3, :cond_0
- .line 123
- new-instance v2, Ljava/lang/ArrayIndexOutOfBoundsException;
- invoke-direct {v2}, Ljava/lang/ArrayIndexOutOfBoundsException;-><init>()V
- throw v2
- .line 125
- :cond_0
- iget v2, p0, Landroid/support/v4/util/CircularArray;->mTail:I
- add-int/lit8 v2, v2, -0x1
- iget v3, p0, Landroid/support/v4/util/CircularArray;->mCapacityBitmask:I
- and-int v1, v2, v3
- .line 126
- .local v1, "t":I
- iget-object v2, p0, Landroid/support/v4/util/CircularArray;->mElements:[Ljava/lang/Object;
- aget-object v0, v2, v1
- .line 127
- .local v0, "result":Ljava/lang/Object;, "TE;"
- iget-object v2, p0, Landroid/support/v4/util/CircularArray;->mElements:[Ljava/lang/Object;
- const/4 v3, 0x0
- aput-object v3, v2, v1
- .line 128
- iput v1, p0, Landroid/support/v4/util/CircularArray;->mTail:I
- .line 129
- return-object v0
- .end method
- .method public removeFromEnd(I)V
- .locals 6
- .param p1, "numOfElements" # I
- .prologue
- .local p0, "this":Landroid/support/v4/util/CircularArray;, "Landroid/support/v4/util/CircularArray<TE;>;"
- const/4 v5, 0x0
- .line 180
- if-gtz p1, :cond_1
- .line 205
- :cond_0
- :goto_0
- return-void
- .line 183
- :cond_1
- invoke-virtual {p0}, Landroid/support/v4/util/CircularArray;->size()I
- move-result v4
- if-le p1, v4, :cond_2
- .line 184
- new-instance v4, Ljava/lang/ArrayIndexOutOfBoundsException;
- invoke-direct {v4}, Ljava/lang/ArrayIndexOutOfBoundsException;-><init>()V
- throw v4
- .line 186
- :cond_2
- const/4 v3, 0x0
- .line 187
- .local v3, "start":I
- iget v4, p0, Landroid/support/v4/util/CircularArray;->mTail:I
- if-ge p1, v4, :cond_3
- .line 188
- iget v4, p0, Landroid/support/v4/util/CircularArray;->mTail:I
- sub-int v3, v4, p1
- .line 190
- :cond_3
- move v0, v3
- .local v0, "i":I
- :goto_1
- iget v4, p0, Landroid/support/v4/util/CircularArray;->mTail:I
- if-ge v0, v4, :cond_4
- .line 191
- iget-object v4, p0, Landroid/support/v4/util/CircularArray;->mElements:[Ljava/lang/Object;
- aput-object v5, v4, v0
- .line 190
- add-int/lit8 v0, v0, 0x1
- goto :goto_1
- .line 193
- :cond_4
- iget v4, p0, Landroid/support/v4/util/CircularArray;->mTail:I
- sub-int v2, v4, v3
- .line 194
- .local v2, "removed":I
- sub-int/2addr p1, v2
- .line 195
- iget v4, p0, Landroid/support/v4/util/CircularArray;->mTail:I
- sub-int/2addr v4, v2
- iput v4, p0, Landroid/support/v4/util/CircularArray;->mTail:I
- .line 196
- if-lez p1, :cond_0
- .line 198
- iget-object v4, p0, Landroid/support/v4/util/CircularArray;->mElements:[Ljava/lang/Object;
- array-length v4, v4
- iput v4, p0, Landroid/support/v4/util/CircularArray;->mTail:I
- .line 199
- iget v4, p0, Landroid/support/v4/util/CircularArray;->mTail:I
- sub-int v1, v4, p1
- .line 200
- .local v1, "newTail":I
- move v0, v1
- :goto_2
- iget v4, p0, Landroid/support/v4/util/CircularArray;->mTail:I
- if-ge v0, v4, :cond_5
- .line 201
- iget-object v4, p0, Landroid/support/v4/util/CircularArray;->mElements:[Ljava/lang/Object;
- aput-object v5, v4, v0
- .line 200
- add-int/lit8 v0, v0, 0x1
- goto :goto_2
- .line 203
- :cond_5
- iput v1, p0, Landroid/support/v4/util/CircularArray;->mTail:I
- goto :goto_0
- .end method
- .method public removeFromStart(I)V
- .locals 6
- .param p1, "numOfElements" # I
- .prologue
- .local p0, "this":Landroid/support/v4/util/CircularArray;, "Landroid/support/v4/util/CircularArray<TE;>;"
- const/4 v5, 0x0
- .line 147
- if-gtz p1, :cond_1
- .line 170
- :cond_0
- :goto_0
- return-void
- .line 150
- :cond_1
- invoke-virtual {p0}, Landroid/support/v4/util/CircularArray;->size()I
- move-result v3
- if-le p1, v3, :cond_2
- .line 151
- new-instance v3, Ljava/lang/ArrayIndexOutOfBoundsException;
- invoke-direct {v3}, Ljava/lang/ArrayIndexOutOfBoundsException;-><init>()V
- throw v3
- .line 153
- :cond_2
- iget-object v3, p0, Landroid/support/v4/util/CircularArray;->mElements:[Ljava/lang/Object;
- array-length v0, v3
- .line 154
- .local v0, "end":I
- iget v3, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- sub-int v3, v0, v3
- if-ge p1, v3, :cond_3
- .line 155
- iget v3, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- add-int v0, v3, p1
- .line 157
- :cond_3
- iget v1, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- .local v1, "i":I
- :goto_1
- if-ge v1, v0, :cond_4
- .line 158
- iget-object v3, p0, Landroid/support/v4/util/CircularArray;->mElements:[Ljava/lang/Object;
- aput-object v5, v3, v1
- .line 157
- add-int/lit8 v1, v1, 0x1
- goto :goto_1
- .line 160
- :cond_4
- iget v3, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- sub-int v2, v0, v3
- .line 161
- .local v2, "removed":I
- sub-int/2addr p1, v2
- .line 162
- iget v3, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- add-int/2addr v3, v2
- iget v4, p0, Landroid/support/v4/util/CircularArray;->mCapacityBitmask:I
- and-int/2addr v3, v4
- iput v3, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- .line 163
- if-lez p1, :cond_0
- .line 165
- const/4 v1, 0x0
- :goto_2
- if-ge v1, p1, :cond_5
- .line 166
- iget-object v3, p0, Landroid/support/v4/util/CircularArray;->mElements:[Ljava/lang/Object;
- aput-object v5, v3, v1
- .line 165
- add-int/lit8 v1, v1, 0x1
- goto :goto_2
- .line 168
- :cond_5
- iput p1, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- goto :goto_0
- .end method
- .method public size()I
- .locals 2
- .prologue
- .line 249
- .local p0, "this":Landroid/support/v4/util/CircularArray;, "Landroid/support/v4/util/CircularArray<TE;>;"
- iget v0, p0, Landroid/support/v4/util/CircularArray;->mTail:I
- iget v1, p0, Landroid/support/v4/util/CircularArray;->mHead:I
- sub-int/2addr v0, v1
- iget v1, p0, Landroid/support/v4/util/CircularArray;->mCapacityBitmask:I
- and-int/2addr v0, v1
- return v0
- .end method
|