.class Lcom/google/common/collect/CompactLinkedHashMap; .super Lcom/google/common/collect/CompactHashMap; .source "CompactLinkedHashMap.java" # annotations .annotation build Lcom/google/common/annotations/GwtIncompatible; .end annotation .annotation runtime Lcom/google/common/collect/ElementTypesAreNonnullByDefault; .end annotation .annotation system Ldalvik/annotation/Signature; value = { "", "Lcom/google/common/collect/CompactHashMap<", "TK;TV;>;" } .end annotation # static fields .field private static final ENDPOINT:I = -0x2 # instance fields .field private final accessOrder:Z .field private transient firstEntry:I .field private transient lastEntry:I .field public transient links:[J .annotation build Lcom/google/common/annotations/VisibleForTesting; .end annotation .annotation runtime Ljavax/annotation/CheckForNull; .end annotation .end field # direct methods .method public constructor ()V .locals 1 const/4 v0, 0x3 .line 1 invoke-direct {p0, v0}, Lcom/google/common/collect/CompactLinkedHashMap;->(I)V return-void .end method .method public constructor (I)V .locals 1 const/4 v0, 0x0 .line 2 invoke-direct {p0, p1, v0}, Lcom/google/common/collect/CompactLinkedHashMap;->(IZ)V return-void .end method .method public constructor (IZ)V .locals 0 .line 3 invoke-direct {p0, p1}, Lcom/google/common/collect/CompactHashMap;->(I)V .line 4 iput-boolean p2, p0, Lcom/google/common/collect/CompactLinkedHashMap;->accessOrder:Z return-void .end method .method public static create()Lcom/google/common/collect/CompactLinkedHashMap; .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "()", "Lcom/google/common/collect/CompactLinkedHashMap<", "TK;TV;>;" } .end annotation .line 1 new-instance v0, Lcom/google/common/collect/CompactLinkedHashMap; invoke-direct {v0}, Lcom/google/common/collect/CompactLinkedHashMap;->()V return-object v0 .end method .method public static createWithExpectedSize(I)Lcom/google/common/collect/CompactLinkedHashMap; .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "(I)", "Lcom/google/common/collect/CompactLinkedHashMap<", "TK;TV;>;" } .end annotation .line 1 new-instance v0, Lcom/google/common/collect/CompactLinkedHashMap; invoke-direct {v0, p0}, Lcom/google/common/collect/CompactLinkedHashMap;->(I)V return-object v0 .end method .method private getPredecessor(I)I .locals 2 .line 1 invoke-direct {p0, p1}, Lcom/google/common/collect/CompactLinkedHashMap;->link(I)J move-result-wide v0 const/16 p1, 0x20 ushr-long/2addr v0, p1 long-to-int p1, v0 add-int/lit8 p1, p1, -0x1 return p1 .end method .method private link(I)J .locals 3 .line 1 invoke-direct {p0}, Lcom/google/common/collect/CompactLinkedHashMap;->requireLinks()[J move-result-object v0 aget-wide v1, v0, p1 return-wide v1 .end method .method private requireLinks()[J .locals 1 .line 1 iget-object v0, p0, Lcom/google/common/collect/CompactLinkedHashMap;->links:[J invoke-static {v0}, Ljava/util/Objects;->requireNonNull(Ljava/lang/Object;)Ljava/lang/Object; check-cast v0, [J return-object v0 .end method .method private setLink(IJ)V .locals 1 .line 1 invoke-direct {p0}, Lcom/google/common/collect/CompactLinkedHashMap;->requireLinks()[J move-result-object v0 aput-wide p2, v0, p1 return-void .end method .method private setPredecessor(II)V .locals 4 .line 1 invoke-direct {p0, p1}, Lcom/google/common/collect/CompactLinkedHashMap;->link(I)J move-result-wide v0 const-wide v2, 0xffffffffL and-long/2addr v0, v2 add-int/lit8 p2, p2, 0x1 int-to-long v2, p2 const/16 p2, 0x20 shl-long/2addr v2, p2 or-long/2addr v0, v2 invoke-direct {p0, p1, v0, v1}, Lcom/google/common/collect/CompactLinkedHashMap;->setLink(IJ)V return-void .end method .method private setSucceeds(II)V .locals 1 const/4 v0, -0x2 if-ne p1, v0, :cond_0 .line 1 iput p2, p0, Lcom/google/common/collect/CompactLinkedHashMap;->firstEntry:I goto :goto_0 .line 2 :cond_0 invoke-direct {p0, p1, p2}, Lcom/google/common/collect/CompactLinkedHashMap;->setSuccessor(II)V :goto_0 if-ne p2, v0, :cond_1 .line 3 iput p1, p0, Lcom/google/common/collect/CompactLinkedHashMap;->lastEntry:I goto :goto_1 .line 4 :cond_1 invoke-direct {p0, p2, p1}, Lcom/google/common/collect/CompactLinkedHashMap;->setPredecessor(II)V :goto_1 return-void .end method .method private setSuccessor(II)V .locals 6 .line 1 invoke-direct {p0, p1}, Lcom/google/common/collect/CompactLinkedHashMap;->link(I)J move-result-wide v0 const-wide v2, -0x100000000L and-long/2addr v0, v2 add-int/lit8 p2, p2, 0x1 int-to-long v2, p2 const-wide v4, 0xffffffffL and-long/2addr v2, v4 or-long/2addr v0, v2 invoke-direct {p0, p1, v0, v1}, Lcom/google/common/collect/CompactLinkedHashMap;->setLink(IJ)V return-void .end method # virtual methods .method public accessEntry(I)V .locals 2 .line 1 iget-boolean v0, p0, Lcom/google/common/collect/CompactLinkedHashMap;->accessOrder:Z if-eqz v0, :cond_0 .line 2 invoke-direct {p0, p1}, Lcom/google/common/collect/CompactLinkedHashMap;->getPredecessor(I)I move-result v0 invoke-virtual {p0, p1}, Lcom/google/common/collect/CompactLinkedHashMap;->getSuccessor(I)I move-result v1 invoke-direct {p0, v0, v1}, Lcom/google/common/collect/CompactLinkedHashMap;->setSucceeds(II)V .line 3 iget v0, p0, Lcom/google/common/collect/CompactLinkedHashMap;->lastEntry:I invoke-direct {p0, v0, p1}, Lcom/google/common/collect/CompactLinkedHashMap;->setSucceeds(II)V const/4 v0, -0x2 .line 4 invoke-direct {p0, p1, v0}, Lcom/google/common/collect/CompactLinkedHashMap;->setSucceeds(II)V .line 5 invoke-virtual {p0}, Lcom/google/common/collect/CompactHashMap;->incrementModCount()V :cond_0 return-void .end method .method public adjustAfterRemove(II)I .locals 1 .line 1 invoke-virtual {p0}, Lcom/google/common/collect/CompactHashMap;->size()I move-result v0 if-lt p1, v0, :cond_0 move p1, p2 :cond_0 return p1 .end method .method public allocArrays()I .locals 2 .line 1 invoke-super {p0}, Lcom/google/common/collect/CompactHashMap;->allocArrays()I move-result v0 .line 2 new-array v1, v0, [J iput-object v1, p0, Lcom/google/common/collect/CompactLinkedHashMap;->links:[J return v0 .end method .method public clear()V .locals 5 .line 1 invoke-virtual {p0}, Lcom/google/common/collect/CompactHashMap;->needsAllocArrays()Z move-result v0 if-eqz v0, :cond_0 return-void :cond_0 const/4 v0, -0x2 .line 2 iput v0, p0, Lcom/google/common/collect/CompactLinkedHashMap;->firstEntry:I .line 3 iput v0, p0, Lcom/google/common/collect/CompactLinkedHashMap;->lastEntry:I .line 4 iget-object v0, p0, Lcom/google/common/collect/CompactLinkedHashMap;->links:[J if-eqz v0, :cond_1 const/4 v1, 0x0 .line 5 invoke-virtual {p0}, Lcom/google/common/collect/CompactHashMap;->size()I move-result v2 const-wide/16 v3, 0x0 invoke-static {v0, v1, v2, v3, v4}, Ljava/util/Arrays;->fill([JIIJ)V .line 6 :cond_1 invoke-super {p0}, Lcom/google/common/collect/CompactHashMap;->clear()V return-void .end method .method public convertToHashFloodingResistantImplementation()Ljava/util/Map; .locals 2 .annotation build Lcom/google/errorprone/annotations/CanIgnoreReturnValue; .end annotation .annotation system Ldalvik/annotation/Signature; value = { "()", "Ljava/util/Map<", "TK;TV;>;" } .end annotation .line 1 invoke-super {p0}, Lcom/google/common/collect/CompactHashMap;->convertToHashFloodingResistantImplementation()Ljava/util/Map; move-result-object v0 const/4 v1, 0x0 .line 2 iput-object v1, p0, Lcom/google/common/collect/CompactLinkedHashMap;->links:[J return-object v0 .end method .method public createHashFloodingResistantDelegate(I)Ljava/util/Map; .locals 3 .annotation system Ldalvik/annotation/Signature; value = { "(I)", "Ljava/util/Map<", "TK;TV;>;" } .end annotation .line 1 new-instance v0, Ljava/util/LinkedHashMap; iget-boolean v1, p0, Lcom/google/common/collect/CompactLinkedHashMap;->accessOrder:Z const/high16 v2, 0x3f800000 # 1.0f invoke-direct {v0, p1, v2, v1}, Ljava/util/LinkedHashMap;->(IFZ)V return-object v0 .end method .method public firstEntryIndex()I .locals 1 .line 1 iget v0, p0, Lcom/google/common/collect/CompactLinkedHashMap;->firstEntry:I return v0 .end method .method public getSuccessor(I)I .locals 2 .line 1 invoke-direct {p0, p1}, Lcom/google/common/collect/CompactLinkedHashMap;->link(I)J move-result-wide v0 long-to-int p1, v0 add-int/lit8 p1, p1, -0x1 return p1 .end method .method public init(I)V .locals 0 .line 1 invoke-super {p0, p1}, Lcom/google/common/collect/CompactHashMap;->init(I)V const/4 p1, -0x2 .line 2 iput p1, p0, Lcom/google/common/collect/CompactLinkedHashMap;->firstEntry:I .line 3 iput p1, p0, Lcom/google/common/collect/CompactLinkedHashMap;->lastEntry:I return-void .end method .method public insertEntry(ILjava/lang/Object;Ljava/lang/Object;II)V .locals 0 .param p2 # Ljava/lang/Object; .annotation runtime Lcom/google/common/collect/ParametricNullness; .end annotation .end param .param p3 # Ljava/lang/Object; .annotation runtime Lcom/google/common/collect/ParametricNullness; .end annotation .end param .annotation system Ldalvik/annotation/Signature; value = { "(ITK;TV;II)V" } .end annotation .line 1 invoke-super/range {p0 .. p5}, Lcom/google/common/collect/CompactHashMap;->insertEntry(ILjava/lang/Object;Ljava/lang/Object;II)V .line 2 iget p2, p0, Lcom/google/common/collect/CompactLinkedHashMap;->lastEntry:I invoke-direct {p0, p2, p1}, Lcom/google/common/collect/CompactLinkedHashMap;->setSucceeds(II)V const/4 p2, -0x2 .line 3 invoke-direct {p0, p1, p2}, Lcom/google/common/collect/CompactLinkedHashMap;->setSucceeds(II)V return-void .end method .method public moveLastEntry(II)V .locals 2 .line 1 invoke-virtual {p0}, Lcom/google/common/collect/CompactHashMap;->size()I move-result v0 add-int/lit8 v0, v0, -0x1 .line 2 invoke-super {p0, p1, p2}, Lcom/google/common/collect/CompactHashMap;->moveLastEntry(II)V .line 3 invoke-direct {p0, p1}, Lcom/google/common/collect/CompactLinkedHashMap;->getPredecessor(I)I move-result p2 invoke-virtual {p0, p1}, Lcom/google/common/collect/CompactLinkedHashMap;->getSuccessor(I)I move-result v1 invoke-direct {p0, p2, v1}, Lcom/google/common/collect/CompactLinkedHashMap;->setSucceeds(II)V if-ge p1, v0, :cond_0 .line 4 invoke-direct {p0, v0}, Lcom/google/common/collect/CompactLinkedHashMap;->getPredecessor(I)I move-result p2 invoke-direct {p0, p2, p1}, Lcom/google/common/collect/CompactLinkedHashMap;->setSucceeds(II)V .line 5 invoke-virtual {p0, v0}, Lcom/google/common/collect/CompactLinkedHashMap;->getSuccessor(I)I move-result p2 invoke-direct {p0, p1, p2}, Lcom/google/common/collect/CompactLinkedHashMap;->setSucceeds(II)V :cond_0 const-wide/16 p1, 0x0 .line 6 invoke-direct {p0, v0, p1, p2}, Lcom/google/common/collect/CompactLinkedHashMap;->setLink(IJ)V return-void .end method .method public resizeEntries(I)V .locals 1 .line 1 invoke-super {p0, p1}, Lcom/google/common/collect/CompactHashMap;->resizeEntries(I)V .line 2 invoke-direct {p0}, Lcom/google/common/collect/CompactLinkedHashMap;->requireLinks()[J move-result-object v0 invoke-static {v0, p1}, Ljava/util/Arrays;->copyOf([JI)[J move-result-object p1 iput-object p1, p0, Lcom/google/common/collect/CompactLinkedHashMap;->links:[J return-void .end method