abstract class com.google.common.graph.AbstractBaseGraph<N> implements com.google.common.graph.BaseGraph<N>
  minor version: 0
  major version: 59
  flags: flags: (0x0420) ACC_SUPER, ACC_ABSTRACT
  this_class: com.google.common.graph.AbstractBaseGraph
  super_class: java.lang.Object
{
  void <init>();
    descriptor: ()V
    flags: (0x0000) 
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.google.common.graph.AbstractBaseGraph this
         0: .line 44
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // com.google.common.graph.AbstractBaseGraph this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/google/common/graph/AbstractBaseGraph<TN;>;

  protected long edgeCount();
    descriptor: ()J
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=4, locals=5, args_size=1
        start local 0 // com.google.common.graph.AbstractBaseGraph this
         0: .line 52
            lconst_0
            lstore 1 /* degreeSum */
        start local 1 // long degreeSum
         1: .line 53
            aload 0 /* this */
            invokevirtual com.google.common.graph.AbstractBaseGraph.nodes:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 4
            goto 4
      StackMap locals: com.google.common.graph.AbstractBaseGraph long top java.util.Iterator
      StackMap stack:
         2: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.lang.Object
            astore 3 /* node */
        start local 3 // java.lang.Object node
         3: .line 54
            lload 1 /* degreeSum */
            aload 0 /* this */
            aload 3 /* node */
            invokevirtual com.google.common.graph.AbstractBaseGraph.degree:(Ljava/lang/Object;)I
            i2l
            ladd
            lstore 1 /* degreeSum */
        end local 3 // java.lang.Object node
         4: .line 53
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 57
            lload 1 /* degreeSum */
            lconst_1
            land
            lconst_0
            lcmp
            ifne 6
            iconst_1
            goto 7
      StackMap locals: com.google.common.graph.AbstractBaseGraph long
      StackMap stack:
         6: iconst_0
      StackMap locals:
      StackMap stack: int
         7: invokestatic com.google.common.base.Preconditions.checkState:(Z)V
         8: .line 58
            lload 1 /* degreeSum */
            iconst_1
            lushr
            lreturn
        end local 1 // long degreeSum
        end local 0 // com.google.common.graph.AbstractBaseGraph this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    9     0       this  Lcom/google/common/graph/AbstractBaseGraph<TN;>;
            1    9     1  degreeSum  J
            3    4     3       node  TN;

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

  public com.google.common.graph.ElementOrder<N> incidentEdgeOrder();
    descriptor: ()Lcom/google/common/graph/ElementOrder;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // com.google.common.graph.AbstractBaseGraph this
         0: .line 102
            invokestatic com.google.common.graph.ElementOrder.unordered:()Lcom/google/common/graph/ElementOrder;
            areturn
        end local 0 // com.google.common.graph.AbstractBaseGraph this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lcom/google/common/graph/AbstractBaseGraph<TN;>;
    Signature: ()Lcom/google/common/graph/ElementOrder<TN;>;

  public java.util.Set<com.google.common.graph.EndpointPair<N>> incidentEdges(N);
    descriptor: (Ljava/lang/Object;)Ljava/util/Set;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // com.google.common.graph.AbstractBaseGraph this
        start local 1 // java.lang.Object node
         0: .line 107
            aload 1 /* node */
            invokestatic com.google.common.base.Preconditions.checkNotNull:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         1: .line 108
            aload 0 /* this */
            invokevirtual com.google.common.graph.AbstractBaseGraph.nodes:()Ljava/util/Set;
            aload 1 /* node */
            invokeinterface java.util.Set.contains:(Ljava/lang/Object;)Z
            ldc "Node %s is not an element of this graph."
            aload 1 /* node */
            invokestatic com.google.common.base.Preconditions.checkArgument:(ZLjava/lang/String;Ljava/lang/Object;)V
         2: .line 109
            new com.google.common.graph.AbstractBaseGraph$2
            dup
            aload 0 /* this */
            aload 0 /* this */
            aload 1 /* node */
            invokespecial com.google.common.graph.AbstractBaseGraph$2.<init>:(Lcom/google/common/graph/AbstractBaseGraph;Lcom/google/common/graph/BaseGraph;Ljava/lang/Object;)V
            areturn
        end local 1 // java.lang.Object node
        end local 0 // com.google.common.graph.AbstractBaseGraph this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lcom/google/common/graph/AbstractBaseGraph<TN;>;
            0    3     1  node  TN;
    Signature: (TN;)Ljava/util/Set<Lcom/google/common/graph/EndpointPair<TN;>;>;
    MethodParameters:
      Name  Flags
      node  

  public int degree();
    descriptor: (Ljava/lang/Object;)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=2
        start local 0 // com.google.common.graph.AbstractBaseGraph this
        start local 1 // java.lang.Object node
         0: .line 149
            aload 0 /* this */
            invokevirtual com.google.common.graph.AbstractBaseGraph.isDirected:()Z
            ifeq 2
         1: .line 150
            aload 0 /* this */
            aload 1 /* node */
            invokevirtual com.google.common.graph.AbstractBaseGraph.predecessors:(Ljava/lang/Object;)Ljava/util/Set;
            invokeinterface java.util.Set.size:()I
            aload 0 /* this */
            aload 1 /* node */
            invokevirtual com.google.common.graph.AbstractBaseGraph.successors:(Ljava/lang/Object;)Ljava/util/Set;
            invokeinterface java.util.Set.size:()I
            invokestatic com.google.common.math.IntMath.saturatedAdd:(II)I
            ireturn
         2: .line 152
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* node */
            invokevirtual com.google.common.graph.AbstractBaseGraph.adjacentNodes:(Ljava/lang/Object;)Ljava/util/Set;
            astore 2 /* neighbors */
        start local 2 // java.util.Set neighbors
         3: .line 153
            aload 0 /* this */
            invokevirtual com.google.common.graph.AbstractBaseGraph.allowsSelfLoops:()Z
            ifeq 4
            aload 2 /* neighbors */
            aload 1 /* node */
            invokeinterface java.util.Set.contains:(Ljava/lang/Object;)Z
            ifeq 4
            iconst_1
            goto 5
      StackMap locals: java.util.Set
      StackMap stack:
         4: iconst_0
      StackMap locals:
      StackMap stack: int
         5: istore 3 /* selfLoopCount */
        start local 3 // int selfLoopCount
         6: .line 154
            aload 2 /* neighbors */
            invokeinterface java.util.Set.size:()I
            iload 3 /* selfLoopCount */
            invokestatic com.google.common.math.IntMath.saturatedAdd:(II)I
            ireturn
        end local 3 // int selfLoopCount
        end local 2 // java.util.Set neighbors
        end local 1 // java.lang.Object node
        end local 0 // com.google.common.graph.AbstractBaseGraph this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    7     0           this  Lcom/google/common/graph/AbstractBaseGraph<TN;>;
            0    7     1           node  TN;
            3    7     2      neighbors  Ljava/util/Set<TN;>;
            6    7     3  selfLoopCount  I
    Signature: (TN;)I
    MethodParameters:
      Name  Flags
      node  

  public int inDegree();
    descriptor: (Ljava/lang/Object;)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // com.google.common.graph.AbstractBaseGraph this
        start local 1 // java.lang.Object node
         0: .line 160
            aload 0 /* this */
            invokevirtual com.google.common.graph.AbstractBaseGraph.isDirected:()Z
            ifeq 1
            aload 0 /* this */
            aload 1 /* node */
            invokevirtual com.google.common.graph.AbstractBaseGraph.predecessors:(Ljava/lang/Object;)Ljava/util/Set;
            invokeinterface java.util.Set.size:()I
            goto 2
      StackMap locals:
      StackMap stack:
         1: aload 0 /* this */
            aload 1 /* node */
            invokevirtual com.google.common.graph.AbstractBaseGraph.degree:(Ljava/lang/Object;)I
      StackMap locals:
      StackMap stack: int
         2: ireturn
        end local 1 // java.lang.Object node
        end local 0 // com.google.common.graph.AbstractBaseGraph this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lcom/google/common/graph/AbstractBaseGraph<TN;>;
            0    3     1  node  TN;
    Signature: (TN;)I
    MethodParameters:
      Name  Flags
      node  

  public int outDegree();
    descriptor: (Ljava/lang/Object;)I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // com.google.common.graph.AbstractBaseGraph this
        start local 1 // java.lang.Object node
         0: .line 165
            aload 0 /* this */
            invokevirtual com.google.common.graph.AbstractBaseGraph.isDirected:()Z
            ifeq 1
            aload 0 /* this */
            aload 1 /* node */
            invokevirtual com.google.common.graph.AbstractBaseGraph.successors:(Ljava/lang/Object;)Ljava/util/Set;
            invokeinterface java.util.Set.size:()I
            goto 2
      StackMap locals:
      StackMap stack:
         1: aload 0 /* this */
            aload 1 /* node */
            invokevirtual com.google.common.graph.AbstractBaseGraph.degree:(Ljava/lang/Object;)I
      StackMap locals:
      StackMap stack: int
         2: ireturn
        end local 1 // java.lang.Object node
        end local 0 // com.google.common.graph.AbstractBaseGraph this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lcom/google/common/graph/AbstractBaseGraph<TN;>;
            0    3     1  node  TN;
    Signature: (TN;)I
    MethodParameters:
      Name  Flags
      node  

  public boolean hasEdgeConnecting(N, );
    descriptor: (Ljava/lang/Object;Ljava/lang/Object;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // com.google.common.graph.AbstractBaseGraph this
        start local 1 // java.lang.Object nodeU
        start local 2 // java.lang.Object nodeV
         0: .line 170
            aload 1 /* nodeU */
            invokestatic com.google.common.base.Preconditions.checkNotNull:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         1: .line 171
            aload 2 /* nodeV */
            invokestatic com.google.common.base.Preconditions.checkNotNull:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         2: .line 172
            aload 0 /* this */
            invokevirtual com.google.common.graph.AbstractBaseGraph.nodes:()Ljava/util/Set;
            aload 1 /* nodeU */
            invokeinterface java.util.Set.contains:(Ljava/lang/Object;)Z
            ifeq 3
            aload 0 /* this */
            aload 1 /* nodeU */
            invokevirtual com.google.common.graph.AbstractBaseGraph.successors:(Ljava/lang/Object;)Ljava/util/Set;
            aload 2 /* nodeV */
            invokeinterface java.util.Set.contains:(Ljava/lang/Object;)Z
            ifeq 3
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         3: iconst_0
            ireturn
        end local 2 // java.lang.Object nodeV
        end local 1 // java.lang.Object nodeU
        end local 0 // com.google.common.graph.AbstractBaseGraph this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    4     0   this  Lcom/google/common/graph/AbstractBaseGraph<TN;>;
            0    4     1  nodeU  TN;
            0    4     2  nodeV  TN;
    Signature: (TN;TN;)Z
    MethodParameters:
       Name  Flags
      nodeU  
      nodeV  

  public boolean hasEdgeConnecting(com.google.common.graph.EndpointPair<N>);
    descriptor: (Lcom/google/common/graph/EndpointPair;)Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // com.google.common.graph.AbstractBaseGraph this
        start local 1 // com.google.common.graph.EndpointPair endpoints
         0: .line 177
            aload 1 /* endpoints */
            invokestatic com.google.common.base.Preconditions.checkNotNull:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         1: .line 178
            aload 0 /* this */
            aload 1 /* endpoints */
            invokevirtual com.google.common.graph.AbstractBaseGraph.isOrderingCompatible:(Lcom/google/common/graph/EndpointPair;)Z
            ifne 3
         2: .line 179
            iconst_0
            ireturn
         3: .line 181
      StackMap locals:
      StackMap stack:
            aload 1 /* endpoints */
            invokevirtual com.google.common.graph.EndpointPair.nodeU:()Ljava/lang/Object;
            astore 2 /* nodeU */
        start local 2 // java.lang.Object nodeU
         4: .line 182
            aload 1 /* endpoints */
            invokevirtual com.google.common.graph.EndpointPair.nodeV:()Ljava/lang/Object;
            astore 3 /* nodeV */
        start local 3 // java.lang.Object nodeV
         5: .line 183
            aload 0 /* this */
            invokevirtual com.google.common.graph.AbstractBaseGraph.nodes:()Ljava/util/Set;
            aload 2 /* nodeU */
            invokeinterface java.util.Set.contains:(Ljava/lang/Object;)Z
            ifeq 6
            aload 0 /* this */
            aload 2 /* nodeU */
            invokevirtual com.google.common.graph.AbstractBaseGraph.successors:(Ljava/lang/Object;)Ljava/util/Set;
            aload 3 /* nodeV */
            invokeinterface java.util.Set.contains:(Ljava/lang/Object;)Z
            ifeq 6
            iconst_1
            ireturn
      StackMap locals: java.lang.Object java.lang.Object
      StackMap stack:
         6: iconst_0
            ireturn
        end local 3 // java.lang.Object nodeV
        end local 2 // java.lang.Object nodeU
        end local 1 // com.google.common.graph.EndpointPair endpoints
        end local 0 // com.google.common.graph.AbstractBaseGraph this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    7     0       this  Lcom/google/common/graph/AbstractBaseGraph<TN;>;
            0    7     1  endpoints  Lcom/google/common/graph/EndpointPair<TN;>;
            4    7     2      nodeU  TN;
            5    7     3      nodeV  TN;
    Signature: (Lcom/google/common/graph/EndpointPair<TN;>;)Z
    MethodParameters:
           Name  Flags
      endpoints  

  protected final void validateEndpoints(com.google.common.graph.EndpointPair<?>);
    descriptor: (Lcom/google/common/graph/EndpointPair;)V
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // com.google.common.graph.AbstractBaseGraph this
        start local 1 // com.google.common.graph.EndpointPair endpoints
         0: .line 191
            aload 1 /* endpoints */
            invokestatic com.google.common.base.Preconditions.checkNotNull:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         1: .line 192
            aload 0 /* this */
            aload 1 /* endpoints */
            invokevirtual com.google.common.graph.AbstractBaseGraph.isOrderingCompatible:(Lcom/google/common/graph/EndpointPair;)Z
            ldc "Mismatch: unordered endpoints cannot be used with directed graphs"
            invokestatic com.google.common.base.Preconditions.checkArgument:(ZLjava/lang/Object;)V
         2: .line 193
            return
        end local 1 // com.google.common.graph.EndpointPair endpoints
        end local 0 // com.google.common.graph.AbstractBaseGraph this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    3     0       this  Lcom/google/common/graph/AbstractBaseGraph<TN;>;
            0    3     1  endpoints  Lcom/google/common/graph/EndpointPair<*>;
    Signature: (Lcom/google/common/graph/EndpointPair<*>;)V
    MethodParameters:
           Name  Flags
      endpoints  

  protected final boolean isOrderingCompatible(com.google.common.graph.EndpointPair<?>);
    descriptor: (Lcom/google/common/graph/EndpointPair;)Z
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // com.google.common.graph.AbstractBaseGraph this
        start local 1 // com.google.common.graph.EndpointPair endpoints
         0: .line 196
            aload 1 /* endpoints */
            invokevirtual com.google.common.graph.EndpointPair.isOrdered:()Z
            ifne 1
            aload 0 /* this */
            invokevirtual com.google.common.graph.AbstractBaseGraph.isDirected:()Z
            ifeq 1
            iconst_0
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_1
            ireturn
        end local 1 // com.google.common.graph.EndpointPair endpoints
        end local 0 // com.google.common.graph.AbstractBaseGraph this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    2     0       this  Lcom/google/common/graph/AbstractBaseGraph<TN;>;
            0    2     1  endpoints  Lcom/google/common/graph/EndpointPair<*>;
    Signature: (Lcom/google/common/graph/EndpointPair<*>;)Z
    MethodParameters:
           Name  Flags
      endpoints  
}
Signature: <N:Ljava/lang/Object;>Ljava/lang/Object;Lcom/google/common/graph/BaseGraph<TN;>;
SourceFile: "AbstractBaseGraph.java"
NestMembers:
  com.google.common.graph.AbstractBaseGraph$1  com.google.common.graph.AbstractBaseGraph$2  com.google.common.graph.AbstractBaseGraph$2$1  com.google.common.graph.AbstractBaseGraph$2$2  com.google.common.graph.AbstractBaseGraph$2$3
InnerClasses:
  com.google.common.graph.AbstractBaseGraph$1
  com.google.common.graph.AbstractBaseGraph$2