public class org.apache.cassandra.streaming.StreamCoordinator
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.cassandra.streaming.StreamCoordinator
  super_class: java.lang.Object
{
  private static final org.slf4j.Logger logger;
    descriptor: Lorg/slf4j/Logger;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final org.apache.cassandra.concurrent.DebuggableThreadPoolExecutor streamExecutor;
    descriptor: Lorg/apache/cassandra/concurrent/DebuggableThreadPoolExecutor;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private final boolean connectSequentially;
    descriptor: Z
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private java.util.Map<java.net.InetAddress, org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData> peerSessions;
    descriptor: Ljava/util/Map;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/Map<Ljava/net/InetAddress;Lorg/apache/cassandra/streaming/StreamCoordinator$HostStreamingData;>;

  private final int connectionsPerHost;
    descriptor: I
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private org.apache.cassandra.streaming.StreamConnectionFactory factory;
    descriptor: Lorg/apache/cassandra/streaming/StreamConnectionFactory;
    flags: (0x0002) ACC_PRIVATE

  private final boolean keepSSTableLevel;
    descriptor: Z
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final boolean isIncremental;
    descriptor: Z
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private java.util.Iterator<org.apache.cassandra.streaming.StreamSession> sessionsToConnect;
    descriptor: Ljava/util/Iterator;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/Iterator<Lorg/apache/cassandra/streaming/StreamSession;>;

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=2, locals=0, args_size=0
         0: .line 44
            ldc Lorg/apache/cassandra/streaming/StreamCoordinator;
            invokestatic org.slf4j.LoggerFactory.getLogger:(Ljava/lang/Class;)Lorg/slf4j/Logger;
            putstatic org.apache.cassandra.streaming.StreamCoordinator.logger:Lorg/slf4j/Logger;
         1: .line 48
            ldc "StreamConnectionEstablisher"
         2: .line 49
            invokestatic org.apache.cassandra.utils.FBUtilities.getAvailableProcessors:()I
         3: .line 48
            invokestatic org.apache.cassandra.concurrent.DebuggableThreadPoolExecutor.createWithFixedPoolSize:(Ljava/lang/String;I)Lorg/apache/cassandra/concurrent/DebuggableThreadPoolExecutor;
            putstatic org.apache.cassandra.streaming.StreamCoordinator.streamExecutor:Lorg/apache/cassandra/concurrent/DebuggableThreadPoolExecutor;
         4: .line 49
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>(int, boolean, boolean, org.apache.cassandra.streaming.StreamConnectionFactory, boolean);
    descriptor: (IZZLorg/apache/cassandra/streaming/StreamConnectionFactory;Z)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=6, args_size=6
        start local 0 // org.apache.cassandra.streaming.StreamCoordinator this
        start local 1 // int connectionsPerHost
        start local 2 // boolean keepSSTableLevel
        start local 3 // boolean isIncremental
        start local 4 // org.apache.cassandra.streaming.StreamConnectionFactory factory
        start local 5 // boolean connectSequentially
         0: .line 59
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 52
            aload 0 /* this */
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
            putfield org.apache.cassandra.streaming.StreamCoordinator.peerSessions:Ljava/util/Map;
         2: .line 57
            aload 0 /* this */
            aconst_null
            putfield org.apache.cassandra.streaming.StreamCoordinator.sessionsToConnect:Ljava/util/Iterator;
         3: .line 62
            aload 0 /* this */
            iload 1 /* connectionsPerHost */
            putfield org.apache.cassandra.streaming.StreamCoordinator.connectionsPerHost:I
         4: .line 63
            aload 0 /* this */
            aload 4 /* factory */
            putfield org.apache.cassandra.streaming.StreamCoordinator.factory:Lorg/apache/cassandra/streaming/StreamConnectionFactory;
         5: .line 64
            aload 0 /* this */
            iload 2 /* keepSSTableLevel */
            putfield org.apache.cassandra.streaming.StreamCoordinator.keepSSTableLevel:Z
         6: .line 65
            aload 0 /* this */
            iload 3 /* isIncremental */
            putfield org.apache.cassandra.streaming.StreamCoordinator.isIncremental:Z
         7: .line 66
            aload 0 /* this */
            iload 5 /* connectSequentially */
            putfield org.apache.cassandra.streaming.StreamCoordinator.connectSequentially:Z
         8: .line 67
            return
        end local 5 // boolean connectSequentially
        end local 4 // org.apache.cassandra.streaming.StreamConnectionFactory factory
        end local 3 // boolean isIncremental
        end local 2 // boolean keepSSTableLevel
        end local 1 // int connectionsPerHost
        end local 0 // org.apache.cassandra.streaming.StreamCoordinator this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0    9     0                 this  Lorg/apache/cassandra/streaming/StreamCoordinator;
            0    9     1   connectionsPerHost  I
            0    9     2     keepSSTableLevel  Z
            0    9     3        isIncremental  Z
            0    9     4              factory  Lorg/apache/cassandra/streaming/StreamConnectionFactory;
            0    9     5  connectSequentially  Z
    MethodParameters:
                     Name  Flags
      connectionsPerHost   
      keepSSTableLevel     
      isIncremental        
      factory              
      connectSequentially  

  public void setConnectionFactory(org.apache.cassandra.streaming.StreamConnectionFactory);
    descriptor: (Lorg/apache/cassandra/streaming/StreamConnectionFactory;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.streaming.StreamCoordinator this
        start local 1 // org.apache.cassandra.streaming.StreamConnectionFactory factory
         0: .line 71
            aload 0 /* this */
            aload 1 /* factory */
            putfield org.apache.cassandra.streaming.StreamCoordinator.factory:Lorg/apache/cassandra/streaming/StreamConnectionFactory;
         1: .line 72
            return
        end local 1 // org.apache.cassandra.streaming.StreamConnectionFactory factory
        end local 0 // org.apache.cassandra.streaming.StreamCoordinator this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lorg/apache/cassandra/streaming/StreamCoordinator;
            0    2     1  factory  Lorg/apache/cassandra/streaming/StreamConnectionFactory;
    MethodParameters:
         Name  Flags
      factory  

  public synchronized boolean hasActiveSessions();
    descriptor: ()Z
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=1, locals=3, args_size=1
        start local 0 // org.apache.cassandra.streaming.StreamCoordinator this
         0: .line 79
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamCoordinator.peerSessions:Ljava/util/Map;
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 2
            goto 4
      StackMap locals: org.apache.cassandra.streaming.StreamCoordinator top java.util.Iterator
      StackMap stack:
         1: aload 2
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData
            astore 1 /* data */
        start local 1 // org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData data
         2: .line 81
            aload 1 /* data */
            invokevirtual org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData.hasActiveSessions:()Z
            ifeq 4
         3: .line 82
            iconst_1
            ireturn
        end local 1 // org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData data
         4: .line 79
      StackMap locals:
      StackMap stack:
            aload 2
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 1
         5: .line 84
            iconst_0
            ireturn
        end local 0 // org.apache.cassandra.streaming.StreamCoordinator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lorg/apache/cassandra/streaming/StreamCoordinator;
            2    4     1  data  Lorg/apache/cassandra/streaming/StreamCoordinator$HostStreamingData;

  public synchronized java.util.Collection<org.apache.cassandra.streaming.StreamSession> getAllStreamSessions();
    descriptor: ()Ljava/util/Collection;
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=2, locals=4, args_size=1
        start local 0 // org.apache.cassandra.streaming.StreamCoordinator this
         0: .line 89
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 1 /* results */
        start local 1 // java.util.Collection results
         1: .line 90
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamCoordinator.peerSessions:Ljava/util/Map;
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 3
            goto 4
      StackMap locals: org.apache.cassandra.streaming.StreamCoordinator java.util.Collection top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData
            astore 2 /* data */
        start local 2 // org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData data
         3: .line 92
            aload 1 /* results */
            aload 2 /* data */
            invokevirtual org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData.getAllStreamSessions:()Ljava/util/Collection;
            invokeinterface java.util.Collection.addAll:(Ljava/util/Collection;)Z
            pop
        end local 2 // org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData data
         4: .line 90
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 94
            aload 1 /* results */
            areturn
        end local 1 // java.util.Collection results
        end local 0 // org.apache.cassandra.streaming.StreamCoordinator this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    6     0     this  Lorg/apache/cassandra/streaming/StreamCoordinator;
            1    6     1  results  Ljava/util/Collection<Lorg/apache/cassandra/streaming/StreamSession;>;
            3    4     2     data  Lorg/apache/cassandra/streaming/StreamCoordinator$HostStreamingData;
    Signature: ()Ljava/util/Collection<Lorg/apache/cassandra/streaming/StreamSession;>;

  public boolean isReceiving();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.streaming.StreamCoordinator this
         0: .line 99
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamCoordinator.connectionsPerHost:I
            ifne 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 0 // org.apache.cassandra.streaming.StreamCoordinator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/cassandra/streaming/StreamCoordinator;

  public void connect(org.apache.cassandra.streaming.StreamResultFuture);
    descriptor: (Lorg/apache/cassandra/streaming/StreamResultFuture;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.streaming.StreamCoordinator this
        start local 1 // org.apache.cassandra.streaming.StreamResultFuture future
         0: .line 104
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamCoordinator.connectSequentially:Z
            ifeq 2
         1: .line 105
            aload 0 /* this */
            aload 1 /* future */
            invokevirtual org.apache.cassandra.streaming.StreamCoordinator.connectSequentially:(Lorg/apache/cassandra/streaming/StreamResultFuture;)V
            goto 3
         2: .line 107
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamCoordinator.connectAllStreamSessions:()V
         3: .line 108
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.apache.cassandra.streaming.StreamResultFuture future
        end local 0 // org.apache.cassandra.streaming.StreamCoordinator this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    4     0    this  Lorg/apache/cassandra/streaming/StreamCoordinator;
            0    4     1  future  Lorg/apache/cassandra/streaming/StreamResultFuture;
    MethodParameters:
        Name  Flags
      future  

  private void connectAllStreamSessions();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=1, locals=3, args_size=1
        start local 0 // org.apache.cassandra.streaming.StreamCoordinator this
         0: .line 112
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamCoordinator.peerSessions:Ljava/util/Map;
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 2
            goto 3
      StackMap locals: org.apache.cassandra.streaming.StreamCoordinator top java.util.Iterator
      StackMap stack:
         1: aload 2
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData
            astore 1 /* data */
        start local 1 // org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData data
         2: .line 113
            aload 1 /* data */
            invokevirtual org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData.connectAllStreamSessions:()V
        end local 1 // org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData data
         3: .line 112
      StackMap locals:
      StackMap stack:
            aload 2
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 1
         4: .line 114
            return
        end local 0 // org.apache.cassandra.streaming.StreamCoordinator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lorg/apache/cassandra/streaming/StreamCoordinator;
            2    3     1  data  Lorg/apache/cassandra/streaming/StreamCoordinator$HostStreamingData;

  private void connectSequentially(org.apache.cassandra.streaming.StreamResultFuture);
    descriptor: (Lorg/apache/cassandra/streaming/StreamResultFuture;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.apache.cassandra.streaming.StreamCoordinator this
        start local 1 // org.apache.cassandra.streaming.StreamResultFuture future
         0: .line 118
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamCoordinator.getAllStreamSessions:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            putfield org.apache.cassandra.streaming.StreamCoordinator.sessionsToConnect:Ljava/util/Iterator;
         1: .line 119
            aload 1 /* future */
            new org.apache.cassandra.streaming.StreamCoordinator$1
            dup
            aload 0 /* this */
            invokespecial org.apache.cassandra.streaming.StreamCoordinator$1.<init>:(Lorg/apache/cassandra/streaming/StreamCoordinator;)V
            invokevirtual org.apache.cassandra.streaming.StreamResultFuture.addEventListener:(Lorg/apache/cassandra/streaming/StreamEventHandler;)V
         2: .line 137
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamCoordinator.connectNext:()V
         3: .line 138
            return
        end local 1 // org.apache.cassandra.streaming.StreamResultFuture future
        end local 0 // org.apache.cassandra.streaming.StreamCoordinator this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    4     0    this  Lorg/apache/cassandra/streaming/StreamCoordinator;
            0    4     1  future  Lorg/apache/cassandra/streaming/StreamResultFuture;
    MethodParameters:
        Name  Flags
      future  

  private void connectNext();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=4, locals=2, args_size=1
        start local 0 // org.apache.cassandra.streaming.StreamCoordinator this
         0: .line 142
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamCoordinator.sessionsToConnect:Ljava/util/Iterator;
            ifnonnull 2
         1: .line 143
            return
         2: .line 145
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamCoordinator.sessionsToConnect:Ljava/util/Iterator;
            invokeinterface java.util.Iterator.hasNext:()Z
            ifeq 7
         3: .line 147
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamCoordinator.sessionsToConnect:Ljava/util/Iterator;
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.streaming.StreamSession
            astore 1 /* next */
        start local 1 // org.apache.cassandra.streaming.StreamSession next
         4: .line 148
            getstatic org.apache.cassandra.streaming.StreamCoordinator.logger:Lorg/slf4j/Logger;
            ldc "Connecting next session {} with {}."
            aload 1 /* next */
            invokevirtual org.apache.cassandra.streaming.StreamSession.planId:()Ljava/util/UUID;
            aload 1 /* next */
            getfield org.apache.cassandra.streaming.StreamSession.peer:Ljava/net/InetAddress;
            invokevirtual java.net.InetAddress.getHostAddress:()Ljava/lang/String;
            invokeinterface org.slf4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
         5: .line 149
            getstatic org.apache.cassandra.streaming.StreamCoordinator.streamExecutor:Lorg/apache/cassandra/concurrent/DebuggableThreadPoolExecutor;
            new org.apache.cassandra.streaming.StreamCoordinator$StreamSessionConnector
            dup
            aload 1 /* next */
            invokespecial org.apache.cassandra.streaming.StreamCoordinator$StreamSessionConnector.<init>:(Lorg/apache/cassandra/streaming/StreamSession;)V
            invokevirtual org.apache.cassandra.concurrent.DebuggableThreadPoolExecutor.execute:(Ljava/lang/Runnable;)V
        end local 1 // org.apache.cassandra.streaming.StreamSession next
         6: .line 150
            goto 8
         7: .line 152
      StackMap locals:
      StackMap stack:
            getstatic org.apache.cassandra.streaming.StreamCoordinator.logger:Lorg/slf4j/Logger;
            ldc "Finished connecting all sessions"
            invokeinterface org.slf4j.Logger.debug:(Ljava/lang/String;)V
         8: .line 153
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.apache.cassandra.streaming.StreamCoordinator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    9     0  this  Lorg/apache/cassandra/streaming/StreamCoordinator;
            4    6     1  next  Lorg/apache/cassandra/streaming/StreamSession;

  public synchronized java.util.Set<java.net.InetAddress> getPeers();
    descriptor: ()Ljava/util/Set;
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.apache.cassandra.streaming.StreamCoordinator this
         0: .line 157
            new java.util.HashSet
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamCoordinator.peerSessions:Ljava/util/Map;
            invokeinterface java.util.Map.keySet:()Ljava/util/Set;
            invokespecial java.util.HashSet.<init>:(Ljava/util/Collection;)V
            areturn
        end local 0 // org.apache.cassandra.streaming.StreamCoordinator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/streaming/StreamCoordinator;
    Signature: ()Ljava/util/Set<Ljava/net/InetAddress;>;

  public synchronized org.apache.cassandra.streaming.StreamSession getOrCreateNextSession(java.net.InetAddress, java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;Ljava/net/InetAddress;)Lorg/apache/cassandra/streaming/StreamSession;
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // org.apache.cassandra.streaming.StreamCoordinator this
        start local 1 // java.net.InetAddress peer
        start local 2 // java.net.InetAddress connecting
         0: .line 162
            aload 0 /* this */
            aload 1 /* peer */
            invokevirtual org.apache.cassandra.streaming.StreamCoordinator.getOrCreateHostData:(Ljava/net/InetAddress;)Lorg/apache/cassandra/streaming/StreamCoordinator$HostStreamingData;
            aload 1 /* peer */
            aload 2 /* connecting */
            invokevirtual org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData.getOrCreateNextSession:(Ljava/net/InetAddress;Ljava/net/InetAddress;)Lorg/apache/cassandra/streaming/StreamSession;
            areturn
        end local 2 // java.net.InetAddress connecting
        end local 1 // java.net.InetAddress peer
        end local 0 // org.apache.cassandra.streaming.StreamCoordinator this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    1     0        this  Lorg/apache/cassandra/streaming/StreamCoordinator;
            0    1     1        peer  Ljava/net/InetAddress;
            0    1     2  connecting  Ljava/net/InetAddress;
    MethodParameters:
            Name  Flags
      peer        
      connecting  

  public synchronized org.apache.cassandra.streaming.StreamSession getOrCreateSessionById(java.net.InetAddress, int, java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;ILjava/net/InetAddress;)Lorg/apache/cassandra/streaming/StreamSession;
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=4, locals=4, args_size=4
        start local 0 // org.apache.cassandra.streaming.StreamCoordinator this
        start local 1 // java.net.InetAddress peer
        start local 2 // int id
        start local 3 // java.net.InetAddress connecting
         0: .line 167
            aload 0 /* this */
            aload 1 /* peer */
            invokevirtual org.apache.cassandra.streaming.StreamCoordinator.getOrCreateHostData:(Ljava/net/InetAddress;)Lorg/apache/cassandra/streaming/StreamCoordinator$HostStreamingData;
            aload 1 /* peer */
            iload 2 /* id */
            aload 3 /* connecting */
            invokevirtual org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData.getOrCreateSessionById:(Ljava/net/InetAddress;ILjava/net/InetAddress;)Lorg/apache/cassandra/streaming/StreamSession;
            areturn
        end local 3 // java.net.InetAddress connecting
        end local 2 // int id
        end local 1 // java.net.InetAddress peer
        end local 0 // org.apache.cassandra.streaming.StreamCoordinator this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    1     0        this  Lorg/apache/cassandra/streaming/StreamCoordinator;
            0    1     1        peer  Ljava/net/InetAddress;
            0    1     2          id  I
            0    1     3  connecting  Ljava/net/InetAddress;
    MethodParameters:
            Name  Flags
      peer        
      id          
      connecting  

  public synchronized void updateProgress(org.apache.cassandra.streaming.ProgressInfo);
    descriptor: (Lorg/apache/cassandra/streaming/ProgressInfo;)V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.streaming.StreamCoordinator this
        start local 1 // org.apache.cassandra.streaming.ProgressInfo info
         0: .line 172
            aload 0 /* this */
            aload 1 /* info */
            getfield org.apache.cassandra.streaming.ProgressInfo.peer:Ljava/net/InetAddress;
            invokevirtual org.apache.cassandra.streaming.StreamCoordinator.getHostData:(Ljava/net/InetAddress;)Lorg/apache/cassandra/streaming/StreamCoordinator$HostStreamingData;
            aload 1 /* info */
            invokevirtual org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData.updateProgress:(Lorg/apache/cassandra/streaming/ProgressInfo;)V
         1: .line 173
            return
        end local 1 // org.apache.cassandra.streaming.ProgressInfo info
        end local 0 // org.apache.cassandra.streaming.StreamCoordinator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/cassandra/streaming/StreamCoordinator;
            0    2     1  info  Lorg/apache/cassandra/streaming/ProgressInfo;
    MethodParameters:
      Name  Flags
      info  

  public synchronized void addSessionInfo(org.apache.cassandra.streaming.SessionInfo);
    descriptor: (Lorg/apache/cassandra/streaming/SessionInfo;)V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // org.apache.cassandra.streaming.StreamCoordinator this
        start local 1 // org.apache.cassandra.streaming.SessionInfo session
         0: .line 177
            aload 0 /* this */
            aload 1 /* session */
            getfield org.apache.cassandra.streaming.SessionInfo.peer:Ljava/net/InetAddress;
            invokevirtual org.apache.cassandra.streaming.StreamCoordinator.getOrCreateHostData:(Ljava/net/InetAddress;)Lorg/apache/cassandra/streaming/StreamCoordinator$HostStreamingData;
            astore 2 /* data */
        start local 2 // org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData data
         1: .line 178
            aload 2 /* data */
            aload 1 /* session */
            invokevirtual org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData.addSessionInfo:(Lorg/apache/cassandra/streaming/SessionInfo;)V
         2: .line 179
            return
        end local 2 // org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData data
        end local 1 // org.apache.cassandra.streaming.SessionInfo session
        end local 0 // org.apache.cassandra.streaming.StreamCoordinator this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    3     0     this  Lorg/apache/cassandra/streaming/StreamCoordinator;
            0    3     1  session  Lorg/apache/cassandra/streaming/SessionInfo;
            1    3     2     data  Lorg/apache/cassandra/streaming/StreamCoordinator$HostStreamingData;
    MethodParameters:
         Name  Flags
      session  

  public synchronized java.util.Set<org.apache.cassandra.streaming.SessionInfo> getAllSessionInfo();
    descriptor: ()Ljava/util/Set;
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=2, locals=4, args_size=1
        start local 0 // org.apache.cassandra.streaming.StreamCoordinator this
         0: .line 183
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            astore 1 /* result */
        start local 1 // java.util.Set result
         1: .line 184
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamCoordinator.peerSessions:Ljava/util/Map;
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 3
            goto 4
      StackMap locals: org.apache.cassandra.streaming.StreamCoordinator java.util.Set top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData
            astore 2 /* data */
        start local 2 // org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData data
         3: .line 186
            aload 1 /* result */
            aload 2 /* data */
            invokevirtual org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData.getAllSessionInfo:()Ljava/util/Collection;
            invokeinterface java.util.Set.addAll:(Ljava/util/Collection;)Z
            pop
        end local 2 // org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData data
         4: .line 184
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 188
            aload 1 /* result */
            areturn
        end local 1 // java.util.Set result
        end local 0 // org.apache.cassandra.streaming.StreamCoordinator this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    6     0    this  Lorg/apache/cassandra/streaming/StreamCoordinator;
            1    6     1  result  Ljava/util/Set<Lorg/apache/cassandra/streaming/SessionInfo;>;
            3    4     2    data  Lorg/apache/cassandra/streaming/StreamCoordinator$HostStreamingData;
    Signature: ()Ljava/util/Set<Lorg/apache/cassandra/streaming/SessionInfo;>;

  public synchronized void transferFiles(java.net.InetAddress, java.util.Collection<org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections>);
    descriptor: (Ljava/net/InetAddress;Ljava/util/Collection;)V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=3, locals=8, args_size=3
        start local 0 // org.apache.cassandra.streaming.StreamCoordinator this
        start local 1 // java.net.InetAddress to
        start local 2 // java.util.Collection sstableDetails
         0: .line 193
            aload 0 /* this */
            aload 1 /* to */
            invokevirtual org.apache.cassandra.streaming.StreamCoordinator.getOrCreateHostData:(Ljava/net/InetAddress;)Lorg/apache/cassandra/streaming/StreamCoordinator$HostStreamingData;
            astore 3 /* sessionList */
        start local 3 // org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData sessionList
         1: .line 195
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamCoordinator.connectionsPerHost:I
            iconst_1
            if_icmple 9
         2: .line 197
            aload 0 /* this */
            aload 2 /* sstableDetails */
            invokevirtual org.apache.cassandra.streaming.StreamCoordinator.sliceSSTableDetails:(Ljava/util/Collection;)Ljava/util/List;
            astore 4 /* buckets */
        start local 4 // java.util.List buckets
         3: .line 199
            aload 4 /* buckets */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 6
            goto 7
      StackMap locals: org.apache.cassandra.streaming.StreamCoordinator java.net.InetAddress java.util.Collection org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData java.util.List top java.util.Iterator
      StackMap stack:
         4: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.util.List
            astore 5 /* subList */
        start local 5 // java.util.List subList
         5: .line 201
            aload 3 /* sessionList */
            aload 1 /* to */
            aload 1 /* to */
            invokevirtual org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData.getOrCreateNextSession:(Ljava/net/InetAddress;Ljava/net/InetAddress;)Lorg/apache/cassandra/streaming/StreamSession;
            astore 7 /* session */
        start local 7 // org.apache.cassandra.streaming.StreamSession session
         6: .line 202
            aload 7 /* session */
            aload 5 /* subList */
            invokevirtual org.apache.cassandra.streaming.StreamSession.addTransferFiles:(Ljava/util/Collection;)V
        end local 7 // org.apache.cassandra.streaming.StreamSession session
        end local 5 // java.util.List subList
         7: .line 199
      StackMap locals:
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 4
        end local 4 // java.util.List buckets
         8: .line 204
            goto 11
         9: .line 207
      StackMap locals: org.apache.cassandra.streaming.StreamCoordinator java.net.InetAddress java.util.Collection org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData
      StackMap stack:
            aload 3 /* sessionList */
            aload 1 /* to */
            aload 1 /* to */
            invokevirtual org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData.getOrCreateNextSession:(Ljava/net/InetAddress;Ljava/net/InetAddress;)Lorg/apache/cassandra/streaming/StreamSession;
            astore 4 /* session */
        start local 4 // org.apache.cassandra.streaming.StreamSession session
        10: .line 208
            aload 4 /* session */
            aload 2 /* sstableDetails */
            invokevirtual org.apache.cassandra.streaming.StreamSession.addTransferFiles:(Ljava/util/Collection;)V
        end local 4 // org.apache.cassandra.streaming.StreamSession session
        11: .line 210
      StackMap locals:
      StackMap stack:
            return
        end local 3 // org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData sessionList
        end local 2 // java.util.Collection sstableDetails
        end local 1 // java.net.InetAddress to
        end local 0 // org.apache.cassandra.streaming.StreamCoordinator this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   12     0            this  Lorg/apache/cassandra/streaming/StreamCoordinator;
            0   12     1              to  Ljava/net/InetAddress;
            0   12     2  sstableDetails  Ljava/util/Collection<Lorg/apache/cassandra/streaming/StreamSession$SSTableStreamingSections;>;
            1   12     3     sessionList  Lorg/apache/cassandra/streaming/StreamCoordinator$HostStreamingData;
            3    8     4         buckets  Ljava/util/List<Ljava/util/List<Lorg/apache/cassandra/streaming/StreamSession$SSTableStreamingSections;>;>;
            5    7     5         subList  Ljava/util/List<Lorg/apache/cassandra/streaming/StreamSession$SSTableStreamingSections;>;
            6    7     7         session  Lorg/apache/cassandra/streaming/StreamSession;
           10   11     4         session  Lorg/apache/cassandra/streaming/StreamSession;
    Signature: (Ljava/net/InetAddress;Ljava/util/Collection<Lorg/apache/cassandra/streaming/StreamSession$SSTableStreamingSections;>;)V
    MethodParameters:
                Name  Flags
      to              
      sstableDetails  

  private java.util.List<java.util.List<org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections>> sliceSSTableDetails(java.util.Collection<org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections>);
    descriptor: (Ljava/util/Collection;)Ljava/util/List;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=9, args_size=2
        start local 0 // org.apache.cassandra.streaming.StreamCoordinator this
        start local 1 // java.util.Collection sstableDetails
         0: .line 215
            aload 1 /* sstableDetails */
            invokeinterface java.util.Collection.size:()I
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamCoordinator.connectionsPerHost:I
            invokestatic java.lang.Math.min:(II)I
            istore 2 /* targetSlices */
        start local 2 // int targetSlices
         1: .line 216
            aload 1 /* sstableDetails */
            invokeinterface java.util.Collection.size:()I
            i2f
            iload 2 /* targetSlices */
            i2f
            fdiv
            invokestatic java.lang.Math.round:(F)I
            istore 3 /* step */
        start local 3 // int step
         2: .line 217
            iconst_0
            istore 4 /* index */
        start local 4 // int index
         3: .line 219
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 5 /* result */
        start local 5 // java.util.List result
         4: .line 220
            aconst_null
            astore 6 /* slice */
        start local 6 // java.util.List slice
         5: .line 221
            aload 1 /* sstableDetails */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 7 /* iter */
        start local 7 // java.util.Iterator iter
         6: .line 222
            goto 14
         7: .line 224
      StackMap locals: org.apache.cassandra.streaming.StreamCoordinator java.util.Collection int int int java.util.List java.util.List java.util.Iterator
      StackMap stack:
            aload 7 /* iter */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections
            astore 8 /* streamSession */
        start local 8 // org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections streamSession
         8: .line 226
            iload 4 /* index */
            iload 3 /* step */
            irem
            ifne 11
         9: .line 228
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 6 /* slice */
        10: .line 229
            aload 5 /* result */
            aload 6 /* slice */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        11: .line 231
      StackMap locals: org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections
      StackMap stack:
            aload 6 /* slice */
            aload 8 /* streamSession */
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        12: .line 232
            iinc 4 /* index */ 1
        13: .line 233
            aload 7 /* iter */
            invokeinterface java.util.Iterator.remove:()V
        end local 8 // org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections streamSession
        14: .line 222
      StackMap locals:
      StackMap stack:
            aload 7 /* iter */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 7
        15: .line 236
            aload 5 /* result */
            areturn
        end local 7 // java.util.Iterator iter
        end local 6 // java.util.List slice
        end local 5 // java.util.List result
        end local 4 // int index
        end local 3 // int step
        end local 2 // int targetSlices
        end local 1 // java.util.Collection sstableDetails
        end local 0 // org.apache.cassandra.streaming.StreamCoordinator this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   16     0            this  Lorg/apache/cassandra/streaming/StreamCoordinator;
            0   16     1  sstableDetails  Ljava/util/Collection<Lorg/apache/cassandra/streaming/StreamSession$SSTableStreamingSections;>;
            1   16     2    targetSlices  I
            2   16     3            step  I
            3   16     4           index  I
            4   16     5          result  Ljava/util/List<Ljava/util/List<Lorg/apache/cassandra/streaming/StreamSession$SSTableStreamingSections;>;>;
            5   16     6           slice  Ljava/util/List<Lorg/apache/cassandra/streaming/StreamSession$SSTableStreamingSections;>;
            6   16     7            iter  Ljava/util/Iterator<Lorg/apache/cassandra/streaming/StreamSession$SSTableStreamingSections;>;
            8   14     8   streamSession  Lorg/apache/cassandra/streaming/StreamSession$SSTableStreamingSections;
    Signature: (Ljava/util/Collection<Lorg/apache/cassandra/streaming/StreamSession$SSTableStreamingSections;>;)Ljava/util/List<Ljava/util/List<Lorg/apache/cassandra/streaming/StreamSession$SSTableStreamingSections;>;>;
    MethodParameters:
                Name  Flags
      sstableDetails  

  private org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData getHostData(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)Lorg/apache/cassandra/streaming/StreamCoordinator$HostStreamingData;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=5, locals=3, args_size=2
        start local 0 // org.apache.cassandra.streaming.StreamCoordinator this
        start local 1 // java.net.InetAddress peer
         0: .line 241
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamCoordinator.peerSessions:Ljava/util/Map;
            aload 1 /* peer */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData
            astore 2 /* data */
        start local 2 // org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData data
         1: .line 242
            aload 2 /* data */
            ifnonnull 3
         2: .line 243
            new java.lang.IllegalArgumentException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Unknown peer requested: "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1 /* peer */
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial java.lang.IllegalArgumentException.<init>:(Ljava/lang/String;)V
            athrow
         3: .line 244
      StackMap locals: org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData
      StackMap stack:
            aload 2 /* data */
            areturn
        end local 2 // org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData data
        end local 1 // java.net.InetAddress peer
        end local 0 // org.apache.cassandra.streaming.StreamCoordinator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/apache/cassandra/streaming/StreamCoordinator;
            0    4     1  peer  Ljava/net/InetAddress;
            1    4     2  data  Lorg/apache/cassandra/streaming/StreamCoordinator$HostStreamingData;
    MethodParameters:
      Name  Flags
      peer  

  private org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData getOrCreateHostData(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)Lorg/apache/cassandra/streaming/StreamCoordinator$HostStreamingData;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // org.apache.cassandra.streaming.StreamCoordinator this
        start local 1 // java.net.InetAddress peer
         0: .line 249
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamCoordinator.peerSessions:Ljava/util/Map;
            aload 1 /* peer */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData
            astore 2 /* data */
        start local 2 // org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData data
         1: .line 250
            aload 2 /* data */
            ifnonnull 4
         2: .line 252
            new org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData
            dup
            aload 0 /* this */
            invokespecial org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData.<init>:(Lorg/apache/cassandra/streaming/StreamCoordinator;)V
            astore 2 /* data */
         3: .line 253
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamCoordinator.peerSessions:Ljava/util/Map;
            aload 1 /* peer */
            aload 2 /* data */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         4: .line 255
      StackMap locals: org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData
      StackMap stack:
            aload 2 /* data */
            areturn
        end local 2 // org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData data
        end local 1 // java.net.InetAddress peer
        end local 0 // org.apache.cassandra.streaming.StreamCoordinator this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lorg/apache/cassandra/streaming/StreamCoordinator;
            0    5     1  peer  Ljava/net/InetAddress;
            1    5     2  data  Lorg/apache/cassandra/streaming/StreamCoordinator$HostStreamingData;
    MethodParameters:
      Name  Flags
      peer  

  public static void shutdownAndWait(long, java.util.concurrent.TimeUnit);
    descriptor: (JLjava/util/concurrent/TimeUnit;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=7, locals=3, args_size=2
        start local 0 // long timeout
        start local 2 // java.util.concurrent.TimeUnit unit
         0: .line 354
            lload 0 /* timeout */
            aload 2 /* unit */
            iconst_1
            anewarray java.lang.Object
            dup
            iconst_0
            getstatic org.apache.cassandra.streaming.StreamCoordinator.streamExecutor:Lorg/apache/cassandra/concurrent/DebuggableThreadPoolExecutor;
            aastore
            invokestatic org.apache.cassandra.utils.ExecutorUtils.shutdownAndWait:(JLjava/util/concurrent/TimeUnit;[Ljava/lang/Object;)V
         1: .line 355
            return
        end local 2 // java.util.concurrent.TimeUnit unit
        end local 0 // long timeout
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0  timeout  J
            0    2     2     unit  Ljava/util/concurrent/TimeUnit;
    Exceptions:
      throws java.lang.InterruptedException, java.util.concurrent.TimeoutException
    RuntimeInvisibleAnnotations: 
      com.google.common.annotations.VisibleForTesting()
    MethodParameters:
         Name  Flags
      timeout  
      unit     
}
SourceFile: "StreamCoordinator.java"
NestMembers:
  org.apache.cassandra.streaming.StreamCoordinator$1  org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData  org.apache.cassandra.streaming.StreamCoordinator$StreamSessionConnector
InnerClasses:
  org.apache.cassandra.streaming.StreamCoordinator$1
  private HostStreamingData = org.apache.cassandra.streaming.StreamCoordinator$HostStreamingData of org.apache.cassandra.streaming.StreamCoordinator
  private StreamSessionConnector = org.apache.cassandra.streaming.StreamCoordinator$StreamSessionConnector of org.apache.cassandra.streaming.StreamCoordinator
  public SSTableStreamingSections = org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections of org.apache.cassandra.streaming.StreamSession