Rabbit-R1/switch port/java/sources/com/google/common/graph/ElementOrder.java
2024-05-21 17:08:36 -04:00

139 lines
4.5 KiB
Java

package com.google.common.graph;
import com.google.common.base.MoreObjects;
import com.google.common.base.Objects;
import com.google.common.base.Preconditions;
import com.google.common.collect.Maps;
import com.google.common.collect.Ordering;
import com.google.errorprone.annotations.Immutable;
import java.util.Comparator;
import java.util.Map;
import javax.annotation.CheckForNull;
@Immutable
@ElementTypesAreNonnullByDefault
/* loaded from: classes3.dex */
public final class ElementOrder<T> {
@CheckForNull
private final Comparator<T> comparator;
private final Type type;
/* loaded from: classes3.dex */
public enum Type {
UNORDERED,
STABLE,
INSERTION,
SORTED
}
/* JADX INFO: Access modifiers changed from: package-private */
/* JADX WARN: Multi-variable type inference failed */
public <T1 extends T> ElementOrder<T1> cast() {
return this;
}
public Type type() {
return this.type;
}
private ElementOrder(Type type, @CheckForNull Comparator<T> comparator) {
this.type = (Type) Preconditions.checkNotNull(type);
this.comparator = comparator;
Preconditions.checkState((type == Type.SORTED) == (comparator != null));
}
public static <S> ElementOrder<S> unordered() {
return new ElementOrder<>(Type.UNORDERED, null);
}
public static <S> ElementOrder<S> stable() {
return new ElementOrder<>(Type.STABLE, null);
}
public static <S> ElementOrder<S> insertion() {
return new ElementOrder<>(Type.INSERTION, null);
}
public static <S extends Comparable<? super S>> ElementOrder<S> natural() {
return new ElementOrder<>(Type.SORTED, Ordering.natural());
}
public static <S> ElementOrder<S> sorted(Comparator<S> comparator) {
return new ElementOrder<>(Type.SORTED, (Comparator) Preconditions.checkNotNull(comparator));
}
public Comparator<T> comparator() {
Comparator<T> comparator = this.comparator;
if (comparator != null) {
return comparator;
}
throw new UnsupportedOperationException("This ordering does not define a comparator.");
}
public boolean equals(@CheckForNull Object obj) {
if (obj == this) {
return true;
}
if (!(obj instanceof ElementOrder)) {
return false;
}
ElementOrder elementOrder = (ElementOrder) obj;
return this.type == elementOrder.type && Objects.equal(this.comparator, elementOrder.comparator);
}
public int hashCode() {
return Objects.hashCode(this.type, this.comparator);
}
public String toString() {
MoreObjects.ToStringHelper add = MoreObjects.toStringHelper(this).add("type", this.type);
Comparator<T> comparator = this.comparator;
if (comparator != null) {
add.add("comparator", comparator);
}
return add.toString();
}
/* renamed from: com.google.common.graph.ElementOrder$1, reason: invalid class name */
/* loaded from: classes3.dex */
static /* synthetic */ class AnonymousClass1 {
static final /* synthetic */ int[] $SwitchMap$com$google$common$graph$ElementOrder$Type;
static {
int[] iArr = new int[Type.values().length];
$SwitchMap$com$google$common$graph$ElementOrder$Type = iArr;
try {
iArr[Type.UNORDERED.ordinal()] = 1;
} catch (NoSuchFieldError unused) {
}
try {
$SwitchMap$com$google$common$graph$ElementOrder$Type[Type.INSERTION.ordinal()] = 2;
} catch (NoSuchFieldError unused2) {
}
try {
$SwitchMap$com$google$common$graph$ElementOrder$Type[Type.STABLE.ordinal()] = 3;
} catch (NoSuchFieldError unused3) {
}
try {
$SwitchMap$com$google$common$graph$ElementOrder$Type[Type.SORTED.ordinal()] = 4;
} catch (NoSuchFieldError unused4) {
}
}
}
/* JADX INFO: Access modifiers changed from: package-private */
public <K extends T, V> Map<K, V> createMap(int i) {
int i2 = AnonymousClass1.$SwitchMap$com$google$common$graph$ElementOrder$Type[this.type.ordinal()];
if (i2 == 1) {
return Maps.newHashMapWithExpectedSize(i);
}
if (i2 == 2 || i2 == 3) {
return Maps.newLinkedHashMapWithExpectedSize(i);
}
if (i2 == 4) {
return Maps.newTreeMap(comparator());
}
throw new AssertionError();
}
}