.class public final Lcom/google/common/collect/TreeMultiset; .super Lcom/google/common/collect/AbstractSortedMultiset; .source "TreeMultiset.java" # interfaces .implements Ljava/io/Serializable; # annotations .annotation build Lcom/google/common/annotations/GwtCompatible; emulated = true .end annotation .annotation runtime Lcom/google/common/collect/ElementTypesAreNonnullByDefault; .end annotation .annotation system Ldalvik/annotation/MemberClasses; value = { Lcom/google/common/collect/TreeMultiset$AvlNode;, Lcom/google/common/collect/TreeMultiset$Reference;, Lcom/google/common/collect/TreeMultiset$Aggregate; } .end annotation .annotation system Ldalvik/annotation/Signature; value = { "", "Lcom/google/common/collect/AbstractSortedMultiset<", "TE;>;", "Ljava/io/Serializable;" } .end annotation # static fields .field private static final serialVersionUID:J = 0x1L .annotation build Lcom/google/common/annotations/GwtIncompatible; .end annotation .end field # instance fields .field private final transient header:Lcom/google/common/collect/TreeMultiset$AvlNode; .annotation system Ldalvik/annotation/Signature; value = { "Lcom/google/common/collect/TreeMultiset$AvlNode<", "TE;>;" } .end annotation .end field .field private final transient range:Lcom/google/common/collect/GeneralRange; .annotation system Ldalvik/annotation/Signature; value = { "Lcom/google/common/collect/GeneralRange<", "TE;>;" } .end annotation .end field .field private final transient rootReference:Lcom/google/common/collect/TreeMultiset$Reference; .annotation system Ldalvik/annotation/Signature; value = { "Lcom/google/common/collect/TreeMultiset$Reference<", "Lcom/google/common/collect/TreeMultiset$AvlNode<", "TE;>;>;" } .end annotation .end field # direct methods .method public constructor (Lcom/google/common/collect/TreeMultiset$Reference;Lcom/google/common/collect/GeneralRange;Lcom/google/common/collect/TreeMultiset$AvlNode;)V .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "(", "Lcom/google/common/collect/TreeMultiset$Reference<", "Lcom/google/common/collect/TreeMultiset$AvlNode<", "TE;>;>;", "Lcom/google/common/collect/GeneralRange<", "TE;>;", "Lcom/google/common/collect/TreeMultiset$AvlNode<", "TE;>;)V" } .end annotation .line 1 invoke-virtual {p2}, Lcom/google/common/collect/GeneralRange;->comparator()Ljava/util/Comparator; move-result-object v0 invoke-direct {p0, v0}, Lcom/google/common/collect/AbstractSortedMultiset;->(Ljava/util/Comparator;)V .line 2 iput-object p1, p0, Lcom/google/common/collect/TreeMultiset;->rootReference:Lcom/google/common/collect/TreeMultiset$Reference; .line 3 iput-object p2, p0, Lcom/google/common/collect/TreeMultiset;->range:Lcom/google/common/collect/GeneralRange; .line 4 iput-object p3, p0, Lcom/google/common/collect/TreeMultiset;->header:Lcom/google/common/collect/TreeMultiset$AvlNode; return-void .end method .method public constructor (Ljava/util/Comparator;)V .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "(", "Ljava/util/Comparator<", "-TE;>;)V" } .end annotation .line 5 invoke-direct {p0, p1}, Lcom/google/common/collect/AbstractSortedMultiset;->(Ljava/util/Comparator;)V .line 6 invoke-static {p1}, Lcom/google/common/collect/GeneralRange;->all(Ljava/util/Comparator;)Lcom/google/common/collect/GeneralRange; move-result-object p1 iput-object p1, p0, Lcom/google/common/collect/TreeMultiset;->range:Lcom/google/common/collect/GeneralRange; .line 7 new-instance p1, Lcom/google/common/collect/TreeMultiset$AvlNode; invoke-direct {p1}, Lcom/google/common/collect/TreeMultiset$AvlNode;->()V iput-object p1, p0, Lcom/google/common/collect/TreeMultiset;->header:Lcom/google/common/collect/TreeMultiset$AvlNode; .line 8 invoke-static {p1, p1}, Lcom/google/common/collect/TreeMultiset;->successor(Lcom/google/common/collect/TreeMultiset$AvlNode;Lcom/google/common/collect/TreeMultiset$AvlNode;)V .line 9 new-instance p1, Lcom/google/common/collect/TreeMultiset$Reference; const/4 v0, 0x0 invoke-direct {p1, v0}, Lcom/google/common/collect/TreeMultiset$Reference;->(Lcom/google/common/collect/TreeMultiset$1;)V iput-object p1, p0, Lcom/google/common/collect/TreeMultiset;->rootReference:Lcom/google/common/collect/TreeMultiset$Reference; return-void .end method .method public static synthetic access$1300(Lcom/google/common/collect/TreeMultiset;)Lcom/google/common/collect/TreeMultiset$AvlNode; .locals 0 .line 1 invoke-direct {p0}, Lcom/google/common/collect/TreeMultiset;->firstNode()Lcom/google/common/collect/TreeMultiset$AvlNode; move-result-object p0 return-object p0 .end method .method public static synthetic access$1400(Lcom/google/common/collect/TreeMultiset;)Lcom/google/common/collect/GeneralRange; .locals 0 .line 1 iget-object p0, p0, Lcom/google/common/collect/TreeMultiset;->range:Lcom/google/common/collect/GeneralRange; return-object p0 .end method .method public static synthetic access$1500(Lcom/google/common/collect/TreeMultiset;Lcom/google/common/collect/TreeMultiset$AvlNode;)Lcom/google/common/collect/Multiset$Entry; .locals 0 .line 1 invoke-direct {p0, p1}, Lcom/google/common/collect/TreeMultiset;->wrapEntry(Lcom/google/common/collect/TreeMultiset$AvlNode;)Lcom/google/common/collect/Multiset$Entry; move-result-object p0 return-object p0 .end method .method public static synthetic access$1600(Lcom/google/common/collect/TreeMultiset;)Lcom/google/common/collect/TreeMultiset$AvlNode; .locals 0 .line 1 iget-object p0, p0, Lcom/google/common/collect/TreeMultiset;->header:Lcom/google/common/collect/TreeMultiset$AvlNode; return-object p0 .end method .method public static synthetic access$1700(Lcom/google/common/collect/TreeMultiset;)Lcom/google/common/collect/TreeMultiset$AvlNode; .locals 0 .line 1 invoke-direct {p0}, Lcom/google/common/collect/TreeMultiset;->lastNode()Lcom/google/common/collect/TreeMultiset$AvlNode; move-result-object p0 return-object p0 .end method .method public static synthetic access$1800(Lcom/google/common/collect/TreeMultiset$AvlNode;Lcom/google/common/collect/TreeMultiset$AvlNode;Lcom/google/common/collect/TreeMultiset$AvlNode;)V .locals 0 .line 1 invoke-static {p0, p1, p2}, Lcom/google/common/collect/TreeMultiset;->successor(Lcom/google/common/collect/TreeMultiset$AvlNode;Lcom/google/common/collect/TreeMultiset$AvlNode;Lcom/google/common/collect/TreeMultiset$AvlNode;)V return-void .end method .method public static synthetic access$1900(Lcom/google/common/collect/TreeMultiset$AvlNode;Lcom/google/common/collect/TreeMultiset$AvlNode;)V .locals 0 .line 1 invoke-static {p0, p1}, Lcom/google/common/collect/TreeMultiset;->successor(Lcom/google/common/collect/TreeMultiset$AvlNode;Lcom/google/common/collect/TreeMultiset$AvlNode;)V return-void .end method .method private aggregateAboveRange(Lcom/google/common/collect/TreeMultiset$Aggregate;Lcom/google/common/collect/TreeMultiset$AvlNode;)J .locals 4 .param p2 # Lcom/google/common/collect/TreeMultiset$AvlNode; .annotation runtime Ljavax/annotation/CheckForNull; .end annotation .end param .annotation system Ldalvik/annotation/Signature; value = { "(", "Lcom/google/common/collect/TreeMultiset$Aggregate;", "Lcom/google/common/collect/TreeMultiset$AvlNode<", "TE;>;)J" } .end annotation if-nez p2, :cond_0 const-wide/16 p1, 0x0 return-wide p1 .line 1 :cond_0 invoke-virtual {p0}, Lcom/google/common/collect/TreeMultiset;->comparator()Ljava/util/Comparator; move-result-object v0 iget-object v1, p0, Lcom/google/common/collect/TreeMultiset;->range:Lcom/google/common/collect/GeneralRange; .line 2 invoke-virtual {v1}, Lcom/google/common/collect/GeneralRange;->getUpperEndpoint()Ljava/lang/Object; move-result-object v1 invoke-static {v1}, Lcom/google/common/collect/NullnessCasts;->uncheckedCastNullableTToT(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v1 invoke-virtual {p2}, Lcom/google/common/collect/TreeMultiset$AvlNode;->getElement()Ljava/lang/Object; move-result-object v2 invoke-interface {v0, v1, v2}, Ljava/util/Comparator;->compare(Ljava/lang/Object;Ljava/lang/Object;)I move-result v0 if-lez v0, :cond_1 .line 3 invoke-static {p2}, Lcom/google/common/collect/TreeMultiset$AvlNode;->access$600(Lcom/google/common/collect/TreeMultiset$AvlNode;)Lcom/google/common/collect/TreeMultiset$AvlNode; move-result-object p2 invoke-direct {p0, p1, p2}, Lcom/google/common/collect/TreeMultiset;->aggregateAboveRange(Lcom/google/common/collect/TreeMultiset$Aggregate;Lcom/google/common/collect/TreeMultiset$AvlNode;)J move-result-wide p1 return-wide p1 :cond_1 if-nez v0, :cond_4 .line 4 sget-object v0, Lcom/google/common/collect/TreeMultiset$4;->$SwitchMap$com$google$common$collect$BoundType:[I iget-object v1, p0, Lcom/google/common/collect/TreeMultiset;->range:Lcom/google/common/collect/GeneralRange; invoke-virtual {v1}, Lcom/google/common/collect/GeneralRange;->getUpperBoundType()Lcom/google/common/collect/BoundType; move-result-object v1 invoke-virtual {v1}, Ljava/lang/Enum;->ordinal()I move-result v1 aget v0, v0, v1 const/4 v1, 0x1 if-eq v0, v1, :cond_3 const/4 v1, 0x2 if-ne v0, v1, :cond_2 .line 5 invoke-static {p2}, Lcom/google/common/collect/TreeMultiset$AvlNode;->access$600(Lcom/google/common/collect/TreeMultiset$AvlNode;)Lcom/google/common/collect/TreeMultiset$AvlNode; move-result-object p2 invoke-virtual {p1, p2}, Lcom/google/common/collect/TreeMultiset$Aggregate;->treeAggregate(Lcom/google/common/collect/TreeMultiset$AvlNode;)J move-result-wide p1 return-wide p1 .line 6 :cond_2 new-instance p1, Ljava/lang/AssertionError; invoke-direct {p1}, Ljava/lang/AssertionError;->()V throw p1 .line 7 :cond_3 invoke-virtual {p1, p2}, Lcom/google/common/collect/TreeMultiset$Aggregate;->nodeAggregate(Lcom/google/common/collect/TreeMultiset$AvlNode;)I move-result v0 int-to-long v0, v0 invoke-static {p2}, Lcom/google/common/collect/TreeMultiset$AvlNode;->access$600(Lcom/google/common/collect/TreeMultiset$AvlNode;)Lcom/google/common/collect/TreeMultiset$AvlNode; move-result-object p2 invoke-virtual {p1, p2}, Lcom/google/common/collect/TreeMultiset$Aggregate;->treeAggregate(Lcom/google/common/collect/TreeMultiset$AvlNode;)J move-result-wide p1 :goto_0 add-long/2addr v0, p1 return-wide v0 .line 8 :cond_4 invoke-static {p2}, Lcom/google/common/collect/TreeMultiset$AvlNode;->access$600(Lcom/google/common/collect/TreeMultiset$AvlNode;)Lcom/google/common/collect/TreeMultiset$AvlNode; move-result-object v0 invoke-virtual {p1, v0}, Lcom/google/common/collect/TreeMultiset$Aggregate;->treeAggregate(Lcom/google/common/collect/TreeMultiset$AvlNode;)J move-result-wide v0 .line 9 invoke-virtual {p1, p2}, Lcom/google/common/collect/TreeMultiset$Aggregate;->nodeAggregate(Lcom/google/common/collect/TreeMultiset$AvlNode;)I move-result v2 int-to-long v2, v2 add-long/2addr v0, v2 .line 10 invoke-static {p2}, Lcom/google/common/collect/TreeMultiset$AvlNode;->access$500(Lcom/google/common/collect/TreeMultiset$AvlNode;)Lcom/google/common/collect/TreeMultiset$AvlNode; move-result-object p2 invoke-direct {p0, p1, p2}, Lcom/google/common/collect/TreeMultiset;->aggregateAboveRange(Lcom/google/common/collect/TreeMultiset$Aggregate;Lcom/google/common/collect/TreeMultiset$AvlNode;)J move-result-wide p1 goto :goto_0 .end method .method private aggregateBelowRange(Lcom/google/common/collect/TreeMultiset$Aggregate;Lcom/google/common/collect/TreeMultiset$AvlNode;)J .locals 4 .param p2 # Lcom/google/common/collect/TreeMultiset$AvlNode; .annotation runtime Ljavax/annotation/CheckForNull; .end annotation .end param .annotation system Ldalvik/annotation/Signature; value = { "(", "Lcom/google/common/collect/TreeMultiset$Aggregate;", "Lcom/google/common/collect/TreeMultiset$AvlNode<", "TE;>;)J" } .end annotation if-nez p2, :cond_0 const-wide/16 p1, 0x0 return-wide p1 .line 1 :cond_0 invoke-virtual {p0}, Lcom/google/common/collect/TreeMultiset;->comparator()Ljava/util/Comparator; move-result-object v0 iget-object v1, p0, Lcom/google/common/collect/TreeMultiset;->range:Lcom/google/common/collect/GeneralRange; .line 2 invoke-virtual {v1}, Lcom/google/common/collect/GeneralRange;->getLowerEndpoint()Ljava/lang/Object; move-result-object v1 invoke-static {v1}, Lcom/google/common/collect/NullnessCasts;->uncheckedCastNullableTToT(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v1 invoke-virtual {p2}, Lcom/google/common/collect/TreeMultiset$AvlNode;->getElement()Ljava/lang/Object; move-result-object v2 invoke-interface {v0, v1, v2}, Ljava/util/Comparator;->compare(Ljava/lang/Object;Ljava/lang/Object;)I move-result v0 if-gez v0, :cond_1 .line 3 invoke-static {p2}, Lcom/google/common/collect/TreeMultiset$AvlNode;->access$500(Lcom/google/common/collect/TreeMultiset$AvlNode;)Lcom/google/common/collect/TreeMultiset$AvlNode; move-result-object p2 invoke-direct {p0, p1, p2}, Lcom/google/common/collect/TreeMultiset;->aggregateBelowRange(Lcom/google/common/collect/TreeMultiset$Aggregate;Lcom/google/common/collect/TreeMultiset$AvlNode;)J move-result-wide p1 return-wide p1 :cond_1 if-nez v0, :cond_4 .line 4 sget-object v0, Lcom/google/common/collect/TreeMultiset$4;->$SwitchMap$com$google$common$collect$BoundType:[I iget-object v1, p0, Lcom/google/common/collect/TreeMultiset;->range:Lcom/google/common/collect/GeneralRange; invoke-virtual {v1}, Lcom/google/common/collect/GeneralRange;->getLowerBoundType()Lcom/google/common/collect/BoundType; move-result-object v1 invoke-virtual {v1}, Ljava/lang/Enum;->ordinal()I move-result v1 aget v0, v0, v1 const/4 v1, 0x1 if-eq v0, v1, :cond_3 const/4 v1, 0x2 if-ne v0, v1, :cond_2 .line 5 invoke-static {p2}, Lcom/google/common/collect/TreeMultiset$AvlNode;->access$500(Lcom/google/common/collect/TreeMultiset$AvlNode;)Lcom/google/common/collect/TreeMultiset$AvlNode; move-result-object p2 invoke-virtual {p1, p2}, Lcom/google/common/collect/TreeMultiset$Aggregate;->treeAggregate(Lcom/google/common/collect/TreeMultiset$AvlNode;)J move-result-wide p1 return-wide p1 .line 6 :cond_2 new-instance p1, Ljava/lang/AssertionError; invoke-direct {p1}, Ljava/lang/AssertionError;->()V throw p1 .line 7 :cond_3 invoke-virtual {p1, p2}, Lcom/google/common/collect/TreeMultiset$Aggregate;->nodeAggregate(Lcom/google/common/collect/TreeMultiset$AvlNode;)I move-result v0 int-to-long v0, v0 invoke-static {p2}, Lcom/google/common/collect/TreeMultiset$AvlNode;->access$500(Lcom/google/common/collect/TreeMultiset$AvlNode;)Lcom/google/common/collect/TreeMultiset$AvlNode; move-result-object p2 invoke-virtual {p1, p2}, Lcom/google/common/collect/TreeMultiset$Aggregate;->treeAggregate(Lcom/google/common/collect/TreeMultiset$AvlNode;)J move-result-wide p1 :goto_0 add-long/2addr v0, p1 return-wide v0 .line 8 :cond_4 invoke-static {p2}, Lcom/google/common/collect/TreeMultiset$AvlNode;->access$500(Lcom/google/common/collect/TreeMultiset$AvlNode;)Lcom/google/common/collect/TreeMultiset$AvlNode; move-result-object v0 invoke-virtual {p1, v0}, Lcom/google/common/collect/TreeMultiset$Aggregate;->treeAggregate(Lcom/google/common/collect/TreeMultiset$AvlNode;)J move-result-wide v0 .line 9 invoke-virtual {p1, p2}, Lcom/google/common/collect/TreeMultiset$Aggregate;->nodeAggregate(Lcom/google/common/collect/TreeMultiset$AvlNode;)I move-result v2 int-to-long v2, v2 add-long/2addr v0, v2 .line 10 invoke-static {p2}, Lcom/google/common/collect/TreeMultiset$AvlNode;->access$600(Lcom/google/common/collect/TreeMultiset$AvlNode;)Lcom/google/common/collect/TreeMultiset$AvlNode; move-result-object p2 invoke-direct {p0, p1, p2}, Lcom/google/common/collect/TreeMultiset;->aggregateBelowRange(Lcom/google/common/collect/TreeMultiset$Aggregate;Lcom/google/common/collect/TreeMultiset$AvlNode;)J move-result-wide p1 goto :goto_0 .end method .method private aggregateForEntries(Lcom/google/common/collect/TreeMultiset$Aggregate;)J .locals 5 .line 1 iget-object v0, p0, Lcom/google/common/collect/TreeMultiset;->rootReference:Lcom/google/common/collect/TreeMultiset$Reference; invoke-virtual {v0}, Lcom/google/common/collect/TreeMultiset$Reference;->get()Ljava/lang/Object; move-result-object v0 check-cast v0, Lcom/google/common/collect/TreeMultiset$AvlNode; .line 2 invoke-virtual {p1, v0}, Lcom/google/common/collect/TreeMultiset$Aggregate;->treeAggregate(Lcom/google/common/collect/TreeMultiset$AvlNode;)J move-result-wide v1 .line 3 iget-object v3, p0, Lcom/google/common/collect/TreeMultiset;->range:Lcom/google/common/collect/GeneralRange; invoke-virtual {v3}, Lcom/google/common/collect/GeneralRange;->hasLowerBound()Z move-result v3 if-eqz v3, :cond_0 .line 4 invoke-direct {p0, p1, v0}, Lcom/google/common/collect/TreeMultiset;->aggregateBelowRange(Lcom/google/common/collect/TreeMultiset$Aggregate;Lcom/google/common/collect/TreeMultiset$AvlNode;)J move-result-wide v3 sub-long/2addr v1, v3 .line 5 :cond_0 iget-object v3, p0, Lcom/google/common/collect/TreeMultiset;->range:Lcom/google/common/collect/GeneralRange; invoke-virtual {v3}, Lcom/google/common/collect/GeneralRange;->hasUpperBound()Z move-result v3 if-eqz v3, :cond_1 .line 6 invoke-direct {p0, p1, v0}, Lcom/google/common/collect/TreeMultiset;->aggregateAboveRange(Lcom/google/common/collect/TreeMultiset$Aggregate;Lcom/google/common/collect/TreeMultiset$AvlNode;)J move-result-wide v3 sub-long/2addr v1, v3 :cond_1 return-wide v1 .end method .method public static create()Lcom/google/common/collect/TreeMultiset; .locals 2 .annotation system Ldalvik/annotation/Signature; value = { "()", "Lcom/google/common/collect/TreeMultiset<", "TE;>;" } .end annotation .line 1 new-instance v0, Lcom/google/common/collect/TreeMultiset; invoke-static {}, Lcom/google/common/collect/Ordering;->natural()Lcom/google/common/collect/Ordering; move-result-object v1 invoke-direct {v0, v1}, Lcom/google/common/collect/TreeMultiset;->(Ljava/util/Comparator;)V return-object v0 .end method .method public static create(Ljava/lang/Iterable;)Lcom/google/common/collect/TreeMultiset; .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "(", "Ljava/lang/Iterable<", "+TE;>;)", "Lcom/google/common/collect/TreeMultiset<", "TE;>;" } .end annotation .line 4 invoke-static {}, Lcom/google/common/collect/TreeMultiset;->create()Lcom/google/common/collect/TreeMultiset; move-result-object v0 .line 5 invoke-static {v0, p0}, Lcom/google/common/collect/Iterables;->addAll(Ljava/util/Collection;Ljava/lang/Iterable;)Z return-object v0 .end method .method public static create(Ljava/util/Comparator;)Lcom/google/common/collect/TreeMultiset; .locals 1 .param p0 # Ljava/util/Comparator; .annotation runtime Ljavax/annotation/CheckForNull; .end annotation .end param .annotation system Ldalvik/annotation/Signature; value = { "(", "Ljava/util/Comparator<", "-TE;>;)", "Lcom/google/common/collect/TreeMultiset<", "TE;>;" } .end annotation if-nez p0, :cond_0 .line 2 new-instance p0, Lcom/google/common/collect/TreeMultiset; invoke-static {}, Lcom/google/common/collect/Ordering;->natural()Lcom/google/common/collect/Ordering; move-result-object v0 invoke-direct {p0, v0}, Lcom/google/common/collect/TreeMultiset;->(Ljava/util/Comparator;)V goto :goto_0 .line 3 :cond_0 new-instance v0, Lcom/google/common/collect/TreeMultiset; invoke-direct {v0, p0}, Lcom/google/common/collect/TreeMultiset;->(Ljava/util/Comparator;)V move-object p0, v0 :goto_0 return-object p0 .end method .method public static distinctElements(Lcom/google/common/collect/TreeMultiset$AvlNode;)I .locals 0 .param p0 # Lcom/google/common/collect/TreeMultiset$AvlNode; .annotation runtime Ljavax/annotation/CheckForNull; .end annotation .end param .annotation system Ldalvik/annotation/Signature; value = { "(", "Lcom/google/common/collect/TreeMultiset$AvlNode<", "*>;)I" } .end annotation if-nez p0, :cond_0 const/4 p0, 0x0 goto :goto_0 .line 2 :cond_0 invoke-static {p0}, Lcom/google/common/collect/TreeMultiset$AvlNode;->access$400(Lcom/google/common/collect/TreeMultiset$AvlNode;)I move-result p0 :goto_0 return p0 .end method .method private firstNode()Lcom/google/common/collect/TreeMultiset$AvlNode; .locals 5 .annotation system Ldalvik/annotation/Signature; value = { "()", "Lcom/google/common/collect/TreeMultiset$AvlNode<", "TE;>;" } .end annotation .annotation runtime Ljavax/annotation/CheckForNull; .end annotation .line 1 iget-object v0, p0, Lcom/google/common/collect/TreeMultiset;->rootReference:Lcom/google/common/collect/TreeMultiset$Reference; invoke-virtual {v0}, Lcom/google/common/collect/TreeMultiset$Reference;->get()Ljava/lang/Object; move-result-object v0 check-cast v0, Lcom/google/common/collect/TreeMultiset$AvlNode; const/4 v1, 0x0 if-nez v0, :cond_0 return-object v1 .line 2 :cond_0 iget-object v2, p0, Lcom/google/common/collect/TreeMultiset;->range:Lcom/google/common/collect/GeneralRange; invoke-virtual {v2}, Lcom/google/common/collect/GeneralRange;->hasLowerBound()Z move-result v2 if-eqz v2, :cond_2 .line 3 iget-object v2, p0, Lcom/google/common/collect/TreeMultiset;->range:Lcom/google/common/collect/GeneralRange; invoke-virtual {v2}, Lcom/google/common/collect/GeneralRange;->getLowerEndpoint()Ljava/lang/Object; move-result-object v2 invoke-static {v2}, Lcom/google/common/collect/NullnessCasts;->uncheckedCastNullableTToT(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v2 .line 4 invoke-virtual {p0}, Lcom/google/common/collect/TreeMultiset;->comparator()Ljava/util/Comparator; move-result-object v3 invoke-static {v0, v3, v2}, Lcom/google/common/collect/TreeMultiset$AvlNode;->access$1000(Lcom/google/common/collect/TreeMultiset$AvlNode;Ljava/util/Comparator;Ljava/lang/Object;)Lcom/google/common/collect/TreeMultiset$AvlNode; move-result-object v0 if-nez v0, :cond_1 return-object v1 .line 5 :cond_1 iget-object v3, p0, Lcom/google/common/collect/TreeMultiset;->range:Lcom/google/common/collect/GeneralRange; invoke-virtual {v3}, Lcom/google/common/collect/GeneralRange;->getLowerBoundType()Lcom/google/common/collect/BoundType; move-result-object v3 sget-object v4, Lcom/google/common/collect/BoundType;->OPEN:Lcom/google/common/collect/BoundType; if-ne v3, v4, :cond_3 .line 6 invoke-virtual {p0}, Lcom/google/common/collect/TreeMultiset;->comparator()Ljava/util/Comparator; move-result-object v3 invoke-virtual {v0}, Lcom/google/common/collect/TreeMultiset$AvlNode;->getElement()Ljava/lang/Object; move-result-object v4 invoke-interface {v3, v2, v4}, Ljava/util/Comparator;->compare(Ljava/lang/Object;Ljava/lang/Object;)I move-result v2 if-nez v2, :cond_3 .line 7 invoke-static {v0}, Lcom/google/common/collect/TreeMultiset$AvlNode;->access$700(Lcom/google/common/collect/TreeMultiset$AvlNode;)Lcom/google/common/collect/TreeMultiset$AvlNode; move-result-object v0 goto :goto_0 .line 8 :cond_2 iget-object v0, p0, Lcom/google/common/collect/TreeMultiset;->header:Lcom/google/common/collect/TreeMultiset$AvlNode; invoke-static {v0}, Lcom/google/common/collect/TreeMultiset$AvlNode;->access$700(Lcom/google/common/collect/TreeMultiset$AvlNode;)Lcom/google/common/collect/TreeMultiset$AvlNode; move-result-object v0 .line 9 :cond_3 :goto_0 iget-object v2, p0, Lcom/google/common/collect/TreeMultiset;->header:Lcom/google/common/collect/TreeMultiset$AvlNode; if-eq v0, v2, :cond_5 iget-object v2, p0, Lcom/google/common/collect/TreeMultiset;->range:Lcom/google/common/collect/GeneralRange; invoke-virtual {v0}, Lcom/google/common/collect/TreeMultiset$AvlNode;->getElement()Ljava/lang/Object; move-result-object v3 invoke-virtual {v2, v3}, Lcom/google/common/collect/GeneralRange;->contains(Ljava/lang/Object;)Z move-result v2 if-nez v2, :cond_4 goto :goto_1 :cond_4 move-object v1, v0 :cond_5 :goto_1 return-object v1 .end method .method private lastNode()Lcom/google/common/collect/TreeMultiset$AvlNode; .locals 5 .annotation system Ldalvik/annotation/Signature; value = { "()", "Lcom/google/common/collect/TreeMultiset$AvlNode<", "TE;>;" } .end annotation .annotation runtime Ljavax/annotation/CheckForNull; .end annotation .line 1 iget-object v0, p0, Lcom/google/common/collect/TreeMultiset;->rootReference:Lcom/google/common/collect/TreeMultiset$Reference; invoke-virtual {v0}, Lcom/google/common/collect/TreeMultiset$Reference;->get()Ljava/lang/Object; move-result-object v0 check-cast v0, Lcom/google/common/collect/TreeMultiset$AvlNode; const/4 v1, 0x0 if-nez v0, :cond_0 return-object v1 .line 2 :cond_0 iget-object v2, p0, Lcom/google/common/collect/TreeMultiset;->range:Lcom/google/common/collect/GeneralRange; invoke-virtual {v2}, Lcom/google/common/collect/GeneralRange;->hasUpperBound()Z move-result v2 if-eqz v2, :cond_2 .line 3 iget-object v2, p0, Lcom/google/common/collect/TreeMultiset;->range:Lcom/google/common/collect/GeneralRange; invoke-virtual {v2}, Lcom/google/common/collect/GeneralRange;->getUpperEndpoint()Ljava/lang/Object; move-result-object v2 invoke-static {v2}, Lcom/google/common/collect/NullnessCasts;->uncheckedCastNullableTToT(Ljava/lang/Object;)Ljava/lang/Object; move-result-object v2 .line 4 invoke-virtual {p0}, Lcom/google/common/collect/TreeMultiset;->comparator()Ljava/util/Comparator; move-result-object v3 invoke-static {v0, v3, v2}, Lcom/google/common/collect/TreeMultiset$AvlNode;->access$1100(Lcom/google/common/collect/TreeMultiset$AvlNode;Ljava/util/Comparator;Ljava/lang/Object;)Lcom/google/common/collect/TreeMultiset$AvlNode; move-result-object v0 if-nez v0, :cond_1 return-object v1 .line 5 :cond_1 iget-object v3, p0, Lcom/google/common/collect/TreeMultiset;->range:Lcom/google/common/collect/GeneralRange; invoke-virtual {v3}, Lcom/google/common/collect/GeneralRange;->getUpperBoundType()Lcom/google/common/collect/BoundType; move-result-object v3 sget-object v4, Lcom/google/common/collect/BoundType;->OPEN:Lcom/google/common/collect/BoundType; if-ne v3, v4, :cond_3 .line 6 invoke-virtual {p0}, Lcom/google/common/collect/TreeMultiset;->comparator()Ljava/util/Comparator; move-result-object v3 invoke-virtual {v0}, Lcom/google/common/collect/TreeMultiset$AvlNode;->getElement()Ljava/lang/Object; move-result-object v4 invoke-interface {v3, v2, v4}, Ljava/util/Comparator;->compare(Ljava/lang/Object;Ljava/lang/Object;)I move-result v2 if-nez v2, :cond_3 .line 7 invoke-static {v0}, Lcom/google/common/collect/TreeMultiset$AvlNode;->access$1200(Lcom/google/common/collect/TreeMultiset$AvlNode;)Lcom/google/common/collect/TreeMultiset$AvlNode; move-result-object v0 goto :goto_0 .line 8 :cond_2 iget-object v0, p0, Lcom/google/common/collect/TreeMultiset;->header:Lcom/google/common/collect/TreeMultiset$AvlNode; invoke-static {v0}, Lcom/google/common/collect/TreeMultiset$AvlNode;->access$1200(Lcom/google/common/collect/TreeMultiset$AvlNode;)Lcom/google/common/collect/TreeMultiset$AvlNode; move-result-object v0 .line 9 :cond_3 :goto_0 iget-object v2, p0, Lcom/google/common/collect/TreeMultiset;->header:Lcom/google/common/collect/TreeMultiset$AvlNode; if-eq v0, v2, :cond_5 iget-object v2, p0, Lcom/google/common/collect/TreeMultiset;->range:Lcom/google/common/collect/GeneralRange; invoke-virtual {v0}, Lcom/google/common/collect/TreeMultiset$AvlNode;->getElement()Ljava/lang/Object; move-result-object v3 invoke-virtual {v2, v3}, Lcom/google/common/collect/GeneralRange;->contains(Ljava/lang/Object;)Z move-result v2 if-nez v2, :cond_4 goto :goto_1 :cond_4 move-object v1, v0 :cond_5 :goto_1 return-object v1 .end method .method private readObject(Ljava/io/ObjectInputStream;)V .locals 3 .annotation build Lcom/google/common/annotations/GwtIncompatible; .end annotation .annotation system Ldalvik/annotation/Throws; value = { Ljava/io/IOException;, Ljava/lang/ClassNotFoundException; } .end annotation .line 1 invoke-virtual {p1}, Ljava/io/ObjectInputStream;->defaultReadObject()V .line 2 invoke-virtual {p1}, Ljava/io/ObjectInputStream;->readObject()Ljava/lang/Object; move-result-object v0 check-cast v0, Ljava/util/Comparator; .line 3 const-class v1, Lcom/google/common/collect/AbstractSortedMultiset; const-string v2, "comparator" invoke-static {v1, v2}, Lcom/google/common/collect/Serialization;->getFieldSetter(Ljava/lang/Class;Ljava/lang/String;)Lcom/google/common/collect/Serialization$FieldSetter; move-result-object v1 invoke-virtual {v1, p0, v0}, Lcom/google/common/collect/Serialization$FieldSetter;->set(Ljava/lang/Object;Ljava/lang/Object;)V .line 4 const-class v1, Lcom/google/common/collect/TreeMultiset; const-string v2, "range" invoke-static {v1, v2}, Lcom/google/common/collect/Serialization;->getFieldSetter(Ljava/lang/Class;Ljava/lang/String;)Lcom/google/common/collect/Serialization$FieldSetter; move-result-object v1 .line 5 invoke-static {v0}, Lcom/google/common/collect/GeneralRange;->all(Ljava/util/Comparator;)Lcom/google/common/collect/GeneralRange; move-result-object v0 invoke-virtual {v1, p0, v0}, Lcom/google/common/collect/Serialization$FieldSetter;->set(Ljava/lang/Object;Ljava/lang/Object;)V .line 6 const-class v0, Lcom/google/common/collect/TreeMultiset; const-string v1, "rootReference" invoke-static {v0, v1}, Lcom/google/common/collect/Serialization;->getFieldSetter(Ljava/lang/Class;Ljava/lang/String;)Lcom/google/common/collect/Serialization$FieldSetter; move-result-object v0 new-instance v1, Lcom/google/common/collect/TreeMultiset$Reference; const/4 v2, 0x0 invoke-direct {v1, v2}, Lcom/google/common/collect/TreeMultiset$Reference;->(Lcom/google/common/collect/TreeMultiset$1;)V .line 7 invoke-virtual {v0, p0, v1}, Lcom/google/common/collect/Serialization$FieldSetter;->set(Ljava/lang/Object;Ljava/lang/Object;)V .line 8 new-instance v0, Lcom/google/common/collect/TreeMultiset$AvlNode; invoke-direct {v0}, Lcom/google/common/collect/TreeMultiset$AvlNode;->()V .line 9 const-class v1, Lcom/google/common/collect/TreeMultiset; const-string v2, "header" invoke-static {v1, v2}, Lcom/google/common/collect/Serialization;->getFieldSetter(Ljava/lang/Class;Ljava/lang/String;)Lcom/google/common/collect/Serialization$FieldSetter; move-result-object v1 invoke-virtual {v1, p0, v0}, Lcom/google/common/collect/Serialization$FieldSetter;->set(Ljava/lang/Object;Ljava/lang/Object;)V .line 10 invoke-static {v0, v0}, Lcom/google/common/collect/TreeMultiset;->successor(Lcom/google/common/collect/TreeMultiset$AvlNode;Lcom/google/common/collect/TreeMultiset$AvlNode;)V .line 11 invoke-static {p0, p1}, Lcom/google/common/collect/Serialization;->populateMultiset(Lcom/google/common/collect/Multiset;Ljava/io/ObjectInputStream;)V return-void .end method .method private static successor(Lcom/google/common/collect/TreeMultiset$AvlNode;Lcom/google/common/collect/TreeMultiset$AvlNode;)V .locals 0 .annotation system Ldalvik/annotation/Signature; value = { "(", "Lcom/google/common/collect/TreeMultiset$AvlNode<", "TT;>;", "Lcom/google/common/collect/TreeMultiset$AvlNode<", "TT;>;)V" } .end annotation .line 1 invoke-static {p0, p1}, Lcom/google/common/collect/TreeMultiset$AvlNode;->access$902(Lcom/google/common/collect/TreeMultiset$AvlNode;Lcom/google/common/collect/TreeMultiset$AvlNode;)Lcom/google/common/collect/TreeMultiset$AvlNode; .line 2 invoke-static {p1, p0}, Lcom/google/common/collect/TreeMultiset$AvlNode;->access$802(Lcom/google/common/collect/TreeMultiset$AvlNode;Lcom/google/common/collect/TreeMultiset$AvlNode;)Lcom/google/common/collect/TreeMultiset$AvlNode; return-void .end method .method private static successor(Lcom/google/common/collect/TreeMultiset$AvlNode;Lcom/google/common/collect/TreeMultiset$AvlNode;Lcom/google/common/collect/TreeMultiset$AvlNode;)V .locals 0 .annotation system Ldalvik/annotation/Signature; value = { "(", "Lcom/google/common/collect/TreeMultiset$AvlNode<", "TT;>;", "Lcom/google/common/collect/TreeMultiset$AvlNode<", "TT;>;", "Lcom/google/common/collect/TreeMultiset$AvlNode<", "TT;>;)V" } .end annotation .line 3 invoke-static {p0, p1}, Lcom/google/common/collect/TreeMultiset;->successor(Lcom/google/common/collect/TreeMultiset$AvlNode;Lcom/google/common/collect/TreeMultiset$AvlNode;)V .line 4 invoke-static {p1, p2}, Lcom/google/common/collect/TreeMultiset;->successor(Lcom/google/common/collect/TreeMultiset$AvlNode;Lcom/google/common/collect/TreeMultiset$AvlNode;)V return-void .end method .method private wrapEntry(Lcom/google/common/collect/TreeMultiset$AvlNode;)Lcom/google/common/collect/Multiset$Entry; .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "(", "Lcom/google/common/collect/TreeMultiset$AvlNode<", "TE;>;)", "Lcom/google/common/collect/Multiset$Entry<", "TE;>;" } .end annotation .line 1 new-instance v0, Lcom/google/common/collect/TreeMultiset$1; invoke-direct {v0, p0, p1}, Lcom/google/common/collect/TreeMultiset$1;->(Lcom/google/common/collect/TreeMultiset;Lcom/google/common/collect/TreeMultiset$AvlNode;)V return-object v0 .end method .method private writeObject(Ljava/io/ObjectOutputStream;)V .locals 1 .annotation build Lcom/google/common/annotations/GwtIncompatible; .end annotation .annotation system Ldalvik/annotation/Throws; value = { Ljava/io/IOException; } .end annotation .line 1 invoke-virtual {p1}, Ljava/io/ObjectOutputStream;->defaultWriteObject()V .line 2 invoke-virtual {p0}, Lcom/google/common/collect/TreeMultiset;->elementSet()Ljava/util/NavigableSet; move-result-object v0 invoke-interface {v0}, Ljava/util/NavigableSet;->comparator()Ljava/util/Comparator; move-result-object v0 invoke-virtual {p1, v0}, Ljava/io/ObjectOutputStream;->writeObject(Ljava/lang/Object;)V .line 3 invoke-static {p0, p1}, Lcom/google/common/collect/Serialization;->writeMultiset(Lcom/google/common/collect/Multiset;Ljava/io/ObjectOutputStream;)V return-void .end method # virtual methods .method public add(Ljava/lang/Object;I)I .locals 4 .param p1 # Ljava/lang/Object; .annotation runtime Lcom/google/common/collect/ParametricNullness; .end annotation .end param .annotation build Lcom/google/errorprone/annotations/CanIgnoreReturnValue; .end annotation .annotation system Ldalvik/annotation/Signature; value = { "(TE;I)I" } .end annotation const-string v0, "occurrences" .line 1 invoke-static {p2, v0}, Lcom/google/common/collect/CollectPreconditions;->checkNonnegative(ILjava/lang/String;)I if-nez p2, :cond_0 .line 2 invoke-virtual {p0, p1}, Lcom/google/common/collect/TreeMultiset;->count(Ljava/lang/Object;)I move-result p1 return p1 .line 3 :cond_0 iget-object v0, p0, Lcom/google/common/collect/TreeMultiset;->range:Lcom/google/common/collect/GeneralRange; invoke-virtual {v0, p1}, Lcom/google/common/collect/GeneralRange;->contains(Ljava/lang/Object;)Z move-result v0 invoke-static {v0}, Lcom/google/common/base/Preconditions;->checkArgument(Z)V .line 4 iget-object v0, p0, Lcom/google/common/collect/TreeMultiset;->rootReference:Lcom/google/common/collect/TreeMultiset$Reference; invoke-virtual {v0}, Lcom/google/common/collect/TreeMultiset$Reference;->get()Ljava/lang/Object; move-result-object v0 check-cast v0, Lcom/google/common/collect/TreeMultiset$AvlNode; const/4 v1, 0x0 if-nez v0, :cond_1 .line 5 invoke-virtual {p0}, Lcom/google/common/collect/TreeMultiset;->comparator()Ljava/util/Comparator; move-result-object v2 invoke-interface {v2, p1, p1}, Ljava/util/Comparator;->compare(Ljava/lang/Object;Ljava/lang/Object;)I .line 6 new-instance v2, Lcom/google/common/collect/TreeMultiset$AvlNode; invoke-direct {v2, p1, p2}, Lcom/google/common/collect/TreeMultiset$AvlNode;->(Ljava/lang/Object;I)V .line 7 iget-object p1, p0, Lcom/google/common/collect/TreeMultiset;->header:Lcom/google/common/collect/TreeMultiset$AvlNode; invoke-static {p1, v2, p1}, Lcom/google/common/collect/TreeMultiset;->successor(Lcom/google/common/collect/TreeMultiset$AvlNode;Lcom/google/common/collect/TreeMultiset$AvlNode;Lcom/google/common/collect/TreeMultiset$AvlNode;)V .line 8 iget-object p1, p0, Lcom/google/common/collect/TreeMultiset;->rootReference:Lcom/google/common/collect/TreeMultiset$Reference; invoke-virtual {p1, v0, v2}, Lcom/google/common/collect/TreeMultiset$Reference;->checkAndSet(Ljava/lang/Object;Ljava/lang/Object;)V return v1 :cond_1 const/4 v2, 0x1 new-array v2, v2, [I .line 9 invoke-virtual {p0}, Lcom/google/common/collect/TreeMultiset;->comparator()Ljava/util/Comparator; move-result-object v3 invoke-virtual {v0, v3, p1, p2, v2}, Lcom/google/common/collect/TreeMultiset$AvlNode;->add(Ljava/util/Comparator;Ljava/lang/Object;I[I)Lcom/google/common/collect/TreeMultiset$AvlNode; move-result-object p1 .line 10 iget-object p2, p0, Lcom/google/common/collect/TreeMultiset;->rootReference:Lcom/google/common/collect/TreeMultiset$Reference; invoke-virtual {p2, v0, p1}, Lcom/google/common/collect/TreeMultiset$Reference;->checkAndSet(Ljava/lang/Object;Ljava/lang/Object;)V .line 11 aget p1, v2, v1 return p1 .end method .method public clear()V .locals 3 .line 1 iget-object v0, p0, Lcom/google/common/collect/TreeMultiset;->range:Lcom/google/common/collect/GeneralRange; invoke-virtual {v0}, Lcom/google/common/collect/GeneralRange;->hasLowerBound()Z move-result v0 if-nez v0, :cond_1 iget-object v0, p0, Lcom/google/common/collect/TreeMultiset;->range:Lcom/google/common/collect/GeneralRange; invoke-virtual {v0}, Lcom/google/common/collect/GeneralRange;->hasUpperBound()Z move-result v0 if-nez v0, :cond_1 .line 2 iget-object v0, p0, Lcom/google/common/collect/TreeMultiset;->header:Lcom/google/common/collect/TreeMultiset$AvlNode; invoke-static {v0}, Lcom/google/common/collect/TreeMultiset$AvlNode;->access$700(Lcom/google/common/collect/TreeMultiset$AvlNode;)Lcom/google/common/collect/TreeMultiset$AvlNode; move-result-object v0 :goto_0 iget-object v1, p0, Lcom/google/common/collect/TreeMultiset;->header:Lcom/google/common/collect/TreeMultiset$AvlNode; if-eq v0, v1, :cond_0 .line 3 invoke-static {v0}, Lcom/google/common/collect/TreeMultiset$AvlNode;->access$700(Lcom/google/common/collect/TreeMultiset$AvlNode;)Lcom/google/common/collect/TreeMultiset$AvlNode; move-result-object v1 const/4 v2, 0x0 .line 4 invoke-static {v0, v2}, Lcom/google/common/collect/TreeMultiset$AvlNode;->access$202(Lcom/google/common/collect/TreeMultiset$AvlNode;I)I const/4 v2, 0x0 .line 5 invoke-static {v0, v2}, Lcom/google/common/collect/TreeMultiset$AvlNode;->access$502(Lcom/google/common/collect/TreeMultiset$AvlNode;Lcom/google/common/collect/TreeMultiset$AvlNode;)Lcom/google/common/collect/TreeMultiset$AvlNode; .line 6 invoke-static {v0, v2}, Lcom/google/common/collect/TreeMultiset$AvlNode;->access$602(Lcom/google/common/collect/TreeMultiset$AvlNode;Lcom/google/common/collect/TreeMultiset$AvlNode;)Lcom/google/common/collect/TreeMultiset$AvlNode; .line 7 invoke-static {v0, v2}, Lcom/google/common/collect/TreeMultiset$AvlNode;->access$802(Lcom/google/common/collect/TreeMultiset$AvlNode;Lcom/google/common/collect/TreeMultiset$AvlNode;)Lcom/google/common/collect/TreeMultiset$AvlNode; .line 8 invoke-static {v0, v2}, Lcom/google/common/collect/TreeMultiset$AvlNode;->access$902(Lcom/google/common/collect/TreeMultiset$AvlNode;Lcom/google/common/collect/TreeMultiset$AvlNode;)Lcom/google/common/collect/TreeMultiset$AvlNode; move-object v0, v1 goto :goto_0 .line 9 :cond_0 invoke-static {v1, v1}, Lcom/google/common/collect/TreeMultiset;->successor(Lcom/google/common/collect/TreeMultiset$AvlNode;Lcom/google/common/collect/TreeMultiset$AvlNode;)V .line 10 iget-object v0, p0, Lcom/google/common/collect/TreeMultiset;->rootReference:Lcom/google/common/collect/TreeMultiset$Reference; invoke-virtual {v0}, Lcom/google/common/collect/TreeMultiset$Reference;->clear()V goto :goto_1 .line 11 :cond_1 invoke-virtual {p0}, Lcom/google/common/collect/TreeMultiset;->entryIterator()Ljava/util/Iterator; move-result-object v0 invoke-static {v0}, Lcom/google/common/collect/Iterators;->clear(Ljava/util/Iterator;)V :goto_1 return-void .end method .method public bridge synthetic comparator()Ljava/util/Comparator; .locals 1 .line 1 invoke-super {p0}, Lcom/google/common/collect/AbstractSortedMultiset;->comparator()Ljava/util/Comparator; move-result-object v0 return-object v0 .end method .method public bridge synthetic contains(Ljava/lang/Object;)Z .locals 0 .param p1 # Ljava/lang/Object; .annotation runtime Ljavax/annotation/CheckForNull; .end annotation .end param .line 1 invoke-super {p0, p1}, Lcom/google/common/collect/AbstractMultiset;->contains(Ljava/lang/Object;)Z move-result p1 return p1 .end method .method public count(Ljava/lang/Object;)I .locals 3 .param p1 # Ljava/lang/Object; .annotation runtime Ljavax/annotation/CheckForNull; .end annotation .end param const/4 v0, 0x0 .line 1 :try_start_0 iget-object v1, p0, Lcom/google/common/collect/TreeMultiset;->rootReference:Lcom/google/common/collect/TreeMultiset$Reference; invoke-virtual {v1}, Lcom/google/common/collect/TreeMultiset$Reference;->get()Ljava/lang/Object; move-result-object v1 check-cast v1, Lcom/google/common/collect/TreeMultiset$AvlNode; .line 2 iget-object v2, p0, Lcom/google/common/collect/TreeMultiset;->range:Lcom/google/common/collect/GeneralRange; invoke-virtual {v2, p1}, Lcom/google/common/collect/GeneralRange;->contains(Ljava/lang/Object;)Z move-result v2 if-eqz v2, :cond_1 if-nez v1, :cond_0 goto :goto_0 .line 3 :cond_0 invoke-virtual {p0}, Lcom/google/common/collect/TreeMultiset;->comparator()Ljava/util/Comparator; move-result-object v2 invoke-virtual {v1, v2, p1}, Lcom/google/common/collect/TreeMultiset$AvlNode;->count(Ljava/util/Comparator;Ljava/lang/Object;)I move-result p1 :try_end_0 .catch Ljava/lang/ClassCastException; {:try_start_0 .. :try_end_0} :catch_0 .catch Ljava/lang/NullPointerException; {:try_start_0 .. :try_end_0} :catch_0 return p1 :catch_0 :cond_1 :goto_0 return v0 .end method .method public descendingEntryIterator()Ljava/util/Iterator; .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "()", "Ljava/util/Iterator<", "Lcom/google/common/collect/Multiset$Entry<", "TE;>;>;" } .end annotation .line 1 new-instance v0, Lcom/google/common/collect/TreeMultiset$3; invoke-direct {v0, p0}, Lcom/google/common/collect/TreeMultiset$3;->(Lcom/google/common/collect/TreeMultiset;)V return-object v0 .end method .method public bridge synthetic descendingMultiset()Lcom/google/common/collect/SortedMultiset; .locals 1 .line 1 invoke-super {p0}, Lcom/google/common/collect/AbstractSortedMultiset;->descendingMultiset()Lcom/google/common/collect/SortedMultiset; move-result-object v0 return-object v0 .end method .method public distinctElements()I .locals 2 .line 1 sget-object v0, Lcom/google/common/collect/TreeMultiset$Aggregate;->DISTINCT:Lcom/google/common/collect/TreeMultiset$Aggregate; invoke-direct {p0, v0}, Lcom/google/common/collect/TreeMultiset;->aggregateForEntries(Lcom/google/common/collect/TreeMultiset$Aggregate;)J move-result-wide v0 invoke-static {v0, v1}, Lcom/google/common/primitives/Ints;->saturatedCast(J)I move-result v0 return v0 .end method .method public elementIterator()Ljava/util/Iterator; .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "()", "Ljava/util/Iterator<", "TE;>;" } .end annotation .line 1 invoke-virtual {p0}, Lcom/google/common/collect/TreeMultiset;->entryIterator()Ljava/util/Iterator; move-result-object v0 invoke-static {v0}, Lcom/google/common/collect/Multisets;->elementIterator(Ljava/util/Iterator;)Ljava/util/Iterator; move-result-object v0 return-object v0 .end method .method public bridge synthetic elementSet()Ljava/util/NavigableSet; .locals 1 .line 1 invoke-super {p0}, Lcom/google/common/collect/AbstractSortedMultiset;->elementSet()Ljava/util/NavigableSet; move-result-object v0 return-object v0 .end method .method public entryIterator()Ljava/util/Iterator; .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "()", "Ljava/util/Iterator<", "Lcom/google/common/collect/Multiset$Entry<", "TE;>;>;" } .end annotation .line 1 new-instance v0, Lcom/google/common/collect/TreeMultiset$2; invoke-direct {v0, p0}, Lcom/google/common/collect/TreeMultiset$2;->(Lcom/google/common/collect/TreeMultiset;)V return-object v0 .end method .method public bridge synthetic entrySet()Ljava/util/Set; .locals 1 .line 1 invoke-super {p0}, Lcom/google/common/collect/AbstractMultiset;->entrySet()Ljava/util/Set; move-result-object v0 return-object v0 .end method .method public bridge synthetic firstEntry()Lcom/google/common/collect/Multiset$Entry; .locals 1 .annotation runtime Ljavax/annotation/CheckForNull; .end annotation .line 1 invoke-super {p0}, Lcom/google/common/collect/AbstractSortedMultiset;->firstEntry()Lcom/google/common/collect/Multiset$Entry; move-result-object v0 return-object v0 .end method .method public headMultiset(Ljava/lang/Object;Lcom/google/common/collect/BoundType;)Lcom/google/common/collect/SortedMultiset; .locals 4 .param p1 # Ljava/lang/Object; .annotation runtime Lcom/google/common/collect/ParametricNullness; .end annotation .end param .annotation system Ldalvik/annotation/Signature; value = { "(TE;", "Lcom/google/common/collect/BoundType;", ")", "Lcom/google/common/collect/SortedMultiset<", "TE;>;" } .end annotation .line 1 new-instance v0, Lcom/google/common/collect/TreeMultiset; iget-object v1, p0, Lcom/google/common/collect/TreeMultiset;->rootReference:Lcom/google/common/collect/TreeMultiset$Reference; iget-object v2, p0, Lcom/google/common/collect/TreeMultiset;->range:Lcom/google/common/collect/GeneralRange; .line 2 invoke-virtual {p0}, Lcom/google/common/collect/TreeMultiset;->comparator()Ljava/util/Comparator; move-result-object v3 invoke-static {v3, p1, p2}, Lcom/google/common/collect/GeneralRange;->upTo(Ljava/util/Comparator;Ljava/lang/Object;Lcom/google/common/collect/BoundType;)Lcom/google/common/collect/GeneralRange; move-result-object p1 invoke-virtual {v2, p1}, Lcom/google/common/collect/GeneralRange;->intersect(Lcom/google/common/collect/GeneralRange;)Lcom/google/common/collect/GeneralRange; move-result-object p1 iget-object p2, p0, Lcom/google/common/collect/TreeMultiset;->header:Lcom/google/common/collect/TreeMultiset$AvlNode; invoke-direct {v0, v1, p1, p2}, Lcom/google/common/collect/TreeMultiset;->(Lcom/google/common/collect/TreeMultiset$Reference;Lcom/google/common/collect/GeneralRange;Lcom/google/common/collect/TreeMultiset$AvlNode;)V return-object v0 .end method .method public bridge synthetic isEmpty()Z .locals 1 .line 1 invoke-super {p0}, Lcom/google/common/collect/AbstractMultiset;->isEmpty()Z move-result v0 return v0 .end method .method public iterator()Ljava/util/Iterator; .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "()", "Ljava/util/Iterator<", "TE;>;" } .end annotation .line 1 invoke-static {p0}, Lcom/google/common/collect/Multisets;->iteratorImpl(Lcom/google/common/collect/Multiset;)Ljava/util/Iterator; move-result-object v0 return-object v0 .end method .method public bridge synthetic lastEntry()Lcom/google/common/collect/Multiset$Entry; .locals 1 .annotation runtime Ljavax/annotation/CheckForNull; .end annotation .line 1 invoke-super {p0}, Lcom/google/common/collect/AbstractSortedMultiset;->lastEntry()Lcom/google/common/collect/Multiset$Entry; move-result-object v0 return-object v0 .end method .method public bridge synthetic pollFirstEntry()Lcom/google/common/collect/Multiset$Entry; .locals 1 .annotation runtime Ljavax/annotation/CheckForNull; .end annotation .line 1 invoke-super {p0}, Lcom/google/common/collect/AbstractSortedMultiset;->pollFirstEntry()Lcom/google/common/collect/Multiset$Entry; move-result-object v0 return-object v0 .end method .method public bridge synthetic pollLastEntry()Lcom/google/common/collect/Multiset$Entry; .locals 1 .annotation runtime Ljavax/annotation/CheckForNull; .end annotation .line 1 invoke-super {p0}, Lcom/google/common/collect/AbstractSortedMultiset;->pollLastEntry()Lcom/google/common/collect/Multiset$Entry; move-result-object v0 return-object v0 .end method .method public remove(Ljava/lang/Object;I)I .locals 4 .param p1 # Ljava/lang/Object; .annotation runtime Ljavax/annotation/CheckForNull; .end annotation .end param .annotation build Lcom/google/errorprone/annotations/CanIgnoreReturnValue; .end annotation const-string v0, "occurrences" .line 1 invoke-static {p2, v0}, Lcom/google/common/collect/CollectPreconditions;->checkNonnegative(ILjava/lang/String;)I if-nez p2, :cond_0 .line 2 invoke-virtual {p0, p1}, Lcom/google/common/collect/TreeMultiset;->count(Ljava/lang/Object;)I move-result p1 return p1 .line 3 :cond_0 iget-object v0, p0, Lcom/google/common/collect/TreeMultiset;->rootReference:Lcom/google/common/collect/TreeMultiset$Reference; invoke-virtual {v0}, Lcom/google/common/collect/TreeMultiset$Reference;->get()Ljava/lang/Object; move-result-object v0 check-cast v0, Lcom/google/common/collect/TreeMultiset$AvlNode; const/4 v1, 0x1 new-array v1, v1, [I const/4 v2, 0x0 .line 4 :try_start_0 iget-object v3, p0, Lcom/google/common/collect/TreeMultiset;->range:Lcom/google/common/collect/GeneralRange; invoke-virtual {v3, p1}, Lcom/google/common/collect/GeneralRange;->contains(Ljava/lang/Object;)Z move-result v3 if-eqz v3, :cond_2 if-nez v0, :cond_1 goto :goto_0 .line 5 :cond_1 invoke-virtual {p0}, Lcom/google/common/collect/TreeMultiset;->comparator()Ljava/util/Comparator; move-result-object v3 invoke-virtual {v0, v3, p1, p2, v1}, Lcom/google/common/collect/TreeMultiset$AvlNode;->remove(Ljava/util/Comparator;Ljava/lang/Object;I[I)Lcom/google/common/collect/TreeMultiset$AvlNode; move-result-object p1 :try_end_0 .catch Ljava/lang/ClassCastException; {:try_start_0 .. :try_end_0} :catch_0 .catch Ljava/lang/NullPointerException; {:try_start_0 .. :try_end_0} :catch_0 .line 6 iget-object p2, p0, Lcom/google/common/collect/TreeMultiset;->rootReference:Lcom/google/common/collect/TreeMultiset$Reference; invoke-virtual {p2, v0, p1}, Lcom/google/common/collect/TreeMultiset$Reference;->checkAndSet(Ljava/lang/Object;Ljava/lang/Object;)V .line 7 aget p1, v1, v2 return p1 :catch_0 :cond_2 :goto_0 return v2 .end method .method public setCount(Ljava/lang/Object;I)I .locals 4 .param p1 # Ljava/lang/Object; .annotation runtime Lcom/google/common/collect/ParametricNullness; .end annotation .end param .annotation build Lcom/google/errorprone/annotations/CanIgnoreReturnValue; .end annotation .annotation system Ldalvik/annotation/Signature; value = { "(TE;I)I" } .end annotation const-string v0, "count" .line 1 invoke-static {p2, v0}, Lcom/google/common/collect/CollectPreconditions;->checkNonnegative(ILjava/lang/String;)I .line 2 iget-object v0, p0, Lcom/google/common/collect/TreeMultiset;->range:Lcom/google/common/collect/GeneralRange; invoke-virtual {v0, p1}, Lcom/google/common/collect/GeneralRange;->contains(Ljava/lang/Object;)Z move-result v0 const/4 v1, 0x1 const/4 v2, 0x0 if-nez v0, :cond_1 if-nez p2, :cond_0 goto :goto_0 :cond_0 move v1, v2 .line 3 :goto_0 invoke-static {v1}, Lcom/google/common/base/Preconditions;->checkArgument(Z)V return v2 .line 4 :cond_1 iget-object v0, p0, Lcom/google/common/collect/TreeMultiset;->rootReference:Lcom/google/common/collect/TreeMultiset$Reference; invoke-virtual {v0}, Lcom/google/common/collect/TreeMultiset$Reference;->get()Ljava/lang/Object; move-result-object v0 check-cast v0, Lcom/google/common/collect/TreeMultiset$AvlNode; if-nez v0, :cond_3 if-lez p2, :cond_2 .line 5 invoke-virtual {p0, p1, p2}, Lcom/google/common/collect/TreeMultiset;->add(Ljava/lang/Object;I)I :cond_2 return v2 :cond_3 new-array v1, v1, [I .line 6 invoke-virtual {p0}, Lcom/google/common/collect/TreeMultiset;->comparator()Ljava/util/Comparator; move-result-object v3 invoke-virtual {v0, v3, p1, p2, v1}, Lcom/google/common/collect/TreeMultiset$AvlNode;->setCount(Ljava/util/Comparator;Ljava/lang/Object;I[I)Lcom/google/common/collect/TreeMultiset$AvlNode; move-result-object p1 .line 7 iget-object p2, p0, Lcom/google/common/collect/TreeMultiset;->rootReference:Lcom/google/common/collect/TreeMultiset$Reference; invoke-virtual {p2, v0, p1}, Lcom/google/common/collect/TreeMultiset$Reference;->checkAndSet(Ljava/lang/Object;Ljava/lang/Object;)V .line 8 aget p1, v1, v2 return p1 .end method .method public setCount(Ljava/lang/Object;II)Z .locals 10 .param p1 # Ljava/lang/Object; .annotation runtime Lcom/google/common/collect/ParametricNullness; .end annotation .end param .annotation build Lcom/google/errorprone/annotations/CanIgnoreReturnValue; .end annotation .annotation system Ldalvik/annotation/Signature; value = { "(TE;II)Z" } .end annotation const-string v0, "newCount" .line 9 invoke-static {p3, v0}, Lcom/google/common/collect/CollectPreconditions;->checkNonnegative(ILjava/lang/String;)I const-string v0, "oldCount" .line 10 invoke-static {p2, v0}, Lcom/google/common/collect/CollectPreconditions;->checkNonnegative(ILjava/lang/String;)I .line 11 iget-object v0, p0, Lcom/google/common/collect/TreeMultiset;->range:Lcom/google/common/collect/GeneralRange; invoke-virtual {v0, p1}, Lcom/google/common/collect/GeneralRange;->contains(Ljava/lang/Object;)Z move-result v0 invoke-static {v0}, Lcom/google/common/base/Preconditions;->checkArgument(Z)V .line 12 iget-object v0, p0, Lcom/google/common/collect/TreeMultiset;->rootReference:Lcom/google/common/collect/TreeMultiset$Reference; invoke-virtual {v0}, Lcom/google/common/collect/TreeMultiset$Reference;->get()Ljava/lang/Object; move-result-object v0 check-cast v0, Lcom/google/common/collect/TreeMultiset$AvlNode; const/4 v7, 0x0 const/4 v8, 0x1 if-nez v0, :cond_2 if-nez p2, :cond_1 if-lez p3, :cond_0 .line 13 invoke-virtual {p0, p1, p3}, Lcom/google/common/collect/TreeMultiset;->add(Ljava/lang/Object;I)I :cond_0 return v8 :cond_1 return v7 :cond_2 new-array v9, v8, [I .line 14 invoke-virtual {p0}, Lcom/google/common/collect/TreeMultiset;->comparator()Ljava/util/Comparator; move-result-object v2 move-object v1, v0 move-object v3, p1 move v4, p2 move v5, p3 move-object v6, v9 invoke-virtual/range {v1 .. v6}, Lcom/google/common/collect/TreeMultiset$AvlNode;->setCount(Ljava/util/Comparator;Ljava/lang/Object;II[I)Lcom/google/common/collect/TreeMultiset$AvlNode; move-result-object p1 .line 15 iget-object p3, p0, Lcom/google/common/collect/TreeMultiset;->rootReference:Lcom/google/common/collect/TreeMultiset$Reference; invoke-virtual {p3, v0, p1}, Lcom/google/common/collect/TreeMultiset$Reference;->checkAndSet(Ljava/lang/Object;Ljava/lang/Object;)V .line 16 aget p1, v9, v7 if-ne p1, p2, :cond_3 move v7, v8 :cond_3 return v7 .end method .method public size()I .locals 2 .line 1 sget-object v0, Lcom/google/common/collect/TreeMultiset$Aggregate;->SIZE:Lcom/google/common/collect/TreeMultiset$Aggregate; invoke-direct {p0, v0}, Lcom/google/common/collect/TreeMultiset;->aggregateForEntries(Lcom/google/common/collect/TreeMultiset$Aggregate;)J move-result-wide v0 invoke-static {v0, v1}, Lcom/google/common/primitives/Ints;->saturatedCast(J)I move-result v0 return v0 .end method .method public bridge synthetic subMultiset(Ljava/lang/Object;Lcom/google/common/collect/BoundType;Ljava/lang/Object;Lcom/google/common/collect/BoundType;)Lcom/google/common/collect/SortedMultiset; .locals 0 .param p1 # 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 .line 1 invoke-super {p0, p1, p2, p3, p4}, Lcom/google/common/collect/AbstractSortedMultiset;->subMultiset(Ljava/lang/Object;Lcom/google/common/collect/BoundType;Ljava/lang/Object;Lcom/google/common/collect/BoundType;)Lcom/google/common/collect/SortedMultiset; move-result-object p1 return-object p1 .end method .method public tailMultiset(Ljava/lang/Object;Lcom/google/common/collect/BoundType;)Lcom/google/common/collect/SortedMultiset; .locals 4 .param p1 # Ljava/lang/Object; .annotation runtime Lcom/google/common/collect/ParametricNullness; .end annotation .end param .annotation system Ldalvik/annotation/Signature; value = { "(TE;", "Lcom/google/common/collect/BoundType;", ")", "Lcom/google/common/collect/SortedMultiset<", "TE;>;" } .end annotation .line 1 new-instance v0, Lcom/google/common/collect/TreeMultiset; iget-object v1, p0, Lcom/google/common/collect/TreeMultiset;->rootReference:Lcom/google/common/collect/TreeMultiset$Reference; iget-object v2, p0, Lcom/google/common/collect/TreeMultiset;->range:Lcom/google/common/collect/GeneralRange; .line 2 invoke-virtual {p0}, Lcom/google/common/collect/TreeMultiset;->comparator()Ljava/util/Comparator; move-result-object v3 invoke-static {v3, p1, p2}, Lcom/google/common/collect/GeneralRange;->downTo(Ljava/util/Comparator;Ljava/lang/Object;Lcom/google/common/collect/BoundType;)Lcom/google/common/collect/GeneralRange; move-result-object p1 invoke-virtual {v2, p1}, Lcom/google/common/collect/GeneralRange;->intersect(Lcom/google/common/collect/GeneralRange;)Lcom/google/common/collect/GeneralRange; move-result-object p1 iget-object p2, p0, Lcom/google/common/collect/TreeMultiset;->header:Lcom/google/common/collect/TreeMultiset$AvlNode; invoke-direct {v0, v1, p1, p2}, Lcom/google/common/collect/TreeMultiset;->(Lcom/google/common/collect/TreeMultiset$Reference;Lcom/google/common/collect/GeneralRange;Lcom/google/common/collect/TreeMultiset$AvlNode;)V return-object v0 .end method