mirror of
https://github.com/Pinball3D/Rabbit-R1.git
synced 2025-01-09 13:43:22 +00:00
354 lines
10 KiB
Smali
354 lines
10 KiB
Smali
.class public abstract Lcom/google/common/graph/Traverser;
|
|
.super Ljava/lang/Object;
|
|
.source "Traverser.java"
|
|
|
|
|
|
# annotations
|
|
.annotation runtime Lcom/google/common/graph/ElementTypesAreNonnullByDefault;
|
|
.end annotation
|
|
|
|
.annotation runtime Lcom/google/errorprone/annotations/DoNotMock;
|
|
value = "Call forGraph or forTree, passing a lambda or a Graph with the desired edges (built with GraphBuilder)"
|
|
.end annotation
|
|
|
|
.annotation system Ldalvik/annotation/MemberClasses;
|
|
value = {
|
|
Lcom/google/common/graph/Traverser$InsertionOrder;,
|
|
Lcom/google/common/graph/Traverser$Traversal;
|
|
}
|
|
.end annotation
|
|
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"<N:",
|
|
"Ljava/lang/Object;",
|
|
">",
|
|
"Ljava/lang/Object;"
|
|
}
|
|
.end annotation
|
|
|
|
|
|
# instance fields
|
|
.field private final successorFunction:Lcom/google/common/graph/SuccessorsFunction;
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"Lcom/google/common/graph/SuccessorsFunction<",
|
|
"TN;>;"
|
|
}
|
|
.end annotation
|
|
.end field
|
|
|
|
|
|
# direct methods
|
|
.method private constructor <init>(Lcom/google/common/graph/SuccessorsFunction;)V
|
|
.locals 0
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"(",
|
|
"Lcom/google/common/graph/SuccessorsFunction<",
|
|
"TN;>;)V"
|
|
}
|
|
.end annotation
|
|
|
|
.line 71
|
|
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
|
|
|
|
.line 72
|
|
invoke-static {p1}, Lcom/google/common/base/Preconditions;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
|
|
|
|
move-result-object p1
|
|
|
|
check-cast p1, Lcom/google/common/graph/SuccessorsFunction;
|
|
|
|
iput-object p1, p0, Lcom/google/common/graph/Traverser;->successorFunction:Lcom/google/common/graph/SuccessorsFunction;
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method synthetic constructor <init>(Lcom/google/common/graph/SuccessorsFunction;Lcom/google/common/graph/Traverser$1;)V
|
|
.locals 0
|
|
|
|
.line 68
|
|
invoke-direct {p0, p1}, Lcom/google/common/graph/Traverser;-><init>(Lcom/google/common/graph/SuccessorsFunction;)V
|
|
|
|
return-void
|
|
.end method
|
|
|
|
.method public static forGraph(Lcom/google/common/graph/SuccessorsFunction;)Lcom/google/common/graph/Traverser;
|
|
.locals 1
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"<N:",
|
|
"Ljava/lang/Object;",
|
|
">(",
|
|
"Lcom/google/common/graph/SuccessorsFunction<",
|
|
"TN;>;)",
|
|
"Lcom/google/common/graph/Traverser<",
|
|
"TN;>;"
|
|
}
|
|
.end annotation
|
|
|
|
.line 100
|
|
new-instance v0, Lcom/google/common/graph/Traverser$1;
|
|
|
|
invoke-direct {v0, p0, p0}, Lcom/google/common/graph/Traverser$1;-><init>(Lcom/google/common/graph/SuccessorsFunction;Lcom/google/common/graph/SuccessorsFunction;)V
|
|
|
|
return-object v0
|
|
.end method
|
|
|
|
.method public static forTree(Lcom/google/common/graph/SuccessorsFunction;)Lcom/google/common/graph/Traverser;
|
|
.locals 2
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"<N:",
|
|
"Ljava/lang/Object;",
|
|
">(",
|
|
"Lcom/google/common/graph/SuccessorsFunction<",
|
|
"TN;>;)",
|
|
"Lcom/google/common/graph/Traverser<",
|
|
"TN;>;"
|
|
}
|
|
.end annotation
|
|
|
|
.line 182
|
|
instance-of v0, p0, Lcom/google/common/graph/BaseGraph;
|
|
|
|
if-eqz v0, :cond_0
|
|
|
|
.line 183
|
|
move-object v0, p0
|
|
|
|
check-cast v0, Lcom/google/common/graph/BaseGraph;
|
|
|
|
invoke-interface {v0}, Lcom/google/common/graph/BaseGraph;->isDirected()Z
|
|
|
|
move-result v0
|
|
|
|
const-string v1, "Undirected graphs can never be trees."
|
|
|
|
invoke-static {v0, v1}, Lcom/google/common/base/Preconditions;->checkArgument(ZLjava/lang/Object;)V
|
|
|
|
.line 185
|
|
:cond_0
|
|
instance-of v0, p0, Lcom/google/common/graph/Network;
|
|
|
|
if-eqz v0, :cond_1
|
|
|
|
.line 186
|
|
move-object v0, p0
|
|
|
|
check-cast v0, Lcom/google/common/graph/Network;
|
|
|
|
invoke-interface {v0}, Lcom/google/common/graph/Network;->isDirected()Z
|
|
|
|
move-result v0
|
|
|
|
const-string v1, "Undirected networks can never be trees."
|
|
|
|
invoke-static {v0, v1}, Lcom/google/common/base/Preconditions;->checkArgument(ZLjava/lang/Object;)V
|
|
|
|
.line 188
|
|
:cond_1
|
|
new-instance v0, Lcom/google/common/graph/Traverser$2;
|
|
|
|
invoke-direct {v0, p0, p0}, Lcom/google/common/graph/Traverser$2;-><init>(Lcom/google/common/graph/SuccessorsFunction;Lcom/google/common/graph/SuccessorsFunction;)V
|
|
|
|
return-object v0
|
|
.end method
|
|
|
|
.method private validate(Ljava/lang/Iterable;)Lcom/google/common/collect/ImmutableSet;
|
|
.locals 3
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"(",
|
|
"Ljava/lang/Iterable<",
|
|
"+TN;>;)",
|
|
"Lcom/google/common/collect/ImmutableSet<",
|
|
"TN;>;"
|
|
}
|
|
.end annotation
|
|
|
|
.line 365
|
|
invoke-static {p1}, Lcom/google/common/collect/ImmutableSet;->copyOf(Ljava/lang/Iterable;)Lcom/google/common/collect/ImmutableSet;
|
|
|
|
move-result-object p1
|
|
|
|
.line 366
|
|
invoke-virtual {p1}, Lcom/google/common/collect/ImmutableSet;->iterator()Lcom/google/common/collect/UnmodifiableIterator;
|
|
|
|
move-result-object v0
|
|
|
|
:goto_0
|
|
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
|
|
|
|
move-result v1
|
|
|
|
if-eqz v1, :cond_0
|
|
|
|
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
|
|
|
|
move-result-object v1
|
|
|
|
iget-object v2, p0, Lcom/google/common/graph/Traverser;->successorFunction:Lcom/google/common/graph/SuccessorsFunction;
|
|
|
|
.line 367
|
|
invoke-interface {v2, v1}, Lcom/google/common/graph/SuccessorsFunction;->successors(Ljava/lang/Object;)Ljava/lang/Iterable;
|
|
|
|
goto :goto_0
|
|
|
|
:cond_0
|
|
return-object p1
|
|
.end method
|
|
|
|
|
|
# virtual methods
|
|
.method public final breadthFirst(Ljava/lang/Iterable;)Ljava/lang/Iterable;
|
|
.locals 1
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"(",
|
|
"Ljava/lang/Iterable<",
|
|
"+TN;>;)",
|
|
"Ljava/lang/Iterable<",
|
|
"TN;>;"
|
|
}
|
|
.end annotation
|
|
|
|
.line 242
|
|
invoke-direct {p0, p1}, Lcom/google/common/graph/Traverser;->validate(Ljava/lang/Iterable;)Lcom/google/common/collect/ImmutableSet;
|
|
|
|
move-result-object p1
|
|
|
|
.line 243
|
|
new-instance v0, Lcom/google/common/graph/Traverser$3;
|
|
|
|
invoke-direct {v0, p0, p1}, Lcom/google/common/graph/Traverser$3;-><init>(Lcom/google/common/graph/Traverser;Lcom/google/common/collect/ImmutableSet;)V
|
|
|
|
return-object v0
|
|
.end method
|
|
|
|
.method public final breadthFirst(Ljava/lang/Object;)Ljava/lang/Iterable;
|
|
.locals 0
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"(TN;)",
|
|
"Ljava/lang/Iterable<",
|
|
"TN;>;"
|
|
}
|
|
.end annotation
|
|
|
|
.line 228
|
|
invoke-static {p1}, Lcom/google/common/collect/ImmutableSet;->of(Ljava/lang/Object;)Lcom/google/common/collect/ImmutableSet;
|
|
|
|
move-result-object p1
|
|
|
|
invoke-virtual {p0, p1}, Lcom/google/common/graph/Traverser;->breadthFirst(Ljava/lang/Iterable;)Ljava/lang/Iterable;
|
|
|
|
move-result-object p0
|
|
|
|
return-object p0
|
|
.end method
|
|
|
|
.method public final depthFirstPostOrder(Ljava/lang/Iterable;)Ljava/lang/Iterable;
|
|
.locals 1
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"(",
|
|
"Ljava/lang/Iterable<",
|
|
"+TN;>;)",
|
|
"Ljava/lang/Iterable<",
|
|
"TN;>;"
|
|
}
|
|
.end annotation
|
|
|
|
.line 352
|
|
invoke-direct {p0, p1}, Lcom/google/common/graph/Traverser;->validate(Ljava/lang/Iterable;)Lcom/google/common/collect/ImmutableSet;
|
|
|
|
move-result-object p1
|
|
|
|
.line 353
|
|
new-instance v0, Lcom/google/common/graph/Traverser$5;
|
|
|
|
invoke-direct {v0, p0, p1}, Lcom/google/common/graph/Traverser$5;-><init>(Lcom/google/common/graph/Traverser;Lcom/google/common/collect/ImmutableSet;)V
|
|
|
|
return-object v0
|
|
.end method
|
|
|
|
.method public final depthFirstPostOrder(Ljava/lang/Object;)Ljava/lang/Iterable;
|
|
.locals 0
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"(TN;)",
|
|
"Ljava/lang/Iterable<",
|
|
"TN;>;"
|
|
}
|
|
.end annotation
|
|
|
|
.line 338
|
|
invoke-static {p1}, Lcom/google/common/collect/ImmutableSet;->of(Ljava/lang/Object;)Lcom/google/common/collect/ImmutableSet;
|
|
|
|
move-result-object p1
|
|
|
|
invoke-virtual {p0, p1}, Lcom/google/common/graph/Traverser;->depthFirstPostOrder(Ljava/lang/Iterable;)Ljava/lang/Iterable;
|
|
|
|
move-result-object p0
|
|
|
|
return-object p0
|
|
.end method
|
|
|
|
.method public final depthFirstPreOrder(Ljava/lang/Iterable;)Ljava/lang/Iterable;
|
|
.locals 1
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"(",
|
|
"Ljava/lang/Iterable<",
|
|
"+TN;>;)",
|
|
"Ljava/lang/Iterable<",
|
|
"TN;>;"
|
|
}
|
|
.end annotation
|
|
|
|
.line 297
|
|
invoke-direct {p0, p1}, Lcom/google/common/graph/Traverser;->validate(Ljava/lang/Iterable;)Lcom/google/common/collect/ImmutableSet;
|
|
|
|
move-result-object p1
|
|
|
|
.line 298
|
|
new-instance v0, Lcom/google/common/graph/Traverser$4;
|
|
|
|
invoke-direct {v0, p0, p1}, Lcom/google/common/graph/Traverser$4;-><init>(Lcom/google/common/graph/Traverser;Lcom/google/common/collect/ImmutableSet;)V
|
|
|
|
return-object v0
|
|
.end method
|
|
|
|
.method public final depthFirstPreOrder(Ljava/lang/Object;)Ljava/lang/Iterable;
|
|
.locals 0
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"(TN;)",
|
|
"Ljava/lang/Iterable<",
|
|
"TN;>;"
|
|
}
|
|
.end annotation
|
|
|
|
.line 283
|
|
invoke-static {p1}, Lcom/google/common/collect/ImmutableSet;->of(Ljava/lang/Object;)Lcom/google/common/collect/ImmutableSet;
|
|
|
|
move-result-object p1
|
|
|
|
invoke-virtual {p0, p1}, Lcom/google/common/graph/Traverser;->depthFirstPreOrder(Ljava/lang/Iterable;)Ljava/lang/Iterable;
|
|
|
|
move-result-object p0
|
|
|
|
return-object p0
|
|
.end method
|
|
|
|
.method abstract newTraversal()Lcom/google/common/graph/Traverser$Traversal;
|
|
.annotation system Ldalvik/annotation/Signature;
|
|
value = {
|
|
"()",
|
|
"Lcom/google/common/graph/Traverser$Traversal<",
|
|
"TN;>;"
|
|
}
|
|
.end annotation
|
|
.end method
|