abstract class com.google.common.graph.AbstractDirectedNetworkConnections<N, E> implements com.google.common.graph.NetworkConnections<N, E>
  minor version: 0
  major version: 59
  flags: flags: (0x0420) ACC_SUPER, ACC_ABSTRACT
  this_class: com.google.common.graph.AbstractDirectedNetworkConnections
  super_class: java.lang.Object
{
  protected final java.util.Map<E, N> inEdgeMap;
    descriptor: Ljava/util/Map;
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL
    Signature: Ljava/util/Map<TE;TN;>;

  protected final java.util.Map<E, N> outEdgeMap;
    descriptor: Ljava/util/Map;
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL
    Signature: Ljava/util/Map<TE;TN;>;

  private int selfLoopCount;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE

  protected void <init>(java.util.Map<E, N>, java.util.Map<E, N>, );
    descriptor: (Ljava/util/Map;Ljava/util/Map;I)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=4, args_size=4
        start local 0 // com.google.common.graph.AbstractDirectedNetworkConnections this
        start local 1 // java.util.Map inEdgeMap
        start local 2 // java.util.Map outEdgeMap
        start local 3 // int selfLoopCount
         0: .line 51
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 53
            aload 0 /* this */
            aload 1 /* inEdgeMap */
            invokestatic com.google.common.base.Preconditions.checkNotNull:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.util.Map
            putfield com.google.common.graph.AbstractDirectedNetworkConnections.inEdgeMap:Ljava/util/Map;
         2: .line 54
            aload 0 /* this */
            aload 2 /* outEdgeMap */
            invokestatic com.google.common.base.Preconditions.checkNotNull:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.util.Map
            putfield com.google.common.graph.AbstractDirectedNetworkConnections.outEdgeMap:Ljava/util/Map;
         3: .line 55
            aload 0 /* this */
            iload 3 /* selfLoopCount */
            invokestatic com.google.common.graph.Graphs.checkNonNegative:(I)I
            putfield com.google.common.graph.AbstractDirectedNetworkConnections.selfLoopCount:I
         4: .line 56
            iload 3 /* selfLoopCount */
            aload 1 /* inEdgeMap */
            invokeinterface java.util.Map.size:()I
            if_icmpgt 5
            iload 3 /* selfLoopCount */
            aload 2 /* outEdgeMap */
            invokeinterface java.util.Map.size:()I
            if_icmpgt 5
            iconst_1
            goto 6
      StackMap locals: com.google.common.graph.AbstractDirectedNetworkConnections java.util.Map java.util.Map int
      StackMap stack:
         5: iconst_0
      StackMap locals:
      StackMap stack: int
         6: invokestatic com.google.common.base.Preconditions.checkState:(Z)V
         7: .line 57
            return
        end local 3 // int selfLoopCount
        end local 2 // java.util.Map outEdgeMap
        end local 1 // java.util.Map inEdgeMap
        end local 0 // com.google.common.graph.AbstractDirectedNetworkConnections this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    8     0           this  Lcom/google/common/graph/AbstractDirectedNetworkConnections<TN;TE;>;
            0    8     1      inEdgeMap  Ljava/util/Map<TE;TN;>;
            0    8     2     outEdgeMap  Ljava/util/Map<TE;TN;>;
            0    8     3  selfLoopCount  I
    Signature: (Ljava/util/Map<TE;TN;>;Ljava/util/Map<TE;TN;>;I)V
    MethodParameters:
               Name  Flags
      inEdgeMap      
      outEdgeMap     
      selfLoopCount  

  public java.util.Set<N> adjacentNodes();
    descriptor: ()Ljava/util/Set;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // com.google.common.graph.AbstractDirectedNetworkConnections this
         0: .line 61
            aload 0 /* this */
            invokevirtual com.google.common.graph.AbstractDirectedNetworkConnections.predecessors:()Ljava/util/Set;
            aload 0 /* this */
            invokevirtual com.google.common.graph.AbstractDirectedNetworkConnections.successors:()Ljava/util/Set;
            invokestatic com.google.common.collect.Sets.union:(Ljava/util/Set;Ljava/util/Set;)Lcom/google/common/collect/Sets$SetView;
            areturn
        end local 0 // com.google.common.graph.AbstractDirectedNetworkConnections this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/google/common/graph/AbstractDirectedNetworkConnections<TN;TE;>;
    Signature: ()Ljava/util/Set<TN;>;

  public java.util.Set<E> incidentEdges();
    descriptor: ()Ljava/util/Set;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // com.google.common.graph.AbstractDirectedNetworkConnections this
         0: .line 66
            new com.google.common.graph.AbstractDirectedNetworkConnections$1
            dup
            aload 0 /* this */
            invokespecial com.google.common.graph.AbstractDirectedNetworkConnections$1.<init>:(Lcom/google/common/graph/AbstractDirectedNetworkConnections;)V
            areturn
        end local 0 // com.google.common.graph.AbstractDirectedNetworkConnections this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/google/common/graph/AbstractDirectedNetworkConnections<TN;TE;>;
    Signature: ()Ljava/util/Set<TE;>;

  public java.util.Set<E> inEdges();
    descriptor: ()Ljava/util/Set;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.google.common.graph.AbstractDirectedNetworkConnections this
         0: .line 90
            aload 0 /* this */
            getfield com.google.common.graph.AbstractDirectedNetworkConnections.inEdgeMap:Ljava/util/Map;
            invokeinterface java.util.Map.keySet:()Ljava/util/Set;
            invokestatic java.util.Collections.unmodifiableSet:(Ljava/util/Set;)Ljava/util/Set;
            areturn
        end local 0 // com.google.common.graph.AbstractDirectedNetworkConnections this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/google/common/graph/AbstractDirectedNetworkConnections<TN;TE;>;
    Signature: ()Ljava/util/Set<TE;>;

  public java.util.Set<E> outEdges();
    descriptor: ()Ljava/util/Set;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.google.common.graph.AbstractDirectedNetworkConnections this
         0: .line 95
            aload 0 /* this */
            getfield com.google.common.graph.AbstractDirectedNetworkConnections.outEdgeMap:Ljava/util/Map;
            invokeinterface java.util.Map.keySet:()Ljava/util/Set;
            invokestatic java.util.Collections.unmodifiableSet:(Ljava/util/Set;)Ljava/util/Set;
            areturn
        end local 0 // com.google.common.graph.AbstractDirectedNetworkConnections this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/google/common/graph/AbstractDirectedNetworkConnections<TN;TE;>;
    Signature: ()Ljava/util/Set<TE;>;

  public N adjacentNode();
    descriptor: (Ljava/lang/Object;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // com.google.common.graph.AbstractDirectedNetworkConnections this
        start local 1 // java.lang.Object edge
         0: .line 102
            aload 0 /* this */
            getfield com.google.common.graph.AbstractDirectedNetworkConnections.outEdgeMap:Ljava/util/Map;
            aload 1 /* edge */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            invokestatic com.google.common.base.Preconditions.checkNotNull:(Ljava/lang/Object;)Ljava/lang/Object;
            areturn
        end local 1 // java.lang.Object edge
        end local 0 // com.google.common.graph.AbstractDirectedNetworkConnections this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/google/common/graph/AbstractDirectedNetworkConnections<TN;TE;>;
            0    1     1  edge  TE;
    Signature: (TE;)TN;
    MethodParameters:
      Name  Flags
      edge  

  public N removeInEdge(E, );
    descriptor: (Ljava/lang/Object;Z)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // com.google.common.graph.AbstractDirectedNetworkConnections this
        start local 1 // java.lang.Object edge
        start local 2 // boolean isSelfLoop
         0: .line 107
            iload 2 /* isSelfLoop */
            ifeq 2
         1: .line 108
            aload 0 /* this */
            dup
            getfield com.google.common.graph.AbstractDirectedNetworkConnections.selfLoopCount:I
            iconst_1
            isub
            dup_x1
            putfield com.google.common.graph.AbstractDirectedNetworkConnections.selfLoopCount:I
            invokestatic com.google.common.graph.Graphs.checkNonNegative:(I)I
            pop
         2: .line 110
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.google.common.graph.AbstractDirectedNetworkConnections.inEdgeMap:Ljava/util/Map;
            aload 1 /* edge */
            invokeinterface java.util.Map.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 3 /* previousNode */
        start local 3 // java.lang.Object previousNode
         3: .line 111
            aload 3 /* previousNode */
            invokestatic com.google.common.base.Preconditions.checkNotNull:(Ljava/lang/Object;)Ljava/lang/Object;
            areturn
        end local 3 // java.lang.Object previousNode
        end local 2 // boolean isSelfLoop
        end local 1 // java.lang.Object edge
        end local 0 // com.google.common.graph.AbstractDirectedNetworkConnections this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    4     0          this  Lcom/google/common/graph/AbstractDirectedNetworkConnections<TN;TE;>;
            0    4     1          edge  TE;
            0    4     2    isSelfLoop  Z
            3    4     3  previousNode  TN;
    Signature: (TE;Z)TN;
    MethodParameters:
            Name  Flags
      edge        
      isSelfLoop  

  public N removeOutEdge();
    descriptor: (Ljava/lang/Object;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // com.google.common.graph.AbstractDirectedNetworkConnections this
        start local 1 // java.lang.Object edge
         0: .line 116
            aload 0 /* this */
            getfield com.google.common.graph.AbstractDirectedNetworkConnections.outEdgeMap:Ljava/util/Map;
            aload 1 /* edge */
            invokeinterface java.util.Map.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            astore 2 /* previousNode */
        start local 2 // java.lang.Object previousNode
         1: .line 117
            aload 2 /* previousNode */
            invokestatic com.google.common.base.Preconditions.checkNotNull:(Ljava/lang/Object;)Ljava/lang/Object;
            areturn
        end local 2 // java.lang.Object previousNode
        end local 1 // java.lang.Object edge
        end local 0 // com.google.common.graph.AbstractDirectedNetworkConnections this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    2     0          this  Lcom/google/common/graph/AbstractDirectedNetworkConnections<TN;TE;>;
            0    2     1          edge  TE;
            1    2     2  previousNode  TN;
    Signature: (TE;)TN;
    MethodParameters:
      Name  Flags
      edge  

  public void addInEdge(E, N, );
    descriptor: (Ljava/lang/Object;Ljava/lang/Object;Z)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=5, args_size=4
        start local 0 // com.google.common.graph.AbstractDirectedNetworkConnections this
        start local 1 // java.lang.Object edge
        start local 2 // java.lang.Object node
        start local 3 // boolean isSelfLoop
         0: .line 122
            iload 3 /* isSelfLoop */
            ifeq 2
         1: .line 123
            aload 0 /* this */
            dup
            getfield com.google.common.graph.AbstractDirectedNetworkConnections.selfLoopCount:I
            iconst_1
            iadd
            dup_x1
            putfield com.google.common.graph.AbstractDirectedNetworkConnections.selfLoopCount:I
            invokestatic com.google.common.graph.Graphs.checkPositive:(I)I
            pop
         2: .line 125
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield com.google.common.graph.AbstractDirectedNetworkConnections.inEdgeMap:Ljava/util/Map;
            aload 1 /* edge */
            aload 2 /* node */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            astore 4 /* previousNode */
        start local 4 // java.lang.Object previousNode
         3: .line 126
            aload 4 /* previousNode */
            ifnonnull 4
            iconst_1
            goto 5
      StackMap locals: java.lang.Object
      StackMap stack:
         4: iconst_0
      StackMap locals:
      StackMap stack: int
         5: invokestatic com.google.common.base.Preconditions.checkState:(Z)V
         6: .line 127
            return
        end local 4 // java.lang.Object previousNode
        end local 3 // boolean isSelfLoop
        end local 2 // java.lang.Object node
        end local 1 // java.lang.Object edge
        end local 0 // com.google.common.graph.AbstractDirectedNetworkConnections this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    7     0          this  Lcom/google/common/graph/AbstractDirectedNetworkConnections<TN;TE;>;
            0    7     1          edge  TE;
            0    7     2          node  TN;
            0    7     3    isSelfLoop  Z
            3    7     4  previousNode  TN;
    Signature: (TE;TN;Z)V
    MethodParameters:
            Name  Flags
      edge        
      node        
      isSelfLoop  

  public void addOutEdge(E, );
    descriptor: (Ljava/lang/Object;Ljava/lang/Object;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=3
        start local 0 // com.google.common.graph.AbstractDirectedNetworkConnections this
        start local 1 // java.lang.Object edge
        start local 2 // java.lang.Object node
         0: .line 131
            aload 0 /* this */
            getfield com.google.common.graph.AbstractDirectedNetworkConnections.outEdgeMap:Ljava/util/Map;
            aload 1 /* edge */
            aload 2 /* node */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            astore 3 /* previousNode */
        start local 3 // java.lang.Object previousNode
         1: .line 132
            aload 3 /* previousNode */
            ifnonnull 2
            iconst_1
            goto 3
      StackMap locals: java.lang.Object
      StackMap stack:
         2: iconst_0
      StackMap locals:
      StackMap stack: int
         3: invokestatic com.google.common.base.Preconditions.checkState:(Z)V
         4: .line 133
            return
        end local 3 // java.lang.Object previousNode
        end local 2 // java.lang.Object node
        end local 1 // java.lang.Object edge
        end local 0 // com.google.common.graph.AbstractDirectedNetworkConnections this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    5     0          this  Lcom/google/common/graph/AbstractDirectedNetworkConnections<TN;TE;>;
            0    5     1          edge  TE;
            0    5     2          node  TN;
            1    5     3  previousNode  TN;
    Signature: (TE;TN;)V
    MethodParameters:
      Name  Flags
      edge  
      node  
}
Signature: <N:Ljava/lang/Object;E:Ljava/lang/Object;>Ljava/lang/Object;Lcom/google/common/graph/NetworkConnections<TN;TE;>;
SourceFile: "AbstractDirectedNetworkConnections.java"
NestMembers:
  com.google.common.graph.AbstractDirectedNetworkConnections$1
InnerClasses:
  public abstract SetView = com.google.common.collect.Sets$SetView of com.google.common.collect.Sets
  com.google.common.graph.AbstractDirectedNetworkConnections$1