.class Lcom/google/common/collect/CompactLinkedHashSet; .super Lcom/google/common/collect/CompactHashSet; .source "CompactLinkedHashSet.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/CompactHashSet<", "TE;>;" } .end annotation # static fields .field private static final ENDPOINT:I = -0x2 # instance fields .field private transient firstEntry:I .field private transient lastEntry:I .field private transient predecessor:[I .annotation runtime Ljavax/annotation/CheckForNull; .end annotation .end field .field private transient successor:[I .annotation runtime Ljavax/annotation/CheckForNull; .end annotation .end field # direct methods .method public constructor ()V .locals 0 .line 1 invoke-direct {p0}, Lcom/google/common/collect/CompactHashSet;->()V return-void .end method .method public constructor (I)V .locals 0 .line 2 invoke-direct {p0, p1}, Lcom/google/common/collect/CompactHashSet;->(I)V return-void .end method .method public static create()Lcom/google/common/collect/CompactLinkedHashSet; .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "()", "Lcom/google/common/collect/CompactLinkedHashSet<", "TE;>;" } .end annotation .line 1 new-instance v0, Lcom/google/common/collect/CompactLinkedHashSet; invoke-direct {v0}, Lcom/google/common/collect/CompactLinkedHashSet;->()V return-object v0 .end method .method public static create(Ljava/util/Collection;)Lcom/google/common/collect/CompactLinkedHashSet; .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "(", "Ljava/util/Collection<", "+TE;>;)", "Lcom/google/common/collect/CompactLinkedHashSet<", "TE;>;" } .end annotation .line 2 invoke-interface {p0}, Ljava/util/Collection;->size()I move-result v0 invoke-static {v0}, Lcom/google/common/collect/CompactLinkedHashSet;->createWithExpectedSize(I)Lcom/google/common/collect/CompactLinkedHashSet; move-result-object v0 .line 3 invoke-virtual {v0, p0}, Ljava/util/AbstractSet;->addAll(Ljava/util/Collection;)Z return-object v0 .end method .method public static varargs create([Ljava/lang/Object;)Lcom/google/common/collect/CompactLinkedHashSet; .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "([TE;)", "Lcom/google/common/collect/CompactLinkedHashSet<", "TE;>;" } .end annotation .annotation runtime Ljava/lang/SafeVarargs; .end annotation .line 4 array-length v0, p0 invoke-static {v0}, Lcom/google/common/collect/CompactLinkedHashSet;->createWithExpectedSize(I)Lcom/google/common/collect/CompactLinkedHashSet; move-result-object v0 .line 5 invoke-static {v0, p0}, Ljava/util/Collections;->addAll(Ljava/util/Collection;[Ljava/lang/Object;)Z return-object v0 .end method .method public static createWithExpectedSize(I)Lcom/google/common/collect/CompactLinkedHashSet; .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "(I)", "Lcom/google/common/collect/CompactLinkedHashSet<", "TE;>;" } .end annotation .line 1 new-instance v0, Lcom/google/common/collect/CompactLinkedHashSet; invoke-direct {v0, p0}, Lcom/google/common/collect/CompactLinkedHashSet;->(I)V return-object v0 .end method .method private getPredecessor(I)I .locals 1 .line 1 invoke-direct {p0}, Lcom/google/common/collect/CompactLinkedHashSet;->requirePredecessors()[I move-result-object v0 aget p1, v0, p1 add-int/lit8 p1, p1, -0x1 return p1 .end method .method private requirePredecessors()[I .locals 1 .line 1 iget-object v0, p0, Lcom/google/common/collect/CompactLinkedHashSet;->predecessor:[I invoke-static {v0}, Ljava/util/Objects;->requireNonNull(Ljava/lang/Object;)Ljava/lang/Object; check-cast v0, [I return-object v0 .end method .method private requireSuccessors()[I .locals 1 .line 1 iget-object v0, p0, Lcom/google/common/collect/CompactLinkedHashSet;->successor:[I invoke-static {v0}, Ljava/util/Objects;->requireNonNull(Ljava/lang/Object;)Ljava/lang/Object; check-cast v0, [I return-object v0 .end method .method private setPredecessor(II)V .locals 1 .line 1 invoke-direct {p0}, Lcom/google/common/collect/CompactLinkedHashSet;->requirePredecessors()[I move-result-object v0 add-int/lit8 p2, p2, 0x1 aput p2, v0, p1 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/CompactLinkedHashSet;->firstEntry:I goto :goto_0 .line 2 :cond_0 invoke-direct {p0, p1, p2}, Lcom/google/common/collect/CompactLinkedHashSet;->setSuccessor(II)V :goto_0 if-ne p2, v0, :cond_1 .line 3 iput p1, p0, Lcom/google/common/collect/CompactLinkedHashSet;->lastEntry:I goto :goto_1 .line 4 :cond_1 invoke-direct {p0, p2, p1}, Lcom/google/common/collect/CompactLinkedHashSet;->setPredecessor(II)V :goto_1 return-void .end method .method private setSuccessor(II)V .locals 1 .line 1 invoke-direct {p0}, Lcom/google/common/collect/CompactLinkedHashSet;->requireSuccessors()[I move-result-object v0 add-int/lit8 p2, p2, 0x1 aput p2, v0, p1 return-void .end method # virtual methods .method public adjustAfterRemove(II)I .locals 1 .line 1 invoke-virtual {p0}, Lcom/google/common/collect/CompactHashSet;->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/CompactHashSet;->allocArrays()I move-result v0 .line 2 new-array v1, v0, [I iput-object v1, p0, Lcom/google/common/collect/CompactLinkedHashSet;->predecessor:[I .line 3 new-array v1, v0, [I iput-object v1, p0, Lcom/google/common/collect/CompactLinkedHashSet;->successor:[I return v0 .end method .method public clear()V .locals 3 .line 1 invoke-virtual {p0}, Lcom/google/common/collect/CompactHashSet;->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/CompactLinkedHashSet;->firstEntry:I .line 3 iput v0, p0, Lcom/google/common/collect/CompactLinkedHashSet;->lastEntry:I .line 4 iget-object v0, p0, Lcom/google/common/collect/CompactLinkedHashSet;->predecessor:[I if-eqz v0, :cond_1 iget-object v1, p0, Lcom/google/common/collect/CompactLinkedHashSet;->successor:[I if-eqz v1, :cond_1 .line 5 invoke-virtual {p0}, Lcom/google/common/collect/CompactHashSet;->size()I move-result v1 const/4 v2, 0x0 invoke-static {v0, v2, v1, v2}, Ljava/util/Arrays;->fill([IIII)V .line 6 iget-object v0, p0, Lcom/google/common/collect/CompactLinkedHashSet;->successor:[I invoke-virtual {p0}, Lcom/google/common/collect/CompactHashSet;->size()I move-result v1 invoke-static {v0, v2, v1, v2}, Ljava/util/Arrays;->fill([IIII)V .line 7 :cond_1 invoke-super {p0}, Lcom/google/common/collect/CompactHashSet;->clear()V return-void .end method .method public convertToHashFloodingResistantImplementation()Ljava/util/Set; .locals 2 .annotation build Lcom/google/errorprone/annotations/CanIgnoreReturnValue; .end annotation .annotation system Ldalvik/annotation/Signature; value = { "()", "Ljava/util/Set<", "TE;>;" } .end annotation .line 1 invoke-super {p0}, Lcom/google/common/collect/CompactHashSet;->convertToHashFloodingResistantImplementation()Ljava/util/Set; move-result-object v0 const/4 v1, 0x0 .line 2 iput-object v1, p0, Lcom/google/common/collect/CompactLinkedHashSet;->predecessor:[I .line 3 iput-object v1, p0, Lcom/google/common/collect/CompactLinkedHashSet;->successor:[I return-object v0 .end method .method public firstEntryIndex()I .locals 1 .line 1 iget v0, p0, Lcom/google/common/collect/CompactLinkedHashSet;->firstEntry:I return v0 .end method .method public getSuccessor(I)I .locals 1 .line 1 invoke-direct {p0}, Lcom/google/common/collect/CompactLinkedHashSet;->requireSuccessors()[I move-result-object v0 aget p1, v0, p1 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/CompactHashSet;->init(I)V const/4 p1, -0x2 .line 2 iput p1, p0, Lcom/google/common/collect/CompactLinkedHashSet;->firstEntry:I .line 3 iput p1, p0, Lcom/google/common/collect/CompactLinkedHashSet;->lastEntry:I return-void .end method .method public insertEntry(ILjava/lang/Object;II)V .locals 0 .param p2 # Ljava/lang/Object; .annotation runtime Lcom/google/common/collect/ParametricNullness; .end annotation .end param .annotation system Ldalvik/annotation/Signature; value = { "(ITE;II)V" } .end annotation .line 1 invoke-super {p0, p1, p2, p3, p4}, Lcom/google/common/collect/CompactHashSet;->insertEntry(ILjava/lang/Object;II)V .line 2 iget p2, p0, Lcom/google/common/collect/CompactLinkedHashSet;->lastEntry:I invoke-direct {p0, p2, p1}, Lcom/google/common/collect/CompactLinkedHashSet;->setSucceeds(II)V const/4 p2, -0x2 .line 3 invoke-direct {p0, p1, p2}, Lcom/google/common/collect/CompactLinkedHashSet;->setSucceeds(II)V return-void .end method .method public moveLastEntry(II)V .locals 2 .line 1 invoke-virtual {p0}, Lcom/google/common/collect/CompactHashSet;->size()I move-result v0 add-int/lit8 v0, v0, -0x1 .line 2 invoke-super {p0, p1, p2}, Lcom/google/common/collect/CompactHashSet;->moveLastEntry(II)V .line 3 invoke-direct {p0, p1}, Lcom/google/common/collect/CompactLinkedHashSet;->getPredecessor(I)I move-result p2 invoke-virtual {p0, p1}, Lcom/google/common/collect/CompactLinkedHashSet;->getSuccessor(I)I move-result v1 invoke-direct {p0, p2, v1}, Lcom/google/common/collect/CompactLinkedHashSet;->setSucceeds(II)V if-ge p1, v0, :cond_0 .line 4 invoke-direct {p0, v0}, Lcom/google/common/collect/CompactLinkedHashSet;->getPredecessor(I)I move-result p2 invoke-direct {p0, p2, p1}, Lcom/google/common/collect/CompactLinkedHashSet;->setSucceeds(II)V .line 5 invoke-virtual {p0, v0}, Lcom/google/common/collect/CompactLinkedHashSet;->getSuccessor(I)I move-result p2 invoke-direct {p0, p1, p2}, Lcom/google/common/collect/CompactLinkedHashSet;->setSucceeds(II)V .line 6 :cond_0 invoke-direct {p0}, Lcom/google/common/collect/CompactLinkedHashSet;->requirePredecessors()[I move-result-object p1 const/4 p2, 0x0 aput p2, p1, v0 .line 7 invoke-direct {p0}, Lcom/google/common/collect/CompactLinkedHashSet;->requireSuccessors()[I move-result-object p1 aput p2, p1, v0 return-void .end method .method public resizeEntries(I)V .locals 1 .line 1 invoke-super {p0, p1}, Lcom/google/common/collect/CompactHashSet;->resizeEntries(I)V .line 2 invoke-direct {p0}, Lcom/google/common/collect/CompactLinkedHashSet;->requirePredecessors()[I move-result-object v0 invoke-static {v0, p1}, Ljava/util/Arrays;->copyOf([II)[I move-result-object v0 iput-object v0, p0, Lcom/google/common/collect/CompactLinkedHashSet;->predecessor:[I .line 3 invoke-direct {p0}, Lcom/google/common/collect/CompactLinkedHashSet;->requireSuccessors()[I move-result-object v0 invoke-static {v0, p1}, Ljava/util/Arrays;->copyOf([II)[I move-result-object p1 iput-object p1, p0, Lcom/google/common/collect/CompactLinkedHashSet;->successor:[I return-void .end method .method public toArray()[Ljava/lang/Object; .locals 1 .line 1 invoke-static {p0}, Lcom/google/common/collect/ObjectArrays;->toArrayImpl(Ljava/util/Collection;)[Ljava/lang/Object; move-result-object v0 return-object v0 .end method .method public toArray([Ljava/lang/Object;)[Ljava/lang/Object; .locals 0 .annotation system Ldalvik/annotation/Signature; value = { "([TT;)[TT;" } .end annotation .line 2 invoke-static {p0, p1}, Lcom/google/common/collect/ObjectArrays;->toArrayImpl(Ljava/util/Collection;[Ljava/lang/Object;)[Ljava/lang/Object; move-result-object p1 return-object p1 .end method