class com.sun.tools.jdeps.Graph$TopoSorter<T>
minor version: 0
major version: 59
flags: flags: (0x0020) ACC_SUPER
this_class: com.sun.tools.jdeps.Graph$TopoSorter
super_class: java.lang.Object
{
final java.util.Deque<T> result;
descriptor: Ljava/util/Deque;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/Deque<TT;>;
final java.util.Deque<T> nodes;
descriptor: Ljava/util/Deque;
flags: (0x0010) ACC_FINAL
Signature: Ljava/util/Deque<TT;>;
final com.sun.tools.jdeps.Graph<T> graph;
descriptor: Lcom/sun/tools/jdeps/Graph;
flags: (0x0010) ACC_FINAL
Signature: Lcom/sun/tools/jdeps/Graph<TT;>;
void <init>(com.sun.tools.jdeps.Graph<T>);
descriptor: (Lcom/sun/tools/jdeps/Graph;)V
flags: (0x0000)
Code:
stack=4, locals=2, args_size=2
start local 0 start local 1 0: aload 0
invokespecial java.lang.Object.<init>:()V
1: aload 0
new java.util.LinkedList
dup
invokespecial java.util.LinkedList.<init>:()V
putfield com.sun.tools.jdeps.Graph$TopoSorter.result:Ljava/util/Deque;
2: aload 0
aload 1
putfield com.sun.tools.jdeps.Graph$TopoSorter.graph:Lcom/sun/tools/jdeps/Graph;
3: aload 0
new java.util.LinkedList
dup
aload 1
getfield com.sun.tools.jdeps.Graph.nodes:Ljava/util/Set;
invokespecial java.util.LinkedList.<init>:(Ljava/util/Collection;)V
putfield com.sun.tools.jdeps.Graph$TopoSorter.nodes:Ljava/util/Deque;
4: aload 0
invokevirtual com.sun.tools.jdeps.Graph$TopoSorter.sort:()V
5: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 6 0 this Lcom/sun/tools/jdeps/Graph$TopoSorter<TT;>;
0 6 1 graph Lcom/sun/tools/jdeps/Graph<TT;>;
Signature: (Lcom/sun/tools/jdeps/Graph<TT;>;)V
MethodParameters:
Name Flags
graph
public void ordered(java.util.function.Consumer<T>);
descriptor: (Ljava/util/function/Consumer;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield com.sun.tools.jdeps.Graph$TopoSorter.result:Ljava/util/Deque;
invokeinterface java.util.Deque.iterator:()Ljava/util/Iterator;
aload 1
invokeinterface java.util.Iterator.forEachRemaining:(Ljava/util/function/Consumer;)V
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lcom/sun/tools/jdeps/Graph$TopoSorter<TT;>;
0 2 1 action Ljava/util/function/Consumer<TT;>;
Signature: (Ljava/util/function/Consumer<TT;>;)V
MethodParameters:
Name Flags
action
public void reverse(java.util.function.Consumer<T>);
descriptor: (Ljava/util/function/Consumer;)V
flags: (0x0001) ACC_PUBLIC
Code:
stack=2, locals=2, args_size=2
start local 0 start local 1 0: aload 0
getfield com.sun.tools.jdeps.Graph$TopoSorter.result:Ljava/util/Deque;
invokeinterface java.util.Deque.descendingIterator:()Ljava/util/Iterator;
aload 1
invokeinterface java.util.Iterator.forEachRemaining:(Ljava/util/function/Consumer;)V
1: return
end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 2 0 this Lcom/sun/tools/jdeps/Graph$TopoSorter<TT;>;
0 2 1 action Ljava/util/function/Consumer<TT;>;
Signature: (Ljava/util/function/Consumer<TT;>;)V
MethodParameters:
Name Flags
action
private void sort();
descriptor: ()V
flags: (0x0002) ACC_PRIVATE
Code:
stack=4, locals=4, args_size=1
start local 0 0: new java.util.LinkedList
dup
invokespecial java.util.LinkedList.<init>:()V
astore 1
start local 1 1: new java.util.LinkedList
dup
invokespecial java.util.LinkedList.<init>:()V
astore 2
start local 2 2: goto 5
start local 3 3: StackMap locals: java.util.Deque java.util.Deque java.lang.Object
StackMap stack:
aload 1
aload 3
invokeinterface java.util.Deque.contains:(Ljava/lang/Object;)Z
ifne 5
4: aload 0
aload 3
aload 1
aload 2
invokevirtual com.sun.tools.jdeps.Graph$TopoSorter.visit:(Ljava/lang/Object;Ljava/util/Deque;Ljava/util/Deque;)V
end local 3 5: StackMap locals:
StackMap stack:
aload 0
getfield com.sun.tools.jdeps.Graph$TopoSorter.nodes:Ljava/util/Deque;
invokeinterface java.util.Deque.poll:()Ljava/lang/Object;
dup
astore 3
start local 3 6: ifnonnull 3
7: return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 8 0 this Lcom/sun/tools/jdeps/Graph$TopoSorter<TT;>;
1 8 1 visited Ljava/util/Deque<TT;>;
2 8 2 done Ljava/util/Deque<TT;>;
3 5 3 node TT;
6 8 3 node TT;
private void visit(T, java.util.Deque<T>, java.util.Deque<T>);
descriptor: (Ljava/lang/Object;Ljava/util/Deque;Ljava/util/Deque;)V
flags: (0x0002) ACC_PRIVATE
Code:
stack=5, locals=4, args_size=4
start local 0 start local 1 start local 2 start local 3 0: aload 2
aload 1
invokeinterface java.util.Deque.contains:(Ljava/lang/Object;)Z
ifeq 6
1: aload 3
aload 1
invokeinterface java.util.Deque.contains:(Ljava/lang/Object;)Z
ifne 5
2: new java.lang.IllegalArgumentException
dup
new java.lang.StringBuilder
dup
ldc "Cyclic detected: "
invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
3: aload 1
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
ldc " "
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
aload 0
getfield com.sun.tools.jdeps.Graph$TopoSorter.graph:Lcom/sun/tools/jdeps/Graph;
invokevirtual com.sun.tools.jdeps.Graph.edges:()Ljava/util/Map;
aload 1
invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
4: invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
athrow
5: StackMap locals:
StackMap stack:
return
6: StackMap locals:
StackMap stack:
aload 2
aload 1
invokeinterface java.util.Deque.add:(Ljava/lang/Object;)Z
pop
7: aload 0
getfield com.sun.tools.jdeps.Graph$TopoSorter.graph:Lcom/sun/tools/jdeps/Graph;
invokevirtual com.sun.tools.jdeps.Graph.edges:()Ljava/util/Map;
aload 1
invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
checkcast java.util.Set
invokeinterface java.util.Set.stream:()Ljava/util/stream/Stream;
8: aload 0
aload 2
aload 3
invokedynamic accept(Lcom/sun/tools/jdeps/Graph$TopoSorter;Ljava/util/Deque;Ljava/util/Deque;)Ljava/util/function/Consumer;
Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
Method arguments:
(Ljava/lang/Object;)V
com/sun/tools/jdeps/Graph$TopoSorter.lambda$0(Ljava/util/Deque;Ljava/util/Deque;Ljava/lang/Object;)V (7)
(Ljava/lang/Object;)V
invokeinterface java.util.stream.Stream.forEach:(Ljava/util/function/Consumer;)V
9: aload 3
aload 1
invokeinterface java.util.Deque.add:(Ljava/lang/Object;)Z
pop
10: aload 0
getfield com.sun.tools.jdeps.Graph$TopoSorter.result:Ljava/util/Deque;
aload 1
invokeinterface java.util.Deque.addLast:(Ljava/lang/Object;)V
11: return
end local 3 end local 2 end local 1 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 12 0 this Lcom/sun/tools/jdeps/Graph$TopoSorter<TT;>;
0 12 1 node TT;
0 12 2 visited Ljava/util/Deque<TT;>;
0 12 3 done Ljava/util/Deque<TT;>;
Signature: (TT;Ljava/util/Deque<TT;>;Ljava/util/Deque<TT;>;)V
MethodParameters:
Name Flags
node
visited
done
private void lambda$0(java.util.Deque, java.util.Deque, java.lang.Object);
descriptor: (Ljava/util/Deque;Ljava/util/Deque;Ljava/lang/Object;)V
flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
Code:
stack=4, locals=4, args_size=4
start local 0 start local 3 0: aload 0
aload 3
aload 1
aload 2
invokevirtual com.sun.tools.jdeps.Graph$TopoSorter.visit:(Ljava/lang/Object;Ljava/util/Deque;Ljava/util/Deque;)V
return
end local 3 end local 0 LocalVariableTable:
Start End Slot Name Signature
0 1 0 this Lcom/sun/tools/jdeps/Graph$TopoSorter<TT;>;
0 1 3 x TT;
}
Signature: <T:Ljava/lang/Object;>Ljava/lang/Object;
SourceFile: "Graph.java"
NestHost: com.sun.tools.jdeps.Graph
InnerClasses:
TopoSorter = com.sun.tools.jdeps.Graph$TopoSorter of com.sun.tools.jdeps.Graph
public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles