Rabbit-R1/android (non root)/smali/smali_classes3/com/google/common/graph/AbstractBaseGraph.smali
2024-05-21 17:08:36 -04:00

488 lines
11 KiB
Smali

.class abstract Lcom/google/common/graph/AbstractBaseGraph;
.super Ljava/lang/Object;
.source "AbstractBaseGraph.java"
# interfaces
.implements Lcom/google/common/graph/BaseGraph;
# annotations
.annotation runtime Lcom/google/common/graph/ElementTypesAreNonnullByDefault;
.end annotation
.annotation system Ldalvik/annotation/Signature;
value = {
"<N:",
"Ljava/lang/Object;",
">",
"Ljava/lang/Object;",
"Lcom/google/common/graph/BaseGraph<",
"TN;>;"
}
.end annotation
# direct methods
.method constructor <init>()V
.locals 0
.line 44
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
# virtual methods
.method public degree(Ljava/lang/Object;)I
.locals 1
.annotation system Ldalvik/annotation/Signature;
value = {
"(TN;)I"
}
.end annotation
.line 134
invoke-virtual {p0}, Lcom/google/common/graph/AbstractBaseGraph;->isDirected()Z
move-result v0
if-eqz v0, :cond_0
.line 135
invoke-virtual {p0, p1}, Lcom/google/common/graph/AbstractBaseGraph;->predecessors(Ljava/lang/Object;)Ljava/util/Set;
move-result-object v0
invoke-interface {v0}, Ljava/util/Set;->size()I
move-result v0
invoke-virtual {p0, p1}, Lcom/google/common/graph/AbstractBaseGraph;->successors(Ljava/lang/Object;)Ljava/util/Set;
move-result-object p0
invoke-interface {p0}, Ljava/util/Set;->size()I
move-result p0
invoke-static {v0, p0}, Lcom/google/common/math/IntMath;->saturatedAdd(II)I
move-result p0
return p0
.line 137
:cond_0
invoke-virtual {p0, p1}, Lcom/google/common/graph/AbstractBaseGraph;->adjacentNodes(Ljava/lang/Object;)Ljava/util/Set;
move-result-object v0
.line 138
invoke-virtual {p0}, Lcom/google/common/graph/AbstractBaseGraph;->allowsSelfLoops()Z
move-result p0
if-eqz p0, :cond_1
invoke-interface {v0, p1}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z
move-result p0
if-eqz p0, :cond_1
const/4 p0, 0x1
goto :goto_0
:cond_1
const/4 p0, 0x0
.line 139
:goto_0
invoke-interface {v0}, Ljava/util/Set;->size()I
move-result p1
invoke-static {p1, p0}, Lcom/google/common/math/IntMath;->saturatedAdd(II)I
move-result p0
return p0
.end method
.method protected edgeCount()J
.locals 7
.line 53
invoke-virtual {p0}, Lcom/google/common/graph/AbstractBaseGraph;->nodes()Ljava/util/Set;
move-result-object v0
invoke-interface {v0}, Ljava/util/Set;->iterator()Ljava/util/Iterator;
move-result-object v0
const-wide/16 v1, 0x0
move-wide v3, v1
:goto_0
invoke-interface {v0}, Ljava/util/Iterator;->hasNext()Z
move-result v5
if-eqz v5, :cond_0
invoke-interface {v0}, Ljava/util/Iterator;->next()Ljava/lang/Object;
move-result-object v5
.line 54
invoke-virtual {p0, v5}, Lcom/google/common/graph/AbstractBaseGraph;->degree(Ljava/lang/Object;)I
move-result v5
int-to-long v5, v5
add-long/2addr v3, v5
goto :goto_0
:cond_0
const-wide/16 v5, 0x1
and-long/2addr v5, v3
cmp-long p0, v5, v1
const/4 v0, 0x1
if-nez p0, :cond_1
move p0, v0
goto :goto_1
:cond_1
const/4 p0, 0x0
.line 57
:goto_1
invoke-static {p0}, Lcom/google/common/base/Preconditions;->checkState(Z)V
ushr-long v0, v3, v0
return-wide v0
.end method
.method public edges()Ljava/util/Set;
.locals 1
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Ljava/util/Set<",
"Lcom/google/common/graph/EndpointPair<",
"TN;>;>;"
}
.end annotation
.line 67
new-instance v0, Lcom/google/common/graph/AbstractBaseGraph$1;
invoke-direct {v0, p0}, Lcom/google/common/graph/AbstractBaseGraph$1;-><init>(Lcom/google/common/graph/AbstractBaseGraph;)V
return-object v0
.end method
.method public hasEdgeConnecting(Lcom/google/common/graph/EndpointPair;)Z
.locals 3
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lcom/google/common/graph/EndpointPair<",
"TN;>;)Z"
}
.end annotation
.line 162
invoke-static {p1}, Lcom/google/common/base/Preconditions;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
.line 163
invoke-virtual {p0, p1}, Lcom/google/common/graph/AbstractBaseGraph;->isOrderingCompatible(Lcom/google/common/graph/EndpointPair;)Z
move-result v0
const/4 v1, 0x0
if-nez v0, :cond_0
return v1
.line 166
:cond_0
invoke-virtual {p1}, Lcom/google/common/graph/EndpointPair;->nodeU()Ljava/lang/Object;
move-result-object v0
.line 167
invoke-virtual {p1}, Lcom/google/common/graph/EndpointPair;->nodeV()Ljava/lang/Object;
move-result-object p1
.line 168
invoke-virtual {p0}, Lcom/google/common/graph/AbstractBaseGraph;->nodes()Ljava/util/Set;
move-result-object v2
invoke-interface {v2, v0}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z
move-result v2
if-eqz v2, :cond_1
invoke-virtual {p0, v0}, Lcom/google/common/graph/AbstractBaseGraph;->successors(Ljava/lang/Object;)Ljava/util/Set;
move-result-object p0
invoke-interface {p0, p1}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z
move-result p0
if-eqz p0, :cond_1
const/4 v1, 0x1
:cond_1
return v1
.end method
.method public hasEdgeConnecting(Ljava/lang/Object;Ljava/lang/Object;)Z
.locals 1
.annotation system Ldalvik/annotation/Signature;
value = {
"(TN;TN;)Z"
}
.end annotation
.line 155
invoke-static {p1}, Lcom/google/common/base/Preconditions;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
.line 156
invoke-static {p2}, Lcom/google/common/base/Preconditions;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
.line 157
invoke-virtual {p0}, Lcom/google/common/graph/AbstractBaseGraph;->nodes()Ljava/util/Set;
move-result-object v0
invoke-interface {v0, p1}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z
move-result v0
if-eqz v0, :cond_0
invoke-virtual {p0, p1}, Lcom/google/common/graph/AbstractBaseGraph;->successors(Ljava/lang/Object;)Ljava/util/Set;
move-result-object p0
invoke-interface {p0, p2}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z
move-result p0
if-eqz p0, :cond_0
const/4 p0, 0x1
goto :goto_0
:cond_0
const/4 p0, 0x0
:goto_0
return p0
.end method
.method public inDegree(Ljava/lang/Object;)I
.locals 1
.annotation system Ldalvik/annotation/Signature;
value = {
"(TN;)I"
}
.end annotation
.line 145
invoke-virtual {p0}, Lcom/google/common/graph/AbstractBaseGraph;->isDirected()Z
move-result v0
if-eqz v0, :cond_0
invoke-virtual {p0, p1}, Lcom/google/common/graph/AbstractBaseGraph;->predecessors(Ljava/lang/Object;)Ljava/util/Set;
move-result-object p0
invoke-interface {p0}, Ljava/util/Set;->size()I
move-result p0
goto :goto_0
:cond_0
invoke-virtual {p0, p1}, Lcom/google/common/graph/AbstractBaseGraph;->degree(Ljava/lang/Object;)I
move-result p0
:goto_0
return p0
.end method
.method public incidentEdgeOrder()Lcom/google/common/graph/ElementOrder;
.locals 0
.annotation system Ldalvik/annotation/Signature;
value = {
"()",
"Lcom/google/common/graph/ElementOrder<",
"TN;>;"
}
.end annotation
.line 102
invoke-static {}, Lcom/google/common/graph/ElementOrder;->unordered()Lcom/google/common/graph/ElementOrder;
move-result-object p0
return-object p0
.end method
.method public incidentEdges(Ljava/lang/Object;)Ljava/util/Set;
.locals 2
.annotation system Ldalvik/annotation/Signature;
value = {
"(TN;)",
"Ljava/util/Set<",
"Lcom/google/common/graph/EndpointPair<",
"TN;>;>;"
}
.end annotation
.line 107
invoke-static {p1}, Lcom/google/common/base/Preconditions;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
.line 108
invoke-virtual {p0}, Lcom/google/common/graph/AbstractBaseGraph;->nodes()Ljava/util/Set;
move-result-object v0
invoke-interface {v0, p1}, Ljava/util/Set;->contains(Ljava/lang/Object;)Z
move-result v0
const-string v1, "Node %s is not an element of this graph."
invoke-static {v0, v1, p1}, Lcom/google/common/base/Preconditions;->checkArgument(ZLjava/lang/String;Ljava/lang/Object;)V
.line 109
new-instance v0, Lcom/google/common/graph/AbstractBaseGraph$2;
invoke-direct {v0, p0, p0, p1}, Lcom/google/common/graph/AbstractBaseGraph$2;-><init>(Lcom/google/common/graph/AbstractBaseGraph;Lcom/google/common/graph/BaseGraph;Ljava/lang/Object;)V
return-object v0
.end method
.method protected final isOrderingCompatible(Lcom/google/common/graph/EndpointPair;)Z
.locals 0
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lcom/google/common/graph/EndpointPair<",
"*>;)Z"
}
.end annotation
.line 181
invoke-virtual {p1}, Lcom/google/common/graph/EndpointPair;->isOrdered()Z
move-result p1
if-nez p1, :cond_1
invoke-virtual {p0}, Lcom/google/common/graph/AbstractBaseGraph;->isDirected()Z
move-result p0
if-nez p0, :cond_0
goto :goto_0
:cond_0
const/4 p0, 0x0
goto :goto_1
:cond_1
:goto_0
const/4 p0, 0x1
:goto_1
return p0
.end method
.method public outDegree(Ljava/lang/Object;)I
.locals 1
.annotation system Ldalvik/annotation/Signature;
value = {
"(TN;)I"
}
.end annotation
.line 150
invoke-virtual {p0}, Lcom/google/common/graph/AbstractBaseGraph;->isDirected()Z
move-result v0
if-eqz v0, :cond_0
invoke-virtual {p0, p1}, Lcom/google/common/graph/AbstractBaseGraph;->successors(Ljava/lang/Object;)Ljava/util/Set;
move-result-object p0
invoke-interface {p0}, Ljava/util/Set;->size()I
move-result p0
goto :goto_0
:cond_0
invoke-virtual {p0, p1}, Lcom/google/common/graph/AbstractBaseGraph;->degree(Ljava/lang/Object;)I
move-result p0
:goto_0
return p0
.end method
.method protected final validateEndpoints(Lcom/google/common/graph/EndpointPair;)V
.locals 0
.annotation system Ldalvik/annotation/Signature;
value = {
"(",
"Lcom/google/common/graph/EndpointPair<",
"*>;)V"
}
.end annotation
.line 176
invoke-static {p1}, Lcom/google/common/base/Preconditions;->checkNotNull(Ljava/lang/Object;)Ljava/lang/Object;
.line 177
invoke-virtual {p0, p1}, Lcom/google/common/graph/AbstractBaseGraph;->isOrderingCompatible(Lcom/google/common/graph/EndpointPair;)Z
move-result p0
const-string p1, "Mismatch: unordered endpoints cannot be used with directed graphs"
invoke-static {p0, p1}, Lcom/google/common/base/Preconditions;->checkArgument(ZLjava/lang/Object;)V
return-void
.end method