ga.smali

.class final Lcom/google/common/collect/ga;
.super Ljava/lang/Object;
.source "TopKSelector.java"


# annotations
.annotation system Ldalvik/annotation/Signature;
    value = {
        "<T:",
        "Ljava/lang/Object;",
        ">",
        "Ljava/lang/Object;"
    }
.end annotation


# instance fields
.field private final a:I

.field private final b:Ljava/util/Comparator;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "Ljava/util/Comparator<",
            "-TT;>;"
        }
    .end annotation
.end field

.field private final c:[Ljava/lang/Object;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "[TT;"
        }
    .end annotation
.end field

.field private d:I

.field private e:Ljava/lang/Object;
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "TT;"
        }
    .end annotation
.end field


# direct methods
.method private constructor <init>(Ljava/util/Comparator;I)V
    .registers 5
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(",
            "Ljava/util/Comparator<",
            "-TT;>;I)V"
        }
    .end annotation

    .line 1
    invoke-direct {p0}, Ljava/lang/Object;-><init>()V

    const-string v0, "comparator"

    .line 2
    invoke-static {p1, v0}, Lcom/google/common/base/r;->a(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;

    check-cast p1, Ljava/util/Comparator;

    iput-object p1, p0, Lcom/google/common/collect/ga;->b:Ljava/util/Comparator;

    .line 3
    iput p2, p0, Lcom/google/common/collect/ga;->a:I

    const/4 p1, 0x0

    if-ltz p2, :cond_13

    const/4 v0, 0x1

    goto :goto_14

    :cond_13
    const/4 v0, 0x0

    :goto_14
    const-string v1, "k must be nonnegative, was %s"

    .line 4
    invoke-static {v0, v1, p2}, Lcom/google/common/base/r;->a(ZLjava/lang/String;I)V

    mul-int/lit8 p2, p2, 0x2

    .line 5
    new-array p2, p2, [Ljava/lang/Object;

    iput-object p2, p0, Lcom/google/common/collect/ga;->c:[Ljava/lang/Object;

    .line 6
    iput p1, p0, Lcom/google/common/collect/ga;->d:I

    const/4 p1, 0x0

    .line 7
    iput-object p1, p0, Lcom/google/common/collect/ga;->e:Ljava/lang/Object;

    return-void
.end method

.method private a(III)I
    .registers 7

    .line 14
    iget-object v0, p0, Lcom/google/common/collect/ga;->c:[Ljava/lang/Object;

    aget-object v1, v0, p3

    .line 15
    aget-object v2, v0, p2

    aput-object v2, v0, p3

    move p3, p1

    :goto_9
    if-ge p1, p2, :cond_1f

    .line 16
    iget-object v0, p0, Lcom/google/common/collect/ga;->b:Ljava/util/Comparator;

    iget-object v2, p0, Lcom/google/common/collect/ga;->c:[Ljava/lang/Object;

    aget-object v2, v2, p1

    invoke-interface {v0, v2, v1}, Ljava/util/Comparator;->compare(Ljava/lang/Object;Ljava/lang/Object;)I

    move-result v0

    if-gez v0, :cond_1c

    .line 17
    invoke-direct {p0, p3, p1}, Lcom/google/common/collect/ga;->a(II)V

    add-int/lit8 p3, p3, 0x1

    :cond_1c
    add-int/lit8 p1, p1, 0x1

    goto :goto_9

    .line 18
    :cond_1f
    iget-object p1, p0, Lcom/google/common/collect/ga;->c:[Ljava/lang/Object;

    aget-object v0, p1, p3

    aput-object v0, p1, p2

    .line 19
    aput-object v1, p1, p3

    return p3
.end method

.method public static a(ILjava/util/Comparator;)Lcom/google/common/collect/ga;
    .registers 3
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "<T:",
            "Ljava/lang/Object;",
            ">(I",
            "Ljava/util/Comparator<",
            "-TT;>;)",
            "Lcom/google/common/collect/ga<",
            "TT;>;"
        }
    .end annotation

    .line 1
    new-instance v0, Lcom/google/common/collect/ga;

    invoke-direct {v0, p1, p0}, Lcom/google/common/collect/ga;-><init>(Ljava/util/Comparator;I)V

    return-object v0
.end method

.method private a(II)V
    .registers 6

    .line 20
    iget-object v0, p0, Lcom/google/common/collect/ga;->c:[Ljava/lang/Object;

    aget-object v1, v0, p1

    .line 21
    aget-object v2, v0, p2

    aput-object v2, v0, p1

    .line 22
    aput-object v1, v0, p2

    return-void
.end method

.method private b()V
    .registers 8

    .line 1
    iget v0, p0, Lcom/google/common/collect/ga;->a:I

    mul-int/lit8 v0, v0, 0x2

    add-int/lit8 v0, v0, -0x1

    add-int/lit8 v1, v0, 0x0

    .line 2
    sget-object v2, Ljava/math/RoundingMode;->CEILING:Ljava/math/RoundingMode;

    invoke-static {v1, v2}, Lc/d/b/a/b;->a(ILjava/math/RoundingMode;)I

    move-result v1

    mul-int/lit8 v1, v1, 0x3

    const/4 v2, 0x0

    const/4 v3, 0x0

    const/4 v4, 0x0

    :cond_13
    if-ge v2, v0, :cond_3b

    add-int v5, v2, v0

    add-int/lit8 v5, v5, 0x1

    ushr-int/lit8 v5, v5, 0x1

    .line 3
    invoke-direct {p0, v2, v0, v5}, Lcom/google/common/collect/ga;->a(III)I

    move-result v5

    .line 4
    iget v6, p0, Lcom/google/common/collect/ga;->a:I

    if-le v5, v6, :cond_27

    add-int/lit8 v5, v5, -0x1

    move v0, v5

    goto :goto_30

    :cond_27
    if-ge v5, v6, :cond_3b

    add-int/lit8 v2, v2, 0x1

    .line 5
    invoke-static {v5, v2}, Ljava/lang/Math;->max(II)I

    move-result v2

    move v4, v5

    :goto_30
    add-int/lit8 v3, v3, 0x1

    if-lt v3, v1, :cond_13

    .line 6
    iget-object v1, p0, Lcom/google/common/collect/ga;->c:[Ljava/lang/Object;

    iget-object v3, p0, Lcom/google/common/collect/ga;->b:Ljava/util/Comparator;

    invoke-static {v1, v2, v0, v3}, Ljava/util/Arrays;->sort([Ljava/lang/Object;IILjava/util/Comparator;)V

    .line 7
    :cond_3b
    iget v0, p0, Lcom/google/common/collect/ga;->a:I

    iput v0, p0, Lcom/google/common/collect/ga;->d:I

    .line 8
    iget-object v0, p0, Lcom/google/common/collect/ga;->c:[Ljava/lang/Object;

    aget-object v0, v0, v4

    iput-object v0, p0, Lcom/google/common/collect/ga;->e:Ljava/lang/Object;

    :goto_45
    add-int/lit8 v4, v4, 0x1

    .line 9
    iget v0, p0, Lcom/google/common/collect/ga;->a:I

    if-ge v4, v0, :cond_60

    .line 10
    iget-object v0, p0, Lcom/google/common/collect/ga;->b:Ljava/util/Comparator;

    iget-object v1, p0, Lcom/google/common/collect/ga;->c:[Ljava/lang/Object;

    aget-object v1, v1, v4

    iget-object v2, p0, Lcom/google/common/collect/ga;->e:Ljava/lang/Object;

    invoke-interface {v0, v1, v2}, Ljava/util/Comparator;->compare(Ljava/lang/Object;Ljava/lang/Object;)I

    move-result v0

    if-lez v0, :cond_5f

    .line 11
    iget-object v0, p0, Lcom/google/common/collect/ga;->c:[Ljava/lang/Object;

    aget-object v0, v0, v4

    iput-object v0, p0, Lcom/google/common/collect/ga;->e:Ljava/lang/Object;

    :cond_5f
    goto :goto_45

    :cond_60
    return-void
.end method


# virtual methods
.method public a()Ljava/util/List;
    .registers 5
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "()",
            "Ljava/util/List<",
            "TT;>;"
        }
    .end annotation

    .line 25
    iget-object v0, p0, Lcom/google/common/collect/ga;->c:[Ljava/lang/Object;

    iget v1, p0, Lcom/google/common/collect/ga;->d:I

    iget-object v2, p0, Lcom/google/common/collect/ga;->b:Ljava/util/Comparator;

    const/4 v3, 0x0

    invoke-static {v0, v3, v1, v2}, Ljava/util/Arrays;->sort([Ljava/lang/Object;IILjava/util/Comparator;)V

    .line 26
    iget v0, p0, Lcom/google/common/collect/ga;->d:I

    iget v1, p0, Lcom/google/common/collect/ga;->a:I

    if-le v0, v1, :cond_23

    .line 27
    iget-object v0, p0, Lcom/google/common/collect/ga;->c:[Ljava/lang/Object;

    array-length v2, v0

    const/4 v3, 0x0

    invoke-static {v0, v1, v2, v3}, Ljava/util/Arrays;->fill([Ljava/lang/Object;IILjava/lang/Object;)V

    .line 28
    iget v0, p0, Lcom/google/common/collect/ga;->a:I

    iput v0, p0, Lcom/google/common/collect/ga;->d:I

    .line 29
    iget-object v1, p0, Lcom/google/common/collect/ga;->c:[Ljava/lang/Object;

    add-int/lit8 v0, v0, -0x1

    aget-object v0, v1, v0

    iput-object v0, p0, Lcom/google/common/collect/ga;->e:Ljava/lang/Object;

    .line 30
    :cond_23
    iget-object v0, p0, Lcom/google/common/collect/ga;->c:[Ljava/lang/Object;

    iget v1, p0, Lcom/google/common/collect/ga;->d:I

    invoke-static {v0, v1}, Ljava/util/Arrays;->copyOf([Ljava/lang/Object;I)[Ljava/lang/Object;

    move-result-object v0

    invoke-static {v0}, Ljava/util/Arrays;->asList([Ljava/lang/Object;)Ljava/util/List;

    move-result-object v0

    invoke-static {v0}, Ljava/util/Collections;->unmodifiableList(Ljava/util/List;)Ljava/util/List;

    move-result-object v0

    return-object v0
.end method

.method public a(Ljava/lang/Object;)V
    .registers 5
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(TT;)V"
        }
    .end annotation

    .line 2
    iget v0, p0, Lcom/google/common/collect/ga;->a:I

    if-nez v0, :cond_5

    return-void

    .line 3
    :cond_5
    iget v1, p0, Lcom/google/common/collect/ga;->d:I

    if-nez v1, :cond_14

    .line 4
    iget-object v0, p0, Lcom/google/common/collect/ga;->c:[Ljava/lang/Object;

    const/4 v1, 0x0

    aput-object p1, v0, v1

    .line 5
    iput-object p1, p0, Lcom/google/common/collect/ga;->e:Ljava/lang/Object;

    const/4 p1, 0x1

    .line 6
    iput p1, p0, Lcom/google/common/collect/ga;->d:I

    goto :goto_4a

    :cond_14
    if-ge v1, v0, :cond_2b

    .line 7
    iget-object v0, p0, Lcom/google/common/collect/ga;->c:[Ljava/lang/Object;

    add-int/lit8 v2, v1, 0x1

    iput v2, p0, Lcom/google/common/collect/ga;->d:I

    aput-object p1, v0, v1

    .line 8
    iget-object v0, p0, Lcom/google/common/collect/ga;->b:Ljava/util/Comparator;

    iget-object v1, p0, Lcom/google/common/collect/ga;->e:Ljava/lang/Object;

    invoke-interface {v0, p1, v1}, Ljava/util/Comparator;->compare(Ljava/lang/Object;Ljava/lang/Object;)I

    move-result v0

    if-lez v0, :cond_4a

    .line 9
    iput-object p1, p0, Lcom/google/common/collect/ga;->e:Ljava/lang/Object;

    goto :goto_4a

    .line 10
    :cond_2b
    iget-object v0, p0, Lcom/google/common/collect/ga;->b:Ljava/util/Comparator;

    iget-object v1, p0, Lcom/google/common/collect/ga;->e:Ljava/lang/Object;

    invoke-interface {v0, p1, v1}, Ljava/util/Comparator;->compare(Ljava/lang/Object;Ljava/lang/Object;)I

    move-result v0

    if-gez v0, :cond_4a

    .line 11
    iget-object v0, p0, Lcom/google/common/collect/ga;->c:[Ljava/lang/Object;

    iget v1, p0, Lcom/google/common/collect/ga;->d:I

    add-int/lit8 v2, v1, 0x1

    iput v2, p0, Lcom/google/common/collect/ga;->d:I

    aput-object p1, v0, v1

    .line 12
    iget p1, p0, Lcom/google/common/collect/ga;->d:I

    iget v0, p0, Lcom/google/common/collect/ga;->a:I

    mul-int/lit8 v0, v0, 0x2

    if-ne p1, v0, :cond_4a

    .line 13
    invoke-direct {p0}, Lcom/google/common/collect/ga;->b()V

    :cond_4a
    :goto_4a
    return-void
.end method

.method public a(Ljava/util/Iterator;)V
    .registers 3
    .annotation system Ldalvik/annotation/Signature;
        value = {
            "(",
            "Ljava/util/Iterator<",
            "+TT;>;)V"
        }
    .end annotation

    .line 23
    :goto_0
    invoke-interface {p1}, Ljava/util/Iterator;->hasNext()Z

    move-result v0

    if-eqz v0, :cond_e

    .line 24
    invoke-interface {p1}, Ljava/util/Iterator;->next()Ljava/lang/Object;

    move-result-object v0

    invoke-virtual {p0, v0}, Lcom/google/common/collect/ga;->a(Ljava/lang/Object;)V

    goto :goto_0

    :cond_e
    return-void
.end method