.class public final Lcom/google/common/collect/MinMaxPriorityQueue; .super Ljava/util/AbstractQueue; .source "MinMaxPriorityQueue.java" # annotations .annotation build Lcom/google/common/annotations/Beta; .end annotation .annotation build Lcom/google/common/annotations/GwtCompatible; .end annotation .annotation runtime Lcom/google/common/collect/ElementTypesAreNonnullByDefault; .end annotation .annotation system Ldalvik/annotation/MemberClasses; value = { Lcom/google/common/collect/MinMaxPriorityQueue$QueueIterator;, Lcom/google/common/collect/MinMaxPriorityQueue$Heap;, Lcom/google/common/collect/MinMaxPriorityQueue$MoveDesc;, Lcom/google/common/collect/MinMaxPriorityQueue$Builder; } .end annotation .annotation system Ldalvik/annotation/Signature; value = { "", "Ljava/util/AbstractQueue<", "TE;>;" } .end annotation # static fields .field private static final DEFAULT_CAPACITY:I = 0xb .field private static final EVEN_POWERS_OF_TWO:I = 0x55555555 .field private static final ODD_POWERS_OF_TWO:I = -0x55555556 # instance fields .field private final maxHeap:Lcom/google/common/collect/MinMaxPriorityQueue$Heap; .annotation system Ldalvik/annotation/Signature; value = { "Lcom/google/common/collect/MinMaxPriorityQueue<", "TE;>.Heap;" } .end annotation .end field .field public final maximumSize:I .annotation build Lcom/google/common/annotations/VisibleForTesting; .end annotation .end field .field private final minHeap:Lcom/google/common/collect/MinMaxPriorityQueue$Heap; .annotation system Ldalvik/annotation/Signature; value = { "Lcom/google/common/collect/MinMaxPriorityQueue<", "TE;>.Heap;" } .end annotation .end field .field private modCount:I .field private queue:[Ljava/lang/Object; .field private size:I # direct methods .method private constructor (Lcom/google/common/collect/MinMaxPriorityQueue$Builder;I)V .locals 3 .annotation system Ldalvik/annotation/Signature; value = { "(", "Lcom/google/common/collect/MinMaxPriorityQueue$Builder<", "-TE;>;I)V" } .end annotation .line 2 invoke-direct {p0}, Ljava/util/AbstractQueue;->()V .line 3 invoke-static {p1}, Lcom/google/common/collect/MinMaxPriorityQueue$Builder;->access$200(Lcom/google/common/collect/MinMaxPriorityQueue$Builder;)Lcom/google/common/collect/Ordering; move-result-object v0 .line 4 new-instance v1, Lcom/google/common/collect/MinMaxPriorityQueue$Heap; invoke-direct {v1, p0, v0}, Lcom/google/common/collect/MinMaxPriorityQueue$Heap;->(Lcom/google/common/collect/MinMaxPriorityQueue;Lcom/google/common/collect/Ordering;)V iput-object v1, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->minHeap:Lcom/google/common/collect/MinMaxPriorityQueue$Heap; .line 5 new-instance v2, Lcom/google/common/collect/MinMaxPriorityQueue$Heap; invoke-virtual {v0}, Lcom/google/common/collect/Ordering;->reverse()Lcom/google/common/collect/Ordering; move-result-object v0 invoke-direct {v2, p0, v0}, Lcom/google/common/collect/MinMaxPriorityQueue$Heap;->(Lcom/google/common/collect/MinMaxPriorityQueue;Lcom/google/common/collect/Ordering;)V iput-object v2, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->maxHeap:Lcom/google/common/collect/MinMaxPriorityQueue$Heap; .line 6 iput-object v2, v1, Lcom/google/common/collect/MinMaxPriorityQueue$Heap;->otherHeap:Lcom/google/common/collect/MinMaxPriorityQueue$Heap; .line 7 iput-object v1, v2, Lcom/google/common/collect/MinMaxPriorityQueue$Heap;->otherHeap:Lcom/google/common/collect/MinMaxPriorityQueue$Heap; .line 8 invoke-static {p1}, Lcom/google/common/collect/MinMaxPriorityQueue$Builder;->access$300(Lcom/google/common/collect/MinMaxPriorityQueue$Builder;)I move-result p1 iput p1, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->maximumSize:I .line 9 new-array p1, p2, [Ljava/lang/Object; iput-object p1, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->queue:[Ljava/lang/Object; return-void .end method .method public synthetic constructor (Lcom/google/common/collect/MinMaxPriorityQueue$Builder;ILcom/google/common/collect/MinMaxPriorityQueue$1;)V .locals 0 .line 1 invoke-direct {p0, p1, p2}, Lcom/google/common/collect/MinMaxPriorityQueue;->(Lcom/google/common/collect/MinMaxPriorityQueue$Builder;I)V return-void .end method .method public static synthetic access$500(Lcom/google/common/collect/MinMaxPriorityQueue;)[Ljava/lang/Object; .locals 0 .line 1 iget-object p0, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->queue:[Ljava/lang/Object; return-object p0 .end method .method public static synthetic access$600(Lcom/google/common/collect/MinMaxPriorityQueue;)I .locals 0 .line 1 iget p0, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->size:I return p0 .end method .method public static synthetic access$700(Lcom/google/common/collect/MinMaxPriorityQueue;)I .locals 0 .line 1 iget p0, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->modCount:I return p0 .end method .method private calculateNewCapacity()I .locals 2 .line 1 iget-object v0, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->queue:[Ljava/lang/Object; array-length v0, v0 const/16 v1, 0x40 if-ge v0, v1, :cond_0 add-int/lit8 v0, v0, 0x1 mul-int/lit8 v0, v0, 0x2 goto :goto_0 .line 2 :cond_0 div-int/lit8 v0, v0, 0x2 const/4 v1, 0x3 invoke-static {v0, v1}, Lcom/google/common/math/IntMath;->checkedMultiply(II)I move-result v0 .line 3 :goto_0 iget v1, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->maximumSize:I invoke-static {v0, v1}, Lcom/google/common/collect/MinMaxPriorityQueue;->capAtMaximumSize(II)I move-result v0 return v0 .end method .method private static capAtMaximumSize(II)I .locals 0 add-int/lit8 p0, p0, -0x1 .line 1 invoke-static {p0, p1}, Ljava/lang/Math;->min(II)I move-result p0 add-int/lit8 p0, p0, 0x1 return p0 .end method .method public static create()Lcom/google/common/collect/MinMaxPriorityQueue; .locals 3 .annotation system Ldalvik/annotation/Signature; value = { ";>()", "Lcom/google/common/collect/MinMaxPriorityQueue<", "TE;>;" } .end annotation .line 1 new-instance v0, Lcom/google/common/collect/MinMaxPriorityQueue$Builder; invoke-static {}, Lcom/google/common/collect/Ordering;->natural()Lcom/google/common/collect/Ordering; move-result-object v1 const/4 v2, 0x0 invoke-direct {v0, v1, v2}, Lcom/google/common/collect/MinMaxPriorityQueue$Builder;->(Ljava/util/Comparator;Lcom/google/common/collect/MinMaxPriorityQueue$1;)V invoke-virtual {v0}, Lcom/google/common/collect/MinMaxPriorityQueue$Builder;->create()Lcom/google/common/collect/MinMaxPriorityQueue; move-result-object v0 return-object v0 .end method .method public static create(Ljava/lang/Iterable;)Lcom/google/common/collect/MinMaxPriorityQueue; .locals 3 .annotation system Ldalvik/annotation/Signature; value = { ";>(", "Ljava/lang/Iterable<", "+TE;>;)", "Lcom/google/common/collect/MinMaxPriorityQueue<", "TE;>;" } .end annotation .line 2 new-instance v0, Lcom/google/common/collect/MinMaxPriorityQueue$Builder; invoke-static {}, Lcom/google/common/collect/Ordering;->natural()Lcom/google/common/collect/Ordering; move-result-object v1 const/4 v2, 0x0 invoke-direct {v0, v1, v2}, Lcom/google/common/collect/MinMaxPriorityQueue$Builder;->(Ljava/util/Comparator;Lcom/google/common/collect/MinMaxPriorityQueue$1;)V invoke-virtual {v0, p0}, Lcom/google/common/collect/MinMaxPriorityQueue$Builder;->create(Ljava/lang/Iterable;)Lcom/google/common/collect/MinMaxPriorityQueue; move-result-object p0 return-object p0 .end method .method public static expectedSize(I)Lcom/google/common/collect/MinMaxPriorityQueue$Builder; .locals 3 .annotation system Ldalvik/annotation/Signature; value = { "(I)", "Lcom/google/common/collect/MinMaxPriorityQueue$Builder<", "Ljava/lang/Comparable;", ">;" } .end annotation .line 1 new-instance v0, Lcom/google/common/collect/MinMaxPriorityQueue$Builder; invoke-static {}, Lcom/google/common/collect/Ordering;->natural()Lcom/google/common/collect/Ordering; move-result-object v1 const/4 v2, 0x0 invoke-direct {v0, v1, v2}, Lcom/google/common/collect/MinMaxPriorityQueue$Builder;->(Ljava/util/Comparator;Lcom/google/common/collect/MinMaxPriorityQueue$1;)V invoke-virtual {v0, p0}, Lcom/google/common/collect/MinMaxPriorityQueue$Builder;->expectedSize(I)Lcom/google/common/collect/MinMaxPriorityQueue$Builder; move-result-object p0 return-object p0 .end method .method private fillHole(ILjava/lang/Object;)Lcom/google/common/collect/MinMaxPriorityQueue$MoveDesc; .locals 3 .annotation system Ldalvik/annotation/Signature; value = { "(ITE;)", "Lcom/google/common/collect/MinMaxPriorityQueue$MoveDesc<", "TE;>;" } .end annotation .annotation runtime Ljavax/annotation/CheckForNull; .end annotation .line 1 invoke-direct {p0, p1}, Lcom/google/common/collect/MinMaxPriorityQueue;->heapForIndex(I)Lcom/google/common/collect/MinMaxPriorityQueue$Heap; move-result-object v0 .line 2 invoke-virtual {v0, p1}, Lcom/google/common/collect/MinMaxPriorityQueue$Heap;->fillHoleAt(I)I move-result v1 .line 3 invoke-virtual {v0, v1, p2}, Lcom/google/common/collect/MinMaxPriorityQueue$Heap;->bubbleUpAlternatingLevels(ILjava/lang/Object;)I move-result v2 if-ne v2, v1, :cond_0 .line 4 invoke-virtual {v0, p1, v1, p2}, Lcom/google/common/collect/MinMaxPriorityQueue$Heap;->tryCrossOverAndBubbleUp(IILjava/lang/Object;)Lcom/google/common/collect/MinMaxPriorityQueue$MoveDesc; move-result-object p1 return-object p1 :cond_0 if-ge v2, p1, :cond_1 .line 5 new-instance v0, Lcom/google/common/collect/MinMaxPriorityQueue$MoveDesc; invoke-virtual {p0, p1}, Lcom/google/common/collect/MinMaxPriorityQueue;->elementData(I)Ljava/lang/Object; move-result-object p1 invoke-direct {v0, p2, p1}, Lcom/google/common/collect/MinMaxPriorityQueue$MoveDesc;->(Ljava/lang/Object;Ljava/lang/Object;)V goto :goto_0 :cond_1 const/4 v0, 0x0 :goto_0 return-object v0 .end method .method private getMaxElementIndex()I .locals 3 .line 1 iget v0, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->size:I const/4 v1, 0x1 if-eq v0, v1, :cond_2 const/4 v2, 0x2 if-eq v0, v2, :cond_1 .line 2 iget-object v0, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->maxHeap:Lcom/google/common/collect/MinMaxPriorityQueue$Heap; invoke-virtual {v0, v1, v2}, Lcom/google/common/collect/MinMaxPriorityQueue$Heap;->compareElements(II)I move-result v0 if-gtz v0, :cond_0 goto :goto_0 :cond_0 move v1, v2 :cond_1 :goto_0 return v1 :cond_2 const/4 v0, 0x0 return v0 .end method .method private growIfNeeded()V .locals 4 .line 1 iget v0, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->size:I iget-object v1, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->queue:[Ljava/lang/Object; array-length v1, v1 if-le v0, v1, :cond_0 .line 2 invoke-direct {p0}, Lcom/google/common/collect/MinMaxPriorityQueue;->calculateNewCapacity()I move-result v0 .line 3 new-array v0, v0, [Ljava/lang/Object; .line 4 iget-object v1, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->queue:[Ljava/lang/Object; array-length v2, v1 const/4 v3, 0x0 invoke-static {v1, v3, v0, v3, v2}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V .line 5 iput-object v0, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->queue:[Ljava/lang/Object; :cond_0 return-void .end method .method private heapForIndex(I)Lcom/google/common/collect/MinMaxPriorityQueue$Heap; .locals 0 .annotation system Ldalvik/annotation/Signature; value = { "(I)", "Lcom/google/common/collect/MinMaxPriorityQueue<", "TE;>.Heap;" } .end annotation .line 1 invoke-static {p1}, Lcom/google/common/collect/MinMaxPriorityQueue;->isEvenLevel(I)Z move-result p1 if-eqz p1, :cond_0 iget-object p1, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->minHeap:Lcom/google/common/collect/MinMaxPriorityQueue$Heap; goto :goto_0 :cond_0 iget-object p1, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->maxHeap:Lcom/google/common/collect/MinMaxPriorityQueue$Heap; :goto_0 return-object p1 .end method .method public static initialQueueSize(IILjava/lang/Iterable;)I .locals 1 .annotation build Lcom/google/common/annotations/VisibleForTesting; .end annotation .annotation system Ldalvik/annotation/Signature; value = { "(II", "Ljava/lang/Iterable<", "*>;)I" } .end annotation const/4 v0, -0x1 if-ne p0, v0, :cond_0 const/16 p0, 0xb .line 1 :cond_0 instance-of v0, p2, Ljava/util/Collection; if-eqz v0, :cond_1 .line 2 check-cast p2, Ljava/util/Collection; invoke-interface {p2}, Ljava/util/Collection;->size()I move-result p2 .line 3 invoke-static {p0, p2}, Ljava/lang/Math;->max(II)I move-result p0 .line 4 :cond_1 invoke-static {p0, p1}, Lcom/google/common/collect/MinMaxPriorityQueue;->capAtMaximumSize(II)I move-result p0 return p0 .end method .method public static isEvenLevel(I)Z .locals 4 .annotation build Lcom/google/common/annotations/VisibleForTesting; .end annotation const/4 v0, 0x1 add-int/2addr p0, v0 not-int p0, p0 not-int p0, p0 const/4 v1, 0x0 if-lez p0, :cond_0 move v2, v0 goto :goto_0 :cond_0 move v2, v1 :goto_0 const-string v3, "negative index" .line 1 invoke-static {v2, v3}, Lcom/google/common/base/Preconditions;->checkState(ZLjava/lang/Object;)V const v2, 0x55555555 and-int/2addr v2, p0 const v3, -0x55555556 and-int/2addr p0, v3 if-le v2, p0, :cond_1 goto :goto_1 :cond_1 move v0, v1 :goto_1 return v0 .end method .method public static maximumSize(I)Lcom/google/common/collect/MinMaxPriorityQueue$Builder; .locals 3 .annotation system Ldalvik/annotation/Signature; value = { "(I)", "Lcom/google/common/collect/MinMaxPriorityQueue$Builder<", "Ljava/lang/Comparable;", ">;" } .end annotation .line 1 new-instance v0, Lcom/google/common/collect/MinMaxPriorityQueue$Builder; invoke-static {}, Lcom/google/common/collect/Ordering;->natural()Lcom/google/common/collect/Ordering; move-result-object v1 const/4 v2, 0x0 invoke-direct {v0, v1, v2}, Lcom/google/common/collect/MinMaxPriorityQueue$Builder;->(Ljava/util/Comparator;Lcom/google/common/collect/MinMaxPriorityQueue$1;)V invoke-virtual {v0, p0}, Lcom/google/common/collect/MinMaxPriorityQueue$Builder;->maximumSize(I)Lcom/google/common/collect/MinMaxPriorityQueue$Builder; move-result-object p0 return-object p0 .end method .method public static orderedBy(Ljava/util/Comparator;)Lcom/google/common/collect/MinMaxPriorityQueue$Builder; .locals 2 .annotation system Ldalvik/annotation/Signature; value = { "(", "Ljava/util/Comparator<", "TB;>;)", "Lcom/google/common/collect/MinMaxPriorityQueue$Builder<", "TB;>;" } .end annotation .line 1 new-instance v0, Lcom/google/common/collect/MinMaxPriorityQueue$Builder; const/4 v1, 0x0 invoke-direct {v0, p0, v1}, Lcom/google/common/collect/MinMaxPriorityQueue$Builder;->(Ljava/util/Comparator;Lcom/google/common/collect/MinMaxPriorityQueue$1;)V return-object v0 .end method .method private removeAndGet(I)Ljava/lang/Object; .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "(I)TE;" } .end annotation .line 1 invoke-virtual {p0, p1}, Lcom/google/common/collect/MinMaxPriorityQueue;->elementData(I)Ljava/lang/Object; move-result-object v0 .line 2 invoke-virtual {p0, p1}, Lcom/google/common/collect/MinMaxPriorityQueue;->removeAt(I)Lcom/google/common/collect/MinMaxPriorityQueue$MoveDesc; return-object v0 .end method # virtual methods .method public add(Ljava/lang/Object;)Z .locals 0 .annotation build Lcom/google/errorprone/annotations/CanIgnoreReturnValue; .end annotation .annotation system Ldalvik/annotation/Signature; value = { "(TE;)Z" } .end annotation .line 1 invoke-virtual {p0, p1}, Lcom/google/common/collect/MinMaxPriorityQueue;->offer(Ljava/lang/Object;)Z const/4 p1, 0x1 return p1 .end method .method public addAll(Ljava/util/Collection;)Z .locals 2 .annotation build Lcom/google/errorprone/annotations/CanIgnoreReturnValue; .end annotation .annotation system Ldalvik/annotation/Signature; value = { "(", "Ljava/util/Collection<", "+TE;>;)Z" } .end annotation .line 1 invoke-interface {p1}, Ljava/util/Collection;->iterator()Ljava/util/Iterator; move-result-object p1 const/4 v0, 0x0 :goto_0 invoke-interface {p1}, Ljava/util/Iterator;->hasNext()Z move-result v1 if-eqz v1, :cond_0 invoke-interface {p1}, Ljava/util/Iterator;->next()Ljava/lang/Object; move-result-object v0 .line 2 invoke-virtual {p0, v0}, Lcom/google/common/collect/MinMaxPriorityQueue;->offer(Ljava/lang/Object;)Z const/4 v0, 0x1 goto :goto_0 :cond_0 return v0 .end method .method public capacity()I .locals 1 .annotation build Lcom/google/common/annotations/VisibleForTesting; .end annotation .line 1 iget-object v0, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->queue:[Ljava/lang/Object; array-length v0, v0 return v0 .end method .method public clear()V .locals 4 const/4 v0, 0x0 move v1, v0 .line 1 :goto_0 iget v2, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->size:I if-ge v1, v2, :cond_0 .line 2 iget-object v2, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->queue:[Ljava/lang/Object; const/4 v3, 0x0 aput-object v3, v2, v1 add-int/lit8 v1, v1, 0x1 goto :goto_0 .line 3 :cond_0 iput v0, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->size:I return-void .end method .method public comparator()Ljava/util/Comparator; .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "()", "Ljava/util/Comparator<", "-TE;>;" } .end annotation .line 1 iget-object v0, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->minHeap:Lcom/google/common/collect/MinMaxPriorityQueue$Heap; iget-object v0, v0, Lcom/google/common/collect/MinMaxPriorityQueue$Heap;->ordering:Lcom/google/common/collect/Ordering; return-object v0 .end method .method public elementData(I)Ljava/lang/Object; .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "(I)TE;" } .end annotation .line 1 iget-object v0, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->queue:[Ljava/lang/Object; aget-object p1, v0, p1 invoke-static {p1}, Ljava/util/Objects;->requireNonNull(Ljava/lang/Object;)Ljava/lang/Object; return-object p1 .end method .method public isIntact()Z .locals 3 .annotation build Lcom/google/common/annotations/VisibleForTesting; .end annotation const/4 v0, 0x1 move v1, v0 .line 1 :goto_0 iget v2, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->size:I if-ge v1, v2, :cond_1 .line 2 invoke-direct {p0, v1}, Lcom/google/common/collect/MinMaxPriorityQueue;->heapForIndex(I)Lcom/google/common/collect/MinMaxPriorityQueue$Heap; move-result-object v2 invoke-static {v2, v1}, Lcom/google/common/collect/MinMaxPriorityQueue$Heap;->access$400(Lcom/google/common/collect/MinMaxPriorityQueue$Heap;I)Z move-result v2 if-nez v2, :cond_0 const/4 v0, 0x0 return v0 :cond_0 add-int/lit8 v1, v1, 0x1 goto :goto_0 :cond_1 return v0 .end method .method public iterator()Ljava/util/Iterator; .locals 2 .annotation system Ldalvik/annotation/Signature; value = { "()", "Ljava/util/Iterator<", "TE;>;" } .end annotation .line 1 new-instance v0, Lcom/google/common/collect/MinMaxPriorityQueue$QueueIterator; const/4 v1, 0x0 invoke-direct {v0, p0, v1}, Lcom/google/common/collect/MinMaxPriorityQueue$QueueIterator;->(Lcom/google/common/collect/MinMaxPriorityQueue;Lcom/google/common/collect/MinMaxPriorityQueue$1;)V return-object v0 .end method .method public offer(Ljava/lang/Object;)Z .locals 3 .annotation build Lcom/google/errorprone/annotations/CanIgnoreReturnValue; .end annotation .annotation system Ldalvik/annotation/Signature; value = { "(TE;)Z" } .end annotation .line 1 invoke-static {p1}, Lcom/google/common/base/Preconditions;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object; .line 2 iget v0, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->modCount:I const/4 v1, 0x1 add-int/2addr v0, v1 iput v0, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->modCount:I .line 3 iget v0, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->size:I add-int/lit8 v2, v0, 0x1 iput v2, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->size:I .line 4 invoke-direct {p0}, Lcom/google/common/collect/MinMaxPriorityQueue;->growIfNeeded()V .line 5 invoke-direct {p0, v0}, Lcom/google/common/collect/MinMaxPriorityQueue;->heapForIndex(I)Lcom/google/common/collect/MinMaxPriorityQueue$Heap; move-result-object v2 invoke-virtual {v2, v0, p1}, Lcom/google/common/collect/MinMaxPriorityQueue$Heap;->bubbleUp(ILjava/lang/Object;)V .line 6 iget v0, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->size:I iget v2, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->maximumSize:I if-le v0, v2, :cond_1 invoke-virtual {p0}, Lcom/google/common/collect/MinMaxPriorityQueue;->pollLast()Ljava/lang/Object; move-result-object v0 if-eq v0, p1, :cond_0 goto :goto_0 :cond_0 const/4 v1, 0x0 :cond_1 :goto_0 return v1 .end method .method public peek()Ljava/lang/Object; .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "()TE;" } .end annotation .annotation runtime Ljavax/annotation/CheckForNull; .end annotation .line 1 invoke-virtual {p0}, Ljava/util/AbstractQueue;->isEmpty()Z move-result v0 if-eqz v0, :cond_0 const/4 v0, 0x0 goto :goto_0 :cond_0 const/4 v0, 0x0 invoke-virtual {p0, v0}, Lcom/google/common/collect/MinMaxPriorityQueue;->elementData(I)Ljava/lang/Object; move-result-object v0 :goto_0 return-object v0 .end method .method public peekFirst()Ljava/lang/Object; .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "()TE;" } .end annotation .annotation runtime Ljavax/annotation/CheckForNull; .end annotation .line 1 invoke-virtual {p0}, Lcom/google/common/collect/MinMaxPriorityQueue;->peek()Ljava/lang/Object; move-result-object v0 return-object v0 .end method .method public peekLast()Ljava/lang/Object; .locals 1 .annotation system Ldalvik/annotation/Signature; value = { "()TE;" } .end annotation .annotation runtime Ljavax/annotation/CheckForNull; .end annotation .line 1 invoke-virtual {p0}, Ljava/util/AbstractQueue;->isEmpty()Z move-result v0 if-eqz v0, :cond_0 const/4 v0, 0x0 goto :goto_0 :cond_0 invoke-direct {p0}, Lcom/google/common/collect/MinMaxPriorityQueue;->getMaxElementIndex()I move-result v0 invoke-virtual {p0, v0}, Lcom/google/common/collect/MinMaxPriorityQueue;->elementData(I)Ljava/lang/Object; move-result-object v0 :goto_0 return-object v0 .end method .method public poll()Ljava/lang/Object; .locals 1 .annotation build Lcom/google/errorprone/annotations/CanIgnoreReturnValue; .end annotation .annotation system Ldalvik/annotation/Signature; value = { "()TE;" } .end annotation .annotation runtime Ljavax/annotation/CheckForNull; .end annotation .line 1 invoke-virtual {p0}, Ljava/util/AbstractQueue;->isEmpty()Z move-result v0 if-eqz v0, :cond_0 const/4 v0, 0x0 goto :goto_0 :cond_0 const/4 v0, 0x0 invoke-direct {p0, v0}, Lcom/google/common/collect/MinMaxPriorityQueue;->removeAndGet(I)Ljava/lang/Object; move-result-object v0 :goto_0 return-object v0 .end method .method public pollFirst()Ljava/lang/Object; .locals 1 .annotation build Lcom/google/errorprone/annotations/CanIgnoreReturnValue; .end annotation .annotation system Ldalvik/annotation/Signature; value = { "()TE;" } .end annotation .annotation runtime Ljavax/annotation/CheckForNull; .end annotation .line 1 invoke-virtual {p0}, Lcom/google/common/collect/MinMaxPriorityQueue;->poll()Ljava/lang/Object; move-result-object v0 return-object v0 .end method .method public pollLast()Ljava/lang/Object; .locals 1 .annotation build Lcom/google/errorprone/annotations/CanIgnoreReturnValue; .end annotation .annotation system Ldalvik/annotation/Signature; value = { "()TE;" } .end annotation .annotation runtime Ljavax/annotation/CheckForNull; .end annotation .line 1 invoke-virtual {p0}, Ljava/util/AbstractQueue;->isEmpty()Z move-result v0 if-eqz v0, :cond_0 const/4 v0, 0x0 goto :goto_0 :cond_0 invoke-direct {p0}, Lcom/google/common/collect/MinMaxPriorityQueue;->getMaxElementIndex()I move-result v0 invoke-direct {p0, v0}, Lcom/google/common/collect/MinMaxPriorityQueue;->removeAndGet(I)Ljava/lang/Object; move-result-object v0 :goto_0 return-object v0 .end method .method public removeAt(I)Lcom/google/common/collect/MinMaxPriorityQueue$MoveDesc; .locals 6 .annotation build Lcom/google/common/annotations/VisibleForTesting; .end annotation .annotation build Lcom/google/errorprone/annotations/CanIgnoreReturnValue; .end annotation .annotation system Ldalvik/annotation/Signature; value = { "(I)", "Lcom/google/common/collect/MinMaxPriorityQueue$MoveDesc<", "TE;>;" } .end annotation .annotation runtime Ljavax/annotation/CheckForNull; .end annotation .line 1 iget v0, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->size:I invoke-static {p1, v0}, Lcom/google/common/base/Preconditions;->checkPositionIndex(II)I .line 2 iget v0, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->modCount:I add-int/lit8 v0, v0, 0x1 iput v0, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->modCount:I .line 3 iget v0, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->size:I add-int/lit8 v0, v0, -0x1 iput v0, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->size:I const/4 v1, 0x0 if-ne v0, p1, :cond_0 .line 4 iget-object p1, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->queue:[Ljava/lang/Object; aput-object v1, p1, v0 return-object v1 .line 5 :cond_0 invoke-virtual {p0, v0}, Lcom/google/common/collect/MinMaxPriorityQueue;->elementData(I)Ljava/lang/Object; move-result-object v0 .line 6 iget v2, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->size:I invoke-direct {p0, v2}, Lcom/google/common/collect/MinMaxPriorityQueue;->heapForIndex(I)Lcom/google/common/collect/MinMaxPriorityQueue$Heap; move-result-object v2 invoke-virtual {v2, v0}, Lcom/google/common/collect/MinMaxPriorityQueue$Heap;->swapWithConceptuallyLastElement(Ljava/lang/Object;)I move-result v2 if-ne v2, p1, :cond_1 .line 7 iget-object p1, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->queue:[Ljava/lang/Object; iget v0, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->size:I aput-object v1, p1, v0 return-object v1 .line 8 :cond_1 iget v3, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->size:I invoke-virtual {p0, v3}, Lcom/google/common/collect/MinMaxPriorityQueue;->elementData(I)Ljava/lang/Object; move-result-object v3 .line 9 iget-object v4, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->queue:[Ljava/lang/Object; iget v5, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->size:I aput-object v1, v4, v5 .line 10 invoke-direct {p0, p1, v3}, Lcom/google/common/collect/MinMaxPriorityQueue;->fillHole(ILjava/lang/Object;)Lcom/google/common/collect/MinMaxPriorityQueue$MoveDesc; move-result-object v1 if-ge v2, p1, :cond_3 if-nez v1, :cond_2 .line 11 new-instance p1, Lcom/google/common/collect/MinMaxPriorityQueue$MoveDesc; invoke-direct {p1, v0, v3}, Lcom/google/common/collect/MinMaxPriorityQueue$MoveDesc;->(Ljava/lang/Object;Ljava/lang/Object;)V return-object p1 .line 12 :cond_2 new-instance p1, Lcom/google/common/collect/MinMaxPriorityQueue$MoveDesc; iget-object v1, v1, Lcom/google/common/collect/MinMaxPriorityQueue$MoveDesc;->replaced:Ljava/lang/Object; invoke-direct {p1, v0, v1}, Lcom/google/common/collect/MinMaxPriorityQueue$MoveDesc;->(Ljava/lang/Object;Ljava/lang/Object;)V return-object p1 :cond_3 return-object v1 .end method .method public removeFirst()Ljava/lang/Object; .locals 1 .annotation build Lcom/google/errorprone/annotations/CanIgnoreReturnValue; .end annotation .annotation system Ldalvik/annotation/Signature; value = { "()TE;" } .end annotation .line 1 invoke-virtual {p0}, Ljava/util/AbstractQueue;->remove()Ljava/lang/Object; move-result-object v0 return-object v0 .end method .method public removeLast()Ljava/lang/Object; .locals 1 .annotation build Lcom/google/errorprone/annotations/CanIgnoreReturnValue; .end annotation .annotation system Ldalvik/annotation/Signature; value = { "()TE;" } .end annotation .line 1 invoke-virtual {p0}, Ljava/util/AbstractQueue;->isEmpty()Z move-result v0 if-nez v0, :cond_0 .line 2 invoke-direct {p0}, Lcom/google/common/collect/MinMaxPriorityQueue;->getMaxElementIndex()I move-result v0 invoke-direct {p0, v0}, Lcom/google/common/collect/MinMaxPriorityQueue;->removeAndGet(I)Ljava/lang/Object; move-result-object v0 return-object v0 .line 3 :cond_0 new-instance v0, Ljava/util/NoSuchElementException; invoke-direct {v0}, Ljava/util/NoSuchElementException;->()V throw v0 .end method .method public size()I .locals 1 .line 1 iget v0, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->size:I return v0 .end method .method public toArray()[Ljava/lang/Object; .locals 4 .line 1 iget v0, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->size:I new-array v1, v0, [Ljava/lang/Object; .line 2 iget-object v2, p0, Lcom/google/common/collect/MinMaxPriorityQueue;->queue:[Ljava/lang/Object; const/4 v3, 0x0 invoke-static {v2, v3, v1, v3, v0}, Ljava/lang/System;->arraycopy(Ljava/lang/Object;ILjava/lang/Object;II)V return-object v1 .end method