public class org.apache.cassandra.streaming.StreamSession implements org.apache.cassandra.gms.IEndpointStateChangeSubscriber
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: org.apache.cassandra.streaming.StreamSession
  super_class: java.lang.Object
{
  private static final org.apache.cassandra.utils.CassandraVersion STREAM_KEEP_ALIVE;
    descriptor: Lorg/apache/cassandra/utils/CassandraVersion;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  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.DebuggableScheduledThreadPoolExecutor keepAliveExecutor;
    descriptor: Lorg/apache/cassandra/concurrent/DebuggableScheduledThreadPoolExecutor;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  public final java.net.InetAddress peer;
    descriptor: Ljava/net/InetAddress;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL

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

  public final java.net.InetAddress connecting;
    descriptor: Ljava/net/InetAddress;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL

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

  protected final java.util.Set<org.apache.cassandra.streaming.StreamRequest> requests;
    descriptor: Ljava/util/Set;
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL
    Signature: Ljava/util/Set<Lorg/apache/cassandra/streaming/StreamRequest;>;

  protected final java.util.concurrent.ConcurrentHashMap<java.util.UUID, org.apache.cassandra.streaming.StreamTransferTask> transfers;
    descriptor: Ljava/util/concurrent/ConcurrentHashMap;
    flags: (0x0014) ACC_PROTECTED, ACC_FINAL
    Signature: Ljava/util/concurrent/ConcurrentHashMap<Ljava/util/UUID;Lorg/apache/cassandra/streaming/StreamTransferTask;>;
    RuntimeInvisibleAnnotations: 
      com.google.common.annotations.VisibleForTesting()

  private final java.util.Map<java.util.UUID, org.apache.cassandra.streaming.StreamReceiveTask> receivers;
    descriptor: Ljava/util/Map;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL
    Signature: Ljava/util/Map<Ljava/util/UUID;Lorg/apache/cassandra/streaming/StreamReceiveTask;>;

  private final org.apache.cassandra.metrics.StreamingMetrics metrics;
    descriptor: Lorg/apache/cassandra/metrics/StreamingMetrics;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  private final org.apache.cassandra.streaming.StreamConnectionFactory factory;
    descriptor: Lorg/apache/cassandra/streaming/StreamConnectionFactory;
    flags: (0x0012) ACC_PRIVATE, ACC_FINAL

  public final java.util.Map<java.lang.String, java.util.Set<org.apache.cassandra.dht.Range<org.apache.cassandra.dht.Token>>> transferredRangesPerKeyspace;
    descriptor: Ljava/util/Map;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL
    Signature: Ljava/util/Map<Ljava/lang/String;Ljava/util/Set<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;>;

  public final org.apache.cassandra.streaming.ConnectionHandler handler;
    descriptor: Lorg/apache/cassandra/streaming/ConnectionHandler;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL

  private java.util.concurrent.atomic.AtomicBoolean isAborted;
    descriptor: Ljava/util/concurrent/atomic/AtomicBoolean;
    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.concurrent.ScheduledFuture<?> keepAliveFuture;
    descriptor: Ljava/util/concurrent/ScheduledFuture;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/concurrent/ScheduledFuture<*>;

  private volatile org.apache.cassandra.streaming.StreamSession$State state;
    descriptor: Lorg/apache/cassandra/streaming/StreamSession$State;
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  private volatile boolean completeSent;
    descriptor: Z
    flags: (0x0042) ACC_PRIVATE, ACC_VOLATILE

  static final boolean $assertionsDisabled;
    descriptor: Z
    flags: (0x1018) ACC_STATIC, ACC_FINAL, ACC_SYNTHETIC

  private static volatile int[] $SWITCH_TABLE$org$apache$cassandra$streaming$messages$StreamMessage$Type;
    descriptor: [I
    flags: (0x104a) ACC_PRIVATE, ACC_STATIC, ACC_VOLATILE, ACC_SYNTHETIC

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=3, locals=0, args_size=0
         0: .line 120
            ldc Lorg/apache/cassandra/streaming/StreamSession;
            invokevirtual java.lang.Class.desiredAssertionStatus:()Z
            ifne 1
            iconst_1
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_0
      StackMap locals:
      StackMap stack: int
         2: putstatic org.apache.cassandra.streaming.StreamSession.$assertionsDisabled:Z
         3: .line 126
            new org.apache.cassandra.utils.CassandraVersion
            dup
            ldc "3.10"
            invokespecial org.apache.cassandra.utils.CassandraVersion.<init>:(Ljava/lang/String;)V
            putstatic org.apache.cassandra.streaming.StreamSession.STREAM_KEEP_ALIVE:Lorg/apache/cassandra/utils/CassandraVersion;
         4: .line 127
            ldc Lorg/apache/cassandra/streaming/StreamSession;
            invokestatic org.slf4j.LoggerFactory.getLogger:(Ljava/lang/Class;)Lorg/slf4j/Logger;
            putstatic org.apache.cassandra.streaming.StreamSession.logger:Lorg/slf4j/Logger;
         5: .line 128
            new org.apache.cassandra.concurrent.DebuggableScheduledThreadPoolExecutor
            dup
            ldc "StreamKeepAliveExecutor"
            invokespecial org.apache.cassandra.concurrent.DebuggableScheduledThreadPoolExecutor.<init>:(Ljava/lang/String;)V
            putstatic org.apache.cassandra.streaming.StreamSession.keepAliveExecutor:Lorg/apache/cassandra/concurrent/DebuggableScheduledThreadPoolExecutor;
         6: .line 131
            getstatic org.apache.cassandra.streaming.StreamSession.keepAliveExecutor:Lorg/apache/cassandra/concurrent/DebuggableScheduledThreadPoolExecutor;
            iconst_1
            invokevirtual org.apache.cassandra.concurrent.DebuggableScheduledThreadPoolExecutor.setRemoveOnCancelPolicy:(Z)V
         7: .line 132
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>(java.net.InetAddress, java.net.InetAddress, org.apache.cassandra.streaming.StreamConnectionFactory, int, boolean, boolean);
    descriptor: (Ljava/net/InetAddress;Ljava/net/InetAddress;Lorg/apache/cassandra/streaming/StreamConnectionFactory;IZZ)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=7, args_size=7
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // java.net.InetAddress peer
        start local 2 // java.net.InetAddress connecting
        start local 3 // org.apache.cassandra.streaming.StreamConnectionFactory factory
        start local 4 // int index
        start local 5 // boolean keepSSTableLevel
        start local 6 // boolean isIncremental
         0: .line 187
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 148
            aload 0 /* this */
            invokestatic com.google.common.collect.Sets.newConcurrentHashSet:()Ljava/util/Set;
            putfield org.apache.cassandra.streaming.StreamSession.requests:Ljava/util/Set;
         2: .line 151
            aload 0 /* this */
            new java.util.concurrent.ConcurrentHashMap
            dup
            invokespecial java.util.concurrent.ConcurrentHashMap.<init>:()V
            putfield org.apache.cassandra.streaming.StreamSession.transfers:Ljava/util/concurrent/ConcurrentHashMap;
         3: .line 153
            aload 0 /* this */
            new java.util.concurrent.ConcurrentHashMap
            dup
            invokespecial java.util.concurrent.ConcurrentHashMap.<init>:()V
            putfield org.apache.cassandra.streaming.StreamSession.receivers:Ljava/util/Map;
         4: .line 158
            aload 0 /* this */
            new java.util.HashMap
            dup
            invokespecial java.util.HashMap.<init>:()V
            putfield org.apache.cassandra.streaming.StreamSession.transferredRangesPerKeyspace:Ljava/util/Map;
         5: .line 162
            aload 0 /* this */
            new java.util.concurrent.atomic.AtomicBoolean
            dup
            iconst_0
            invokespecial java.util.concurrent.atomic.AtomicBoolean.<init>:(Z)V
            putfield org.apache.cassandra.streaming.StreamSession.isAborted:Ljava/util/concurrent/atomic/AtomicBoolean;
         6: .line 165
            aload 0 /* this */
            aconst_null
            putfield org.apache.cassandra.streaming.StreamSession.keepAliveFuture:Ljava/util/concurrent/ScheduledFuture;
         7: .line 177
            aload 0 /* this */
            getstatic org.apache.cassandra.streaming.StreamSession$State.INITIALIZED:Lorg/apache/cassandra/streaming/StreamSession$State;
            putfield org.apache.cassandra.streaming.StreamSession.state:Lorg/apache/cassandra/streaming/StreamSession$State;
         8: .line 178
            aload 0 /* this */
            iconst_0
            putfield org.apache.cassandra.streaming.StreamSession.completeSent:Z
         9: .line 189
            aload 0 /* this */
            aload 1 /* peer */
            putfield org.apache.cassandra.streaming.StreamSession.peer:Ljava/net/InetAddress;
        10: .line 190
            aload 0 /* this */
            aload 2 /* connecting */
            putfield org.apache.cassandra.streaming.StreamSession.connecting:Ljava/net/InetAddress;
        11: .line 191
            aload 0 /* this */
            iload 4 /* index */
            putfield org.apache.cassandra.streaming.StreamSession.index:I
        12: .line 192
            aload 0 /* this */
            aload 3 /* factory */
            putfield org.apache.cassandra.streaming.StreamSession.factory:Lorg/apache/cassandra/streaming/StreamConnectionFactory;
        13: .line 193
            aload 0 /* this */
        14: new org.apache.cassandra.streaming.ConnectionHandler
            dup
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.isKeepAliveSupported:()Z
            ifeq 16
        15: .line 194
            getstatic java.util.concurrent.TimeUnit.SECONDS:Ljava/util/concurrent/TimeUnit;
            iconst_2
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.getStreamingKeepAlivePeriod:()I
            imul
            i2l
            invokevirtual java.util.concurrent.TimeUnit.toMillis:(J)J
            l2i
            goto 17
        16: .line 195
      StackMap locals: org.apache.cassandra.streaming.StreamSession java.net.InetAddress java.net.InetAddress org.apache.cassandra.streaming.StreamConnectionFactory int int int
      StackMap stack: org.apache.cassandra.streaming.StreamSession new 14 new 14 org.apache.cassandra.streaming.StreamSession
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.getStreamingSocketTimeout:()I
      StackMap locals: org.apache.cassandra.streaming.StreamSession java.net.InetAddress java.net.InetAddress org.apache.cassandra.streaming.StreamConnectionFactory int int int
      StackMap stack: org.apache.cassandra.streaming.StreamSession new 14 new 14 org.apache.cassandra.streaming.StreamSession int
        17: invokespecial org.apache.cassandra.streaming.ConnectionHandler.<init>:(Lorg/apache/cassandra/streaming/StreamSession;I)V
        18: .line 193
            putfield org.apache.cassandra.streaming.StreamSession.handler:Lorg/apache/cassandra/streaming/ConnectionHandler;
        19: .line 196
            aload 0 /* this */
            aload 2 /* connecting */
            invokestatic org.apache.cassandra.metrics.StreamingMetrics.get:(Ljava/net/InetAddress;)Lorg/apache/cassandra/metrics/StreamingMetrics;
            putfield org.apache.cassandra.streaming.StreamSession.metrics:Lorg/apache/cassandra/metrics/StreamingMetrics;
        20: .line 197
            aload 0 /* this */
            iload 5 /* keepSSTableLevel */
            putfield org.apache.cassandra.streaming.StreamSession.keepSSTableLevel:Z
        21: .line 198
            aload 0 /* this */
            iload 6 /* isIncremental */
            putfield org.apache.cassandra.streaming.StreamSession.isIncremental:Z
        22: .line 199
            return
        end local 6 // boolean isIncremental
        end local 5 // boolean keepSSTableLevel
        end local 4 // int index
        end local 3 // org.apache.cassandra.streaming.StreamConnectionFactory factory
        end local 2 // java.net.InetAddress connecting
        end local 1 // java.net.InetAddress peer
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   23     0              this  Lorg/apache/cassandra/streaming/StreamSession;
            0   23     1              peer  Ljava/net/InetAddress;
            0   23     2        connecting  Ljava/net/InetAddress;
            0   23     3           factory  Lorg/apache/cassandra/streaming/StreamConnectionFactory;
            0   23     4             index  I
            0   23     5  keepSSTableLevel  Z
            0   23     6     isIncremental  Z
    MethodParameters:
                  Name  Flags
      peer              
      connecting        
      factory           
      index             
      keepSSTableLevel  
      isIncremental     

  public java.util.UUID planId();
    descriptor: ()Ljava/util/UUID;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.streaming.StreamSession this
         0: .line 203
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.streamResult:Lorg/apache/cassandra/streaming/StreamResultFuture;
            ifnonnull 1
            aconst_null
            goto 2
      StackMap locals:
      StackMap stack:
         1: aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.streamResult:Lorg/apache/cassandra/streaming/StreamResultFuture;
            getfield org.apache.cassandra.streaming.StreamResultFuture.planId:Ljava/util/UUID;
      StackMap locals:
      StackMap stack: java.util.UUID
         2: areturn
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/cassandra/streaming/StreamSession;

  public int sessionIndex();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.streaming.StreamSession this
         0: .line 208
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.index:I
            ireturn
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/streaming/StreamSession;

  public java.lang.String description();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.streaming.StreamSession this
         0: .line 213
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.streamResult:Lorg/apache/cassandra/streaming/StreamResultFuture;
            ifnonnull 1
            aconst_null
            goto 2
      StackMap locals:
      StackMap stack:
         1: aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.streamResult:Lorg/apache/cassandra/streaming/StreamResultFuture;
            getfield org.apache.cassandra.streaming.StreamResultFuture.description:Ljava/lang/String;
      StackMap locals:
      StackMap stack: java.lang.String
         2: areturn
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/cassandra/streaming/StreamSession;

  public boolean keepSSTableLevel();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.streaming.StreamSession this
         0: .line 218
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.keepSSTableLevel:Z
            ireturn
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/streaming/StreamSession;

  public boolean isIncremental();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.streaming.StreamSession this
         0: .line 223
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.isIncremental:Z
            ireturn
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/streaming/StreamSession;

  org.apache.cassandra.streaming.StreamReceiveTask getReceivingTask(java.util.UUID);
    descriptor: (Ljava/util/UUID;)Lorg/apache/cassandra/streaming/StreamReceiveTask;
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // java.util.UUID cfId
         0: .line 229
            getstatic org.apache.cassandra.streaming.StreamSession.$assertionsDisabled:Z
            ifne 1
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.receivers:Ljava/util/Map;
            aload 1 /* cfId */
            invokeinterface java.util.Map.containsKey:(Ljava/lang/Object;)Z
            ifne 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 230
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.receivers:Ljava/util/Map;
            aload 1 /* cfId */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.streaming.StreamReceiveTask
            areturn
        end local 1 // java.util.UUID cfId
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/cassandra/streaming/StreamSession;
            0    2     1  cfId  Ljava/util/UUID;
    MethodParameters:
      Name  Flags
      cfId  

  private boolean isKeepAliveSupported();
    descriptor: ()Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // org.apache.cassandra.streaming.StreamSession this
         0: .line 235
            getstatic org.apache.cassandra.gms.Gossiper.instance:Lorg/apache/cassandra/gms/Gossiper;
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.peer:Ljava/net/InetAddress;
            invokevirtual org.apache.cassandra.gms.Gossiper.getReleaseVersion:(Ljava/net/InetAddress;)Lorg/apache/cassandra/utils/CassandraVersion;
            astore 1 /* peerVersion */
        start local 1 // org.apache.cassandra.utils.CassandraVersion peerVersion
         1: .line 236
            getstatic org.apache.cassandra.streaming.StreamSession.STREAM_KEEP_ALIVE:Lorg/apache/cassandra/utils/CassandraVersion;
            aload 1 /* peerVersion */
            invokevirtual org.apache.cassandra.utils.CassandraVersion.isSupportedBy:(Lorg/apache/cassandra/utils/CassandraVersion;)Z
            ireturn
        end local 1 // org.apache.cassandra.utils.CassandraVersion peerVersion
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    2     0         this  Lorg/apache/cassandra/streaming/StreamSession;
            1    2     1  peerVersion  Lorg/apache/cassandra/utils/CassandraVersion;

  public void init(org.apache.cassandra.streaming.StreamResultFuture);
    descriptor: (Lorg/apache/cassandra/streaming/StreamResultFuture;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // org.apache.cassandra.streaming.StreamResultFuture streamResult
         0: .line 247
            aload 0 /* this */
            aload 1 /* streamResult */
            putfield org.apache.cassandra.streaming.StreamSession.streamResult:Lorg/apache/cassandra/streaming/StreamResultFuture;
         1: .line 248
            getstatic org.apache.cassandra.streaming.StreamHook.instance:Lorg/apache/cassandra/streaming/StreamHook;
            aload 0 /* this */
            aload 1 /* streamResult */
            invokeinterface org.apache.cassandra.streaming.StreamHook.reportStreamFuture:(Lorg/apache/cassandra/streaming/StreamSession;Lorg/apache/cassandra/streaming/StreamResultFuture;)V
         2: .line 250
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.isKeepAliveSupported:()Z
            ifeq 4
         3: .line 251
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.scheduleKeepAliveTask:()V
            goto 5
         4: .line 253
      StackMap locals:
      StackMap stack:
            getstatic org.apache.cassandra.streaming.StreamSession.logger:Lorg/slf4j/Logger;
            ldc "Peer {} does not support keep-alive."
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.peer:Ljava/net/InetAddress;
            invokeinterface org.slf4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;)V
         5: .line 254
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.apache.cassandra.streaming.StreamResultFuture streamResult
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    6     0          this  Lorg/apache/cassandra/streaming/StreamSession;
            0    6     1  streamResult  Lorg/apache/cassandra/streaming/StreamResultFuture;
    MethodParameters:
              Name  Flags
      streamResult  

  public void start();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=8, locals=2, args_size=1
        start local 0 // org.apache.cassandra.streaming.StreamSession this
         0: .line 258
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.requests:Ljava/util/Set;
            invokeinterface java.util.Set.isEmpty:()Z
            ifeq 4
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.transfers:Ljava/util/concurrent/ConcurrentHashMap;
            invokevirtual java.util.concurrent.ConcurrentHashMap.isEmpty:()Z
            ifeq 4
         1: .line 260
            getstatic org.apache.cassandra.streaming.StreamSession.logger:Lorg/slf4j/Logger;
            ldc "[Stream #{}] Session does not have any tasks."
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.planId:()Ljava/util/UUID;
            invokeinterface org.slf4j.Logger.info:(Ljava/lang/String;Ljava/lang/Object;)V
         2: .line 261
            aload 0 /* this */
            getstatic org.apache.cassandra.streaming.StreamSession$State.COMPLETE:Lorg/apache/cassandra/streaming/StreamSession$State;
            invokevirtual org.apache.cassandra.streaming.StreamSession.closeSession:(Lorg/apache/cassandra/streaming/StreamSession$State;)V
         3: .line 262
            return
         4: .line 267
      StackMap locals:
      StackMap stack:
            getstatic org.apache.cassandra.streaming.StreamSession.logger:Lorg/slf4j/Logger;
            ldc "[Stream #{}] Starting streaming to {}{}"
            iconst_3
            anewarray java.lang.Object
            dup
            iconst_0
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.planId:()Ljava/util/UUID;
            aastore
            dup
            iconst_1
         5: .line 268
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.peer:Ljava/net/InetAddress;
            aastore
            dup
            iconst_2
         6: .line 269
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.peer:Ljava/net/InetAddress;
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.connecting:Ljava/net/InetAddress;
            invokevirtual java.net.InetAddress.equals:(Ljava/lang/Object;)Z
            ifeq 7
            ldc ""
            goto 8
      StackMap locals: org.apache.cassandra.streaming.StreamSession
      StackMap stack: org.slf4j.Logger java.lang.String java.lang.Object[] java.lang.Object[] int
         7: new java.lang.StringBuilder
            dup
            ldc " through "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.connecting:Ljava/net/InetAddress;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/Object;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
      StackMap locals: org.apache.cassandra.streaming.StreamSession
      StackMap stack: org.slf4j.Logger java.lang.String java.lang.Object[] java.lang.Object[] int java.lang.String
         8: aastore
         9: .line 267
            invokeinterface org.slf4j.Logger.info:(Ljava/lang/String;[Ljava/lang/Object;)V
        10: .line 270
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.handler:Lorg/apache/cassandra/streaming/ConnectionHandler;
            invokevirtual org.apache.cassandra.streaming.ConnectionHandler.initiate:()V
        11: .line 271
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.onInitializationComplete:()V
        12: .line 272
            goto 16
        13: .line 273
      StackMap locals:
      StackMap stack: java.lang.Exception
            astore 1 /* e */
        start local 1 // java.lang.Exception e
        14: .line 275
            aload 1 /* e */
            invokestatic org.apache.cassandra.utils.JVMStabilityInspector.inspectThrowable:(Ljava/lang/Throwable;)V
        15: .line 276
            aload 0 /* this */
            aload 1 /* e */
            invokevirtual org.apache.cassandra.streaming.StreamSession.onError:(Ljava/lang/Throwable;)V
        end local 1 // java.lang.Exception e
        16: .line 278
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   17     0  this  Lorg/apache/cassandra/streaming/StreamSession;
           14   16     1     e  Ljava/lang/Exception;
      Exception table:
        from    to  target  type
           4    12      13  Class java.lang.Exception

  public java.net.Socket createConnection();
    descriptor: ()Ljava/net/Socket;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.cassandra.streaming.StreamSession this
         0: .line 282
            getstatic org.apache.cassandra.streaming.StreamSession.$assertionsDisabled:Z
            ifne 1
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.factory:Lorg/apache/cassandra/streaming/StreamConnectionFactory;
            ifnonnull 1
            new java.lang.AssertionError
            dup
            invokespecial java.lang.AssertionError.<init>:()V
            athrow
         1: .line 283
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.factory:Lorg/apache/cassandra/streaming/StreamConnectionFactory;
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.connecting:Ljava/net/InetAddress;
            invokeinterface org.apache.cassandra.streaming.StreamConnectionFactory.createConnection:(Ljava/net/InetAddress;)Ljava/net/Socket;
            areturn
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/cassandra/streaming/StreamSession;
    Exceptions:
      throws java.io.IOException

  public void addStreamRequest(java.lang.String, java.util.Collection<org.apache.cassandra.dht.Range<org.apache.cassandra.dht.Token>>, java.util.Collection<java.lang.String>, );
    descriptor: (Ljava/lang/String;Ljava/util/Collection;Ljava/util/Collection;J)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=8, locals=6, args_size=5
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // java.lang.String keyspace
        start local 2 // java.util.Collection ranges
        start local 3 // java.util.Collection columnFamilies
        start local 4 // long repairedAt
         0: .line 295
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.requests:Ljava/util/Set;
            new org.apache.cassandra.streaming.StreamRequest
            dup
            aload 1 /* keyspace */
            aload 2 /* ranges */
            aload 3 /* columnFamilies */
            lload 4 /* repairedAt */
            invokespecial org.apache.cassandra.streaming.StreamRequest.<init>:(Ljava/lang/String;Ljava/util/Collection;Ljava/util/Collection;J)V
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
         1: .line 296
            return
        end local 4 // long repairedAt
        end local 3 // java.util.Collection columnFamilies
        end local 2 // java.util.Collection ranges
        end local 1 // java.lang.String keyspace
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    2     0            this  Lorg/apache/cassandra/streaming/StreamSession;
            0    2     1        keyspace  Ljava/lang/String;
            0    2     2          ranges  Ljava/util/Collection<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;
            0    2     3  columnFamilies  Ljava/util/Collection<Ljava/lang/String;>;
            0    2     4      repairedAt  J
    Signature: (Ljava/lang/String;Ljava/util/Collection<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;Ljava/util/Collection<Ljava/lang/String;>;J)V
    MethodParameters:
                Name  Flags
      keyspace        
      ranges          
      columnFamilies  
      repairedAt      

  public synchronized void addTransferRanges(java.lang.String, java.util.Collection<org.apache.cassandra.dht.Range<org.apache.cassandra.dht.Token>>, java.util.Collection<java.lang.String>, boolean, );
    descriptor: (Ljava/lang/String;Ljava/util/Collection;Ljava/util/Collection;ZJ)V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=5, locals=14, args_size=6
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // java.lang.String keyspace
        start local 2 // java.util.Collection ranges
        start local 3 // java.util.Collection columnFamilies
        start local 4 // boolean flushTables
        start local 5 // long repairedAt
         0: .line 311
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.failIfFinished:()V
         1: .line 312
            aload 0 /* this */
            aload 1 /* keyspace */
            aload 3 /* columnFamilies */
            invokevirtual org.apache.cassandra.streaming.StreamSession.getColumnFamilyStores:(Ljava/lang/String;Ljava/util/Collection;)Ljava/util/Collection;
            astore 7 /* stores */
        start local 7 // java.util.Collection stores
         2: .line 313
            iload 4 /* flushTables */
            ifeq 4
         3: .line 314
            aload 0 /* this */
            aload 7 /* stores */
            invokevirtual org.apache.cassandra.streaming.StreamSession.flushSSTables:(Ljava/lang/Iterable;)V
         4: .line 316
      StackMap locals: java.util.Collection
      StackMap stack:
            aload 2 /* ranges */
            invokestatic org.apache.cassandra.dht.Range.normalize:(Ljava/util/Collection;)Ljava/util/List;
            astore 8 /* normalizedRanges */
        start local 8 // java.util.List normalizedRanges
         5: .line 317
            aload 8 /* normalizedRanges */
            aload 7 /* stores */
            lload 5 /* repairedAt */
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.isIncremental:Z
            invokestatic org.apache.cassandra.streaming.StreamSession.getSSTableSectionsForRanges:(Ljava/util/Collection;Ljava/util/Collection;JZ)Ljava/util/List;
            astore 9 /* sections */
        start local 9 // java.util.List sections
         6: .line 320
            aload 0 /* this */
            aload 9 /* sections */
            invokevirtual org.apache.cassandra.streaming.StreamSession.addTransferFiles:(Ljava/util/Collection;)V
         7: .line 321
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.transferredRangesPerKeyspace:Ljava/util/Map;
            aload 1 /* keyspace */
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.util.Set
            astore 10 /* toBeUpdated */
        start local 10 // java.util.Set toBeUpdated
         8: .line 322
            aload 10 /* toBeUpdated */
            ifnonnull 10
         9: .line 324
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            astore 10 /* toBeUpdated */
        10: .line 326
      StackMap locals: java.util.List java.util.List java.util.Set
      StackMap stack:
            aload 10 /* toBeUpdated */
            aload 2 /* ranges */
            invokeinterface java.util.Set.addAll:(Ljava/util/Collection;)Z
            pop
        11: .line 327
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.transferredRangesPerKeyspace:Ljava/util/Map;
            aload 1 /* keyspace */
            aload 10 /* toBeUpdated */
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
        end local 10 // java.util.Set toBeUpdated
        12: .line 328
            goto 19
        13: .line 330
      StackMap locals: org.apache.cassandra.streaming.StreamSession java.lang.String java.util.Collection java.util.Collection int long java.util.Collection java.util.List java.util.List
      StackMap stack: java.lang.Throwable
            astore 11
        14: .line 331
            aload 9 /* sections */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 13
            goto 17
      StackMap locals: org.apache.cassandra.streaming.StreamSession java.lang.String java.util.Collection java.util.Collection int long java.util.Collection java.util.List java.util.List top java.lang.Throwable top java.util.Iterator
      StackMap stack:
        15: aload 13
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections
            astore 12 /* release */
        start local 12 // org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections release
        16: .line 332
            aload 12 /* release */
            getfield org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections.ref:Lorg/apache/cassandra/utils/concurrent/Ref;
            invokevirtual org.apache.cassandra.utils.concurrent.Ref.release:()V
        end local 12 // org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections release
        17: .line 331
      StackMap locals:
      StackMap stack:
            aload 13
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 15
        18: .line 333
            aload 11
            athrow
        19: .line 331
      StackMap locals: org.apache.cassandra.streaming.StreamSession java.lang.String java.util.Collection java.util.Collection int long java.util.Collection java.util.List java.util.List
      StackMap stack:
            aload 9 /* sections */
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 13
            goto 22
      StackMap locals: org.apache.cassandra.streaming.StreamSession java.lang.String java.util.Collection java.util.Collection int long java.util.Collection java.util.List java.util.List top top top java.util.Iterator
      StackMap stack:
        20: aload 13
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections
            astore 12 /* release */
        start local 12 // org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections release
        21: .line 332
            aload 12 /* release */
            getfield org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections.ref:Lorg/apache/cassandra/utils/concurrent/Ref;
            invokevirtual org.apache.cassandra.utils.concurrent.Ref.release:()V
        end local 12 // org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections release
        22: .line 331
      StackMap locals:
      StackMap stack:
            aload 13
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 20
        23: .line 334
            return
        end local 9 // java.util.List sections
        end local 8 // java.util.List normalizedRanges
        end local 7 // java.util.Collection stores
        end local 5 // long repairedAt
        end local 4 // boolean flushTables
        end local 3 // java.util.Collection columnFamilies
        end local 2 // java.util.Collection ranges
        end local 1 // java.lang.String keyspace
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0   24     0              this  Lorg/apache/cassandra/streaming/StreamSession;
            0   24     1          keyspace  Ljava/lang/String;
            0   24     2            ranges  Ljava/util/Collection<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;
            0   24     3    columnFamilies  Ljava/util/Collection<Ljava/lang/String;>;
            0   24     4       flushTables  Z
            0   24     5        repairedAt  J
            2   24     7            stores  Ljava/util/Collection<Lorg/apache/cassandra/db/ColumnFamilyStore;>;
            5   24     8  normalizedRanges  Ljava/util/List<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;
            6   24     9          sections  Ljava/util/List<Lorg/apache/cassandra/streaming/StreamSession$SSTableStreamingSections;>;
            8   12    10       toBeUpdated  Ljava/util/Set<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;
           16   17    12           release  Lorg/apache/cassandra/streaming/StreamSession$SSTableStreamingSections;
           21   22    12           release  Lorg/apache/cassandra/streaming/StreamSession$SSTableStreamingSections;
      Exception table:
        from    to  target  type
           6    13      13  any
    Signature: (Ljava/lang/String;Ljava/util/Collection<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;Ljava/util/Collection<Ljava/lang/String;>;ZJ)V
    MethodParameters:
                Name  Flags
      keyspace        
      ranges          
      columnFamilies  
      flushTables     
      repairedAt      

  private void failIfFinished();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=7, locals=1, args_size=1
        start local 0 // org.apache.cassandra.streaming.StreamSession this
         0: .line 338
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.state:()Lorg/apache/cassandra/streaming/StreamSession$State;
            getstatic org.apache.cassandra.streaming.StreamSession$State.COMPLETE:Lorg/apache/cassandra/streaming/StreamSession$State;
            if_acmpeq 1
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.state:()Lorg/apache/cassandra/streaming/StreamSession$State;
            getstatic org.apache.cassandra.streaming.StreamSession$State.FAILED:Lorg/apache/cassandra/streaming/StreamSession$State;
            if_acmpne 2
         1: .line 339
      StackMap locals:
      StackMap stack:
            new java.lang.RuntimeException
            dup
            ldc "Stream %s is finished with state %s"
            iconst_2
            anewarray java.lang.Object
            dup
            iconst_0
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.planId:()Ljava/util/UUID;
            aastore
            dup
            iconst_1
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.state:()Lorg/apache/cassandra/streaming/StreamSession$State;
            invokevirtual org.apache.cassandra.streaming.StreamSession$State.name:()Ljava/lang/String;
            aastore
            invokestatic java.lang.String.format:(Ljava/lang/String;[Ljava/lang/Object;)Ljava/lang/String;
            invokespecial java.lang.RuntimeException.<init>:(Ljava/lang/String;)V
            athrow
         2: .line 340
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/cassandra/streaming/StreamSession;

  private java.util.Collection<org.apache.cassandra.db.ColumnFamilyStore> getColumnFamilyStores(java.lang.String, java.util.Collection<java.lang.String>);
    descriptor: (Ljava/lang/String;Ljava/util/Collection;)Ljava/util/Collection;
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=6, args_size=3
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // java.lang.String keyspace
        start local 2 // java.util.Collection columnFamilies
         0: .line 344
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            astore 3 /* stores */
        start local 3 // java.util.Collection stores
         1: .line 346
            aload 2 /* columnFamilies */
            invokeinterface java.util.Collection.isEmpty:()Z
            ifeq 4
         2: .line 348
            aload 3 /* stores */
            aload 1 /* keyspace */
            invokestatic org.apache.cassandra.db.Keyspace.open:(Ljava/lang/String;)Lorg/apache/cassandra/db/Keyspace;
            invokevirtual org.apache.cassandra.db.Keyspace.getColumnFamilyStores:()Ljava/util/Collection;
            invokeinterface java.util.Collection.addAll:(Ljava/util/Collection;)Z
            pop
         3: .line 349
            goto 8
         4: .line 352
      StackMap locals: java.util.Collection
      StackMap stack:
            aload 2 /* columnFamilies */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 5
            goto 7
      StackMap locals: org.apache.cassandra.streaming.StreamSession java.lang.String java.util.Collection java.util.Collection top java.util.Iterator
      StackMap stack:
         5: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 4 /* cf */
        start local 4 // java.lang.String cf
         6: .line 353
            aload 3 /* stores */
            aload 1 /* keyspace */
            invokestatic org.apache.cassandra.db.Keyspace.open:(Ljava/lang/String;)Lorg/apache/cassandra/db/Keyspace;
            aload 4 /* cf */
            invokevirtual org.apache.cassandra.db.Keyspace.getColumnFamilyStore:(Ljava/lang/String;)Lorg/apache/cassandra/db/ColumnFamilyStore;
            invokeinterface java.util.Collection.add:(Ljava/lang/Object;)Z
            pop
        end local 4 // java.lang.String cf
         7: .line 352
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
         8: .line 355
      StackMap locals: org.apache.cassandra.streaming.StreamSession java.lang.String java.util.Collection java.util.Collection
      StackMap stack:
            aload 3 /* stores */
            areturn
        end local 3 // java.util.Collection stores
        end local 2 // java.util.Collection columnFamilies
        end local 1 // java.lang.String keyspace
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    9     0            this  Lorg/apache/cassandra/streaming/StreamSession;
            0    9     1        keyspace  Ljava/lang/String;
            0    9     2  columnFamilies  Ljava/util/Collection<Ljava/lang/String;>;
            1    9     3          stores  Ljava/util/Collection<Lorg/apache/cassandra/db/ColumnFamilyStore;>;
            6    7     4              cf  Ljava/lang/String;
    Signature: (Ljava/lang/String;Ljava/util/Collection<Ljava/lang/String;>;)Ljava/util/Collection<Lorg/apache/cassandra/db/ColumnFamilyStore;>;
    MethodParameters:
                Name  Flags
      keyspace        
      columnFamilies  

  public static java.util.List<org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections> getSSTableSectionsForRanges(java.util.Collection<org.apache.cassandra.dht.Range<org.apache.cassandra.dht.Token>>, java.util.Collection<org.apache.cassandra.db.ColumnFamilyStore>, long, boolean);
    descriptor: (Ljava/util/Collection;Ljava/util/Collection;JZ)Ljava/util/List;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=9, locals=11, args_size=4
        start local 0 // java.util.Collection ranges
        start local 1 // java.util.Collection stores
        start local 2 // long overriddenRepairedAt
        start local 4 // boolean isIncremental
         0: .line 361
            new org.apache.cassandra.utils.concurrent.Refs
            dup
            invokespecial org.apache.cassandra.utils.concurrent.Refs.<init>:()V
            astore 5 /* refs */
        start local 5 // org.apache.cassandra.utils.concurrent.Refs refs
         1: .line 364
            aload 1 /* stores */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 7
            goto 11
      StackMap locals: java.util.Collection java.util.Collection long int org.apache.cassandra.utils.concurrent.Refs top java.util.Iterator
      StackMap stack:
         2: aload 7
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.db.ColumnFamilyStore
            astore 6 /* cfStore */
        start local 6 // org.apache.cassandra.db.ColumnFamilyStore cfStore
         3: .line 366
            new java.util.ArrayList
            dup
            aload 0 /* ranges */
            invokeinterface java.util.Collection.size:()I
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 8 /* keyRanges */
        start local 8 // java.util.List keyRanges
         4: .line 367
            aload 0 /* ranges */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 10
            goto 7
      StackMap locals: java.util.Collection java.util.Collection long int org.apache.cassandra.utils.concurrent.Refs org.apache.cassandra.db.ColumnFamilyStore java.util.Iterator java.util.List top java.util.Iterator
      StackMap stack:
         5: aload 10
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Range
            astore 9 /* range */
        start local 9 // org.apache.cassandra.dht.Range range
         6: .line 368
            aload 8 /* keyRanges */
            aload 9 /* range */
            invokestatic org.apache.cassandra.dht.Range.makeRowRange:(Lorg/apache/cassandra/dht/Range;)Lorg/apache/cassandra/dht/Range;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 9 // org.apache.cassandra.dht.Range range
         7: .line 367
      StackMap locals:
      StackMap stack:
            aload 10
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
         8: .line 369
            aload 5 /* refs */
            aload 6 /* cfStore */
            aload 8 /* keyRanges */
            iload 4 /* isIncremental */
            invokedynamic apply(Ljava/util/List;Z)Lcom/google/common/base/Function;
              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;)Ljava/lang/Object;
                  org/apache/cassandra/streaming/StreamSession.lambda$0(Ljava/util/List;ZLorg/apache/cassandra/db/lifecycle/View;)Ljava/lang/Iterable; (6)
                  (Lorg/apache/cassandra/db/lifecycle/View;)Ljava/lang/Iterable;
            invokevirtual org.apache.cassandra.db.ColumnFamilyStore.selectAndReference:(Lcom/google/common/base/Function;)Lorg/apache/cassandra/db/ColumnFamilyStore$RefViewFragment;
         9: .line 390
            getfield org.apache.cassandra.db.ColumnFamilyStore$RefViewFragment.refs:Lorg/apache/cassandra/utils/concurrent/Refs;
        10: .line 369
            invokevirtual org.apache.cassandra.utils.concurrent.Refs.addAll:(Lorg/apache/cassandra/utils/concurrent/Refs;)Lorg/apache/cassandra/utils/concurrent/Refs;
            pop
        end local 8 // java.util.List keyRanges
        end local 6 // org.apache.cassandra.db.ColumnFamilyStore cfStore
        11: .line 364
      StackMap locals: java.util.Collection java.util.Collection long int org.apache.cassandra.utils.concurrent.Refs top java.util.Iterator
      StackMap stack:
            aload 7
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
        12: .line 393
            new java.util.ArrayList
            dup
            aload 5 /* refs */
            invokevirtual org.apache.cassandra.utils.concurrent.Refs.size:()I
            invokespecial java.util.ArrayList.<init>:(I)V
            astore 6 /* sections */
        start local 6 // java.util.List sections
        13: .line 394
            aload 5 /* refs */
            invokevirtual org.apache.cassandra.utils.concurrent.Refs.iterator:()Ljava/util/Iterator;
            astore 8
            goto 23
      StackMap locals: java.util.Collection java.util.Collection long int org.apache.cassandra.utils.concurrent.Refs java.util.List top java.util.Iterator
      StackMap stack:
        14: aload 8
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.io.sstable.format.SSTableReader
            astore 7 /* sstable */
        start local 7 // org.apache.cassandra.io.sstable.format.SSTableReader sstable
        15: .line 396
            lload 2 /* overriddenRepairedAt */
            lstore 9 /* repairedAt */
        start local 9 // long repairedAt
        16: .line 397
            lload 2 /* overriddenRepairedAt */
            lconst_0
            lcmp
            ifne 18
        17: .line 398
            aload 7 /* sstable */
            invokevirtual org.apache.cassandra.io.sstable.format.SSTableReader.getSSTableMetadata:()Lorg/apache/cassandra/io/sstable/metadata/StatsMetadata;
            getfield org.apache.cassandra.io.sstable.metadata.StatsMetadata.repairedAt:J
            lstore 9 /* repairedAt */
        18: .line 399
      StackMap locals: java.util.Collection java.util.Collection long int org.apache.cassandra.utils.concurrent.Refs java.util.List org.apache.cassandra.io.sstable.format.SSTableReader java.util.Iterator long
      StackMap stack:
            aload 6 /* sections */
            new org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections
            dup
            aload 5 /* refs */
            aload 7 /* sstable */
            invokevirtual org.apache.cassandra.utils.concurrent.Refs.get:(Lorg/apache/cassandra/utils/concurrent/RefCounted;)Lorg/apache/cassandra/utils/concurrent/Ref;
        19: .line 400
            aload 7 /* sstable */
            aload 0 /* ranges */
            invokevirtual org.apache.cassandra.io.sstable.format.SSTableReader.getPositionsForRanges:(Ljava/util/Collection;)Ljava/util/List;
        20: .line 401
            aload 7 /* sstable */
            aload 0 /* ranges */
            invokevirtual org.apache.cassandra.io.sstable.format.SSTableReader.estimatedKeysForRanges:(Ljava/util/Collection;)J
        21: .line 402
            lload 9 /* repairedAt */
            invokespecial org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections.<init>:(Lorg/apache/cassandra/utils/concurrent/Ref;Ljava/util/List;JJ)V
        22: .line 399
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 9 // long repairedAt
        end local 7 // org.apache.cassandra.io.sstable.format.SSTableReader sstable
        23: .line 394
      StackMap locals: java.util.Collection java.util.Collection long int org.apache.cassandra.utils.concurrent.Refs java.util.List top java.util.Iterator
      StackMap stack:
            aload 8
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 14
        24: .line 404
            aload 6 /* sections */
        25: areturn
        end local 6 // java.util.List sections
        26: .line 406
      StackMap locals: java.util.Collection java.util.Collection long int org.apache.cassandra.utils.concurrent.Refs
      StackMap stack: java.lang.Throwable
            astore 6 /* t */
        start local 6 // java.lang.Throwable t
        27: .line 408
            aload 5 /* refs */
            invokevirtual org.apache.cassandra.utils.concurrent.Refs.release:()V
        28: .line 409
            aload 6 /* t */
            athrow
        end local 6 // java.lang.Throwable t
        end local 5 // org.apache.cassandra.utils.concurrent.Refs refs
        end local 4 // boolean isIncremental
        end local 2 // long overriddenRepairedAt
        end local 1 // java.util.Collection stores
        end local 0 // java.util.Collection ranges
      LocalVariableTable:
        Start  End  Slot                  Name  Signature
            0   29     0                ranges  Ljava/util/Collection<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;
            0   29     1                stores  Ljava/util/Collection<Lorg/apache/cassandra/db/ColumnFamilyStore;>;
            0   29     2  overriddenRepairedAt  J
            0   29     4         isIncremental  Z
            1   29     5                  refs  Lorg/apache/cassandra/utils/concurrent/Refs<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;
            3   11     6               cfStore  Lorg/apache/cassandra/db/ColumnFamilyStore;
            4   11     8             keyRanges  Ljava/util/List<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/db/PartitionPosition;>;>;
            6    7     9                 range  Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;
           13   26     6              sections  Ljava/util/List<Lorg/apache/cassandra/streaming/StreamSession$SSTableStreamingSections;>;
           15   23     7               sstable  Lorg/apache/cassandra/io/sstable/format/SSTableReader;
           16   23     9            repairedAt  J
           27   29     6                     t  Ljava/lang/Throwable;
      Exception table:
        from    to  target  type
           1    25      26  Class java.lang.Throwable
    Signature: (Ljava/util/Collection<Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/dht/Token;>;>;Ljava/util/Collection<Lorg/apache/cassandra/db/ColumnFamilyStore;>;JZ)Ljava/util/List<Lorg/apache/cassandra/streaming/StreamSession$SSTableStreamingSections;>;
    RuntimeInvisibleAnnotations: 
      com.google.common.annotations.VisibleForTesting()
    RuntimeInvisibleTypeAnnotations: 
      METHOD_RETURN
        com.google.common.annotations.VisibleForTesting()
    MethodParameters:
                      Name  Flags
      ranges                
      stores                
      overriddenRepairedAt  
      isIncremental         final

  public synchronized void addTransferFiles(java.util.Collection<org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections>);
    descriptor: (Ljava/util/Collection;)V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=7, locals=7, args_size=2
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // java.util.Collection sstableDetails
         0: .line 415
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.failIfFinished:()V
         1: .line 416
            aload 1 /* sstableDetails */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 2 /* iter */
        start local 2 // java.util.Iterator iter
         2: .line 417
            goto 17
         3: .line 419
      StackMap locals: java.util.Iterator
      StackMap stack:
            aload 2 /* iter */
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections
            astore 3 /* details */
        start local 3 // org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections details
         4: .line 420
            aload 3 /* details */
            getfield org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections.sections:Ljava/util/List;
            invokeinterface java.util.List.isEmpty:()Z
            ifeq 8
         5: .line 423
            aload 3 /* details */
            getfield org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections.ref:Lorg/apache/cassandra/utils/concurrent/Ref;
            invokevirtual org.apache.cassandra.utils.concurrent.Ref.release:()V
         6: .line 424
            aload 2 /* iter */
            invokeinterface java.util.Iterator.remove:()V
         7: .line 425
            goto 17
         8: .line 428
      StackMap locals: org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections
      StackMap stack:
            aload 3 /* details */
            getfield org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections.ref:Lorg/apache/cassandra/utils/concurrent/Ref;
            invokevirtual org.apache.cassandra.utils.concurrent.Ref.get:()Ljava/lang/Object;
            checkcast org.apache.cassandra.io.sstable.format.SSTableReader
            getfield org.apache.cassandra.io.sstable.format.SSTableReader.metadata:Lorg/apache/cassandra/config/CFMetaData;
            getfield org.apache.cassandra.config.CFMetaData.cfId:Ljava/util/UUID;
            astore 4 /* cfId */
        start local 4 // java.util.UUID cfId
         9: .line 429
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.transfers:Ljava/util/concurrent/ConcurrentHashMap;
            aload 4 /* cfId */
            invokevirtual java.util.concurrent.ConcurrentHashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.streaming.StreamTransferTask
            astore 5 /* task */
        start local 5 // org.apache.cassandra.streaming.StreamTransferTask task
        10: .line 430
            aload 5 /* task */
            ifnonnull 15
        11: .line 433
            new org.apache.cassandra.streaming.StreamTransferTask
            dup
            aload 0 /* this */
            aload 4 /* cfId */
            invokespecial org.apache.cassandra.streaming.StreamTransferTask.<init>:(Lorg/apache/cassandra/streaming/StreamSession;Ljava/util/UUID;)V
            astore 6 /* newTask */
        start local 6 // org.apache.cassandra.streaming.StreamTransferTask newTask
        12: .line 434
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.transfers:Ljava/util/concurrent/ConcurrentHashMap;
            aload 4 /* cfId */
            aload 6 /* newTask */
            invokevirtual java.util.concurrent.ConcurrentHashMap.putIfAbsent:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.streaming.StreamTransferTask
            astore 5 /* task */
        13: .line 435
            aload 5 /* task */
            ifnonnull 15
        14: .line 436
            aload 6 /* newTask */
            astore 5 /* task */
        end local 6 // org.apache.cassandra.streaming.StreamTransferTask newTask
        15: .line 438
      StackMap locals: java.util.UUID org.apache.cassandra.streaming.StreamTransferTask
      StackMap stack:
            aload 5 /* task */
            aload 3 /* details */
            getfield org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections.ref:Lorg/apache/cassandra/utils/concurrent/Ref;
            aload 3 /* details */
            getfield org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections.estimatedKeys:J
            aload 3 /* details */
            getfield org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections.sections:Ljava/util/List;
            aload 3 /* details */
            getfield org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections.repairedAt:J
            invokevirtual org.apache.cassandra.streaming.StreamTransferTask.addTransferFile:(Lorg/apache/cassandra/utils/concurrent/Ref;JLjava/util/List;J)V
        16: .line 439
            aload 2 /* iter */
            invokeinterface java.util.Iterator.remove:()V
        end local 5 // org.apache.cassandra.streaming.StreamTransferTask task
        end local 4 // java.util.UUID cfId
        end local 3 // org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections details
        17: .line 417
      StackMap locals:
      StackMap stack:
            aload 2 /* iter */
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
        18: .line 441
            return
        end local 2 // java.util.Iterator iter
        end local 1 // java.util.Collection sstableDetails
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   19     0            this  Lorg/apache/cassandra/streaming/StreamSession;
            0   19     1  sstableDetails  Ljava/util/Collection<Lorg/apache/cassandra/streaming/StreamSession$SSTableStreamingSections;>;
            2   19     2            iter  Ljava/util/Iterator<Lorg/apache/cassandra/streaming/StreamSession$SSTableStreamingSections;>;
            4   17     3         details  Lorg/apache/cassandra/streaming/StreamSession$SSTableStreamingSections;
            9   17     4            cfId  Ljava/util/UUID;
           10   17     5            task  Lorg/apache/cassandra/streaming/StreamTransferTask;
           12   15     6         newTask  Lorg/apache/cassandra/streaming/StreamTransferTask;
    Signature: (Ljava/util/Collection<Lorg/apache/cassandra/streaming/StreamSession$SSTableStreamingSections;>;)V
    MethodParameters:
                Name  Flags
      sstableDetails  

  private synchronized void closeSession(org.apache.cassandra.streaming.StreamSession$State);
    descriptor: (Lorg/apache/cassandra/streaming/StreamSession$State;)V
    flags: (0x0022) ACC_PRIVATE, ACC_SYNCHRONIZED
    Code:
      stack=3, locals=4, args_size=2
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // org.apache.cassandra.streaming.StreamSession$State finalState
         0: .line 461
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.isAborted:Ljava/util/concurrent/atomic/AtomicBoolean;
            iconst_0
            iconst_1
            invokevirtual java.util.concurrent.atomic.AtomicBoolean.compareAndSet:(ZZ)Z
            ifeq 13
         1: .line 463
            aload 0 /* this */
            aload 1 /* finalState */
            invokevirtual org.apache.cassandra.streaming.StreamSession.state:(Lorg/apache/cassandra/streaming/StreamSession$State;)V
         2: .line 465
            aload 1 /* finalState */
            getstatic org.apache.cassandra.streaming.StreamSession$State.FAILED:Lorg/apache/cassandra/streaming/StreamSession$State;
            if_acmpne 7
         3: .line 467
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.receivers:Ljava/util/Map;
            invokeinterface java.util.Map.values:()Ljava/util/Collection;
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.transfers:Ljava/util/concurrent/ConcurrentHashMap;
            invokevirtual java.util.concurrent.ConcurrentHashMap.values:()Ljava/util/Collection;
            invokestatic com.google.common.collect.Iterables.concat:(Ljava/lang/Iterable;Ljava/lang/Iterable;)Ljava/lang/Iterable;
            invokeinterface java.lang.Iterable.iterator:()Ljava/util/Iterator;
            astore 3
            goto 6
      StackMap locals: org.apache.cassandra.streaming.StreamSession org.apache.cassandra.streaming.StreamSession$State top java.util.Iterator
      StackMap stack:
         4: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.streaming.StreamTask
            astore 2 /* task */
        start local 2 // org.apache.cassandra.streaming.StreamTask task
         5: .line 468
            aload 2 /* task */
            invokevirtual org.apache.cassandra.streaming.StreamTask.abort:()V
        end local 2 // org.apache.cassandra.streaming.StreamTask task
         6: .line 467
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 4
         7: .line 471
      StackMap locals: org.apache.cassandra.streaming.StreamSession org.apache.cassandra.streaming.StreamSession$State
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.keepAliveFuture:Ljava/util/concurrent/ScheduledFuture;
            ifnull 11
         8: .line 473
            getstatic org.apache.cassandra.streaming.StreamSession.logger:Lorg/slf4j/Logger;
            ldc "[Stream #{}] Finishing keep-alive task."
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.planId:()Ljava/util/UUID;
            invokeinterface org.slf4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;)V
         9: .line 474
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.keepAliveFuture:Ljava/util/concurrent/ScheduledFuture;
            iconst_0
            invokeinterface java.util.concurrent.ScheduledFuture.cancel:(Z)Z
            pop
        10: .line 475
            aload 0 /* this */
            aconst_null
            putfield org.apache.cassandra.streaming.StreamSession.keepAliveFuture:Ljava/util/concurrent/ScheduledFuture;
        11: .line 480
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.handler:Lorg/apache/cassandra/streaming/ConnectionHandler;
            invokevirtual org.apache.cassandra.streaming.ConnectionHandler.close:()Lcom/google/common/util/concurrent/ListenableFuture;
            pop
        12: .line 482
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.streamResult:Lorg/apache/cassandra/streaming/StreamResultFuture;
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamResultFuture.handleSessionComplete:(Lorg/apache/cassandra/streaming/StreamSession;)V
        13: .line 484
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.apache.cassandra.streaming.StreamSession$State finalState
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   14     0        this  Lorg/apache/cassandra/streaming/StreamSession;
            0   14     1  finalState  Lorg/apache/cassandra/streaming/StreamSession$State;
            5    6     2        task  Lorg/apache/cassandra/streaming/StreamTask;
    MethodParameters:
            Name  Flags
      finalState  

  public void state(org.apache.cassandra.streaming.StreamSession$State);
    descriptor: (Lorg/apache/cassandra/streaming/StreamSession$State;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // org.apache.cassandra.streaming.StreamSession$State newState
         0: .line 493
            aload 0 /* this */
            aload 1 /* newState */
            putfield org.apache.cassandra.streaming.StreamSession.state:Lorg/apache/cassandra/streaming/StreamSession$State;
         1: .line 494
            return
        end local 1 // org.apache.cassandra.streaming.StreamSession$State newState
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lorg/apache/cassandra/streaming/StreamSession;
            0    2     1  newState  Lorg/apache/cassandra/streaming/StreamSession$State;
    MethodParameters:
          Name  Flags
      newState  

  public org.apache.cassandra.streaming.StreamSession$State state();
    descriptor: ()Lorg/apache/cassandra/streaming/StreamSession$State;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.streaming.StreamSession this
         0: .line 501
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.state:Lorg/apache/cassandra/streaming/StreamSession$State;
            areturn
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/streaming/StreamSession;

  public boolean isSuccess();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.cassandra.streaming.StreamSession this
         0: .line 511
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.state:Lorg/apache/cassandra/streaming/StreamSession$State;
            getstatic org.apache.cassandra.streaming.StreamSession$State.COMPLETE:Lorg/apache/cassandra/streaming/StreamSession$State;
            if_acmpne 1
            iconst_1
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_0
            ireturn
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/cassandra/streaming/StreamSession;

  public void messageReceived(org.apache.cassandra.streaming.messages.StreamMessage);
    descriptor: (Lorg/apache/cassandra/streaming/messages/StreamMessage;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=4, args_size=2
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // org.apache.cassandra.streaming.messages.StreamMessage message
         0: .line 516
            invokestatic org.apache.cassandra.streaming.StreamSession.$SWITCH_TABLE$org$apache$cassandra$streaming$messages$StreamMessage$Type:()[I
            aload 1 /* message */
            getfield org.apache.cassandra.streaming.messages.StreamMessage.type:Lorg/apache/cassandra/streaming/messages/StreamMessage$Type;
            invokevirtual org.apache.cassandra.streaming.messages.StreamMessage$Type.ordinal:()I
            iaload
            tableswitch { // 1 - 6
                    1: 1
                    2: 4
                    3: 6
                    4: 12
                    5: 9
                    6: 11
              default: 12
          }
         1: .line 519
      StackMap locals:
      StackMap stack:
            aload 1 /* message */
            checkcast org.apache.cassandra.streaming.messages.PrepareMessage
            astore 2 /* msg */
        start local 2 // org.apache.cassandra.streaming.messages.PrepareMessage msg
         2: .line 520
            aload 0 /* this */
            aload 2 /* msg */
            getfield org.apache.cassandra.streaming.messages.PrepareMessage.requests:Ljava/util/Collection;
            aload 2 /* msg */
            getfield org.apache.cassandra.streaming.messages.PrepareMessage.summaries:Ljava/util/Collection;
            invokevirtual org.apache.cassandra.streaming.StreamSession.prepare:(Ljava/util/Collection;Ljava/util/Collection;)V
         3: .line 521
            goto 12
        end local 2 // org.apache.cassandra.streaming.messages.PrepareMessage msg
         4: .line 524
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            aload 1 /* message */
            checkcast org.apache.cassandra.streaming.messages.IncomingFileMessage
            invokevirtual org.apache.cassandra.streaming.StreamSession.receive:(Lorg/apache/cassandra/streaming/messages/IncomingFileMessage;)V
         5: .line 525
            goto 12
         6: .line 528
      StackMap locals:
      StackMap stack:
            aload 1 /* message */
            checkcast org.apache.cassandra.streaming.messages.ReceivedMessage
            astore 3 /* received */
        start local 3 // org.apache.cassandra.streaming.messages.ReceivedMessage received
         7: .line 529
            aload 0 /* this */
            aload 3 /* received */
            getfield org.apache.cassandra.streaming.messages.ReceivedMessage.cfId:Ljava/util/UUID;
            aload 3 /* received */
            getfield org.apache.cassandra.streaming.messages.ReceivedMessage.sequenceNumber:I
            invokevirtual org.apache.cassandra.streaming.StreamSession.received:(Ljava/util/UUID;I)V
         8: .line 530
            goto 12
        end local 3 // org.apache.cassandra.streaming.messages.ReceivedMessage received
         9: .line 533
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.complete:()V
        10: .line 534
            goto 12
        11: .line 537
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.sessionFailed:()V
        12: .line 540
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.apache.cassandra.streaming.messages.StreamMessage message
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   13     0      this  Lorg/apache/cassandra/streaming/StreamSession;
            0   13     1   message  Lorg/apache/cassandra/streaming/messages/StreamMessage;
            2    4     2       msg  Lorg/apache/cassandra/streaming/messages/PrepareMessage;
            7    9     3  received  Lorg/apache/cassandra/streaming/messages/ReceivedMessage;
    MethodParameters:
         Name  Flags
      message  

  public void onInitializationComplete();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=4, args_size=1
        start local 0 // org.apache.cassandra.streaming.StreamSession this
         0: .line 548
            aload 0 /* this */
            getstatic org.apache.cassandra.streaming.StreamSession$State.PREPARING:Lorg/apache/cassandra/streaming/StreamSession$State;
            invokevirtual org.apache.cassandra.streaming.StreamSession.state:(Lorg/apache/cassandra/streaming/StreamSession$State;)V
         1: .line 549
            new org.apache.cassandra.streaming.messages.PrepareMessage
            dup
            invokespecial org.apache.cassandra.streaming.messages.PrepareMessage.<init>:()V
            astore 1 /* prepare */
        start local 1 // org.apache.cassandra.streaming.messages.PrepareMessage prepare
         2: .line 550
            aload 1 /* prepare */
            getfield org.apache.cassandra.streaming.messages.PrepareMessage.requests:Ljava/util/Collection;
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.requests:Ljava/util/Set;
            invokeinterface java.util.Collection.addAll:(Ljava/util/Collection;)Z
            pop
         3: .line 551
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.transfers:Ljava/util/concurrent/ConcurrentHashMap;
            invokevirtual java.util.concurrent.ConcurrentHashMap.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 3
            goto 6
      StackMap locals: org.apache.cassandra.streaming.StreamSession org.apache.cassandra.streaming.messages.PrepareMessage top java.util.Iterator
      StackMap stack:
         4: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.streaming.StreamTransferTask
            astore 2 /* task */
        start local 2 // org.apache.cassandra.streaming.StreamTransferTask task
         5: .line 552
            aload 1 /* prepare */
            getfield org.apache.cassandra.streaming.messages.PrepareMessage.summaries:Ljava/util/Collection;
            aload 2 /* task */
            invokevirtual org.apache.cassandra.streaming.StreamTransferTask.getSummary:()Lorg/apache/cassandra/streaming/StreamSummary;
            invokeinterface java.util.Collection.add:(Ljava/lang/Object;)Z
            pop
        end local 2 // org.apache.cassandra.streaming.StreamTransferTask task
         6: .line 551
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 4
         7: .line 553
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.handler:Lorg/apache/cassandra/streaming/ConnectionHandler;
            aload 1 /* prepare */
            invokevirtual org.apache.cassandra.streaming.ConnectionHandler.sendMessage:(Lorg/apache/cassandra/streaming/messages/StreamMessage;)V
         8: .line 556
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.requests:Ljava/util/Set;
            invokeinterface java.util.Set.isEmpty:()Z
            ifeq 10
         9: .line 557
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.startStreamingFiles:()V
        10: .line 558
      StackMap locals: org.apache.cassandra.streaming.StreamSession org.apache.cassandra.streaming.messages.PrepareMessage
      StackMap stack:
            return
        end local 1 // org.apache.cassandra.streaming.messages.PrepareMessage prepare
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0   11     0     this  Lorg/apache/cassandra/streaming/StreamSession;
            2   11     1  prepare  Lorg/apache/cassandra/streaming/messages/PrepareMessage;
            5    6     2     task  Lorg/apache/cassandra/streaming/StreamTransferTask;

  public void onError(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // java.lang.Throwable e
         0: .line 567
            aload 0 /* this */
            aload 1 /* e */
            invokevirtual org.apache.cassandra.streaming.StreamSession.logError:(Ljava/lang/Throwable;)V
         1: .line 569
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.handler:Lorg/apache/cassandra/streaming/ConnectionHandler;
            invokevirtual org.apache.cassandra.streaming.ConnectionHandler.isOutgoingConnected:()Z
            ifeq 3
         2: .line 570
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.handler:Lorg/apache/cassandra/streaming/ConnectionHandler;
            new org.apache.cassandra.streaming.messages.SessionFailedMessage
            dup
            invokespecial org.apache.cassandra.streaming.messages.SessionFailedMessage.<init>:()V
            invokevirtual org.apache.cassandra.streaming.ConnectionHandler.sendMessage:(Lorg/apache/cassandra/streaming/messages/StreamMessage;)V
         3: .line 572
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getstatic org.apache.cassandra.streaming.StreamSession$State.FAILED:Lorg/apache/cassandra/streaming/StreamSession$State;
            invokevirtual org.apache.cassandra.streaming.StreamSession.closeSession:(Lorg/apache/cassandra/streaming/StreamSession$State;)V
         4: .line 573
            return
        end local 1 // java.lang.Throwable e
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lorg/apache/cassandra/streaming/StreamSession;
            0    5     1     e  Ljava/lang/Throwable;
    MethodParameters:
      Name  Flags
      e     

  private void logError(java.lang.Throwable);
    descriptor: (Ljava/lang/Throwable;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=8, locals=2, args_size=2
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // java.lang.Throwable e
         0: .line 577
            aload 1 /* e */
            instanceof java.net.SocketTimeoutException
            ifeq 16
         1: .line 579
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.isKeepAliveSupported:()Z
            ifeq 12
         2: .line 580
            getstatic org.apache.cassandra.streaming.StreamSession.logger:Lorg/slf4j/Logger;
            ldc "[Stream #{}] Did not receive response from peer {}{} for {} secs. Is peer down? If not, maybe try increasing streaming_keep_alive_period_in_secs."
            iconst_5
            anewarray java.lang.Object
            dup
            iconst_0
         3: .line 581
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.planId:()Ljava/util/UUID;
            aastore
            dup
            iconst_1
         4: .line 582
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.peer:Ljava/net/InetAddress;
            invokevirtual java.net.InetAddress.getHostAddress:()Ljava/lang/String;
            aastore
            dup
            iconst_2
         5: .line 583
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.peer:Ljava/net/InetAddress;
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.connecting:Ljava/net/InetAddress;
            invokevirtual java.net.InetAddress.equals:(Ljava/lang/Object;)Z
            ifeq 6
            ldc ""
            goto 7
      StackMap locals: org.apache.cassandra.streaming.StreamSession java.lang.Throwable
      StackMap stack: org.slf4j.Logger java.lang.String java.lang.Object[] java.lang.Object[] int
         6: new java.lang.StringBuilder
            dup
            ldc " through "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.connecting:Ljava/net/InetAddress;
            invokevirtual java.net.InetAddress.getHostAddress:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
      StackMap locals: org.apache.cassandra.streaming.StreamSession java.lang.Throwable
      StackMap stack: org.slf4j.Logger java.lang.String java.lang.Object[] java.lang.Object[] int java.lang.String
         7: aastore
            dup
            iconst_3
         8: .line 584
            iconst_2
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.getStreamingKeepAlivePeriod:()I
            imul
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            dup
            iconst_4
         9: .line 585
            aload 1 /* e */
            aastore
        10: .line 580
            invokeinterface org.slf4j.Logger.error:(Ljava/lang/String;[Ljava/lang/Object;)V
        11: .line 585
            goto 23
        12: .line 587
      StackMap locals:
      StackMap stack:
            getstatic org.apache.cassandra.streaming.StreamSession.logger:Lorg/slf4j/Logger;
            ldc "[Stream #{}] Streaming socket timed out. This means the session peer stopped responding or is still processing received data. If there is no sign of failure in the other end or a very dense table is being transferred you may want to increase streaming_socket_timeout_in_ms property. Current value is {}ms."
            iconst_3
            anewarray java.lang.Object
            dup
            iconst_0
        13: .line 590
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.planId:()Ljava/util/UUID;
            aastore
            dup
            iconst_1
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.getStreamingSocketTimeout:()I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aastore
            dup
            iconst_2
            aload 1 /* e */
            aastore
        14: .line 587
            invokeinterface org.slf4j.Logger.error:(Ljava/lang/String;[Ljava/lang/Object;)V
        15: .line 591
            goto 23
        16: .line 594
      StackMap locals:
      StackMap stack:
            getstatic org.apache.cassandra.streaming.StreamSession.logger:Lorg/slf4j/Logger;
            ldc "[Stream #{}] Streaming error occurred on session with peer {}{}"
            iconst_4
            anewarray java.lang.Object
            dup
            iconst_0
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.planId:()Ljava/util/UUID;
            aastore
            dup
            iconst_1
        17: .line 595
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.peer:Ljava/net/InetAddress;
            invokevirtual java.net.InetAddress.getHostAddress:()Ljava/lang/String;
            aastore
            dup
            iconst_2
        18: .line 596
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.peer:Ljava/net/InetAddress;
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.connecting:Ljava/net/InetAddress;
            invokevirtual java.net.InetAddress.equals:(Ljava/lang/Object;)Z
            ifeq 19
            ldc ""
            goto 20
      StackMap locals: org.apache.cassandra.streaming.StreamSession java.lang.Throwable
      StackMap stack: org.slf4j.Logger java.lang.String java.lang.Object[] java.lang.Object[] int
        19: new java.lang.StringBuilder
            dup
            ldc " through "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.connecting:Ljava/net/InetAddress;
            invokevirtual java.net.InetAddress.getHostAddress:()Ljava/lang/String;
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
      StackMap locals: org.apache.cassandra.streaming.StreamSession java.lang.Throwable
      StackMap stack: org.slf4j.Logger java.lang.String java.lang.Object[] java.lang.Object[] int java.lang.String
        20: aastore
            dup
            iconst_3
        21: .line 597
            aload 1 /* e */
            aastore
        22: .line 594
            invokeinterface org.slf4j.Logger.error:(Ljava/lang/String;[Ljava/lang/Object;)V
        23: .line 599
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.lang.Throwable e
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   24     0  this  Lorg/apache/cassandra/streaming/StreamSession;
            0   24     1     e  Ljava/lang/Throwable;
    MethodParameters:
      Name  Flags
      e     

  public void prepare(java.util.Collection<org.apache.cassandra.streaming.StreamRequest>, java.util.Collection<org.apache.cassandra.streaming.StreamSummary>);
    descriptor: (Ljava/util/Collection;Ljava/util/Collection;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=7, locals=6, args_size=3
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // java.util.Collection requests
        start local 2 // java.util.Collection summaries
         0: .line 607
            aload 0 /* this */
            getstatic org.apache.cassandra.streaming.StreamSession$State.PREPARING:Lorg/apache/cassandra/streaming/StreamSession$State;
            invokevirtual org.apache.cassandra.streaming.StreamSession.state:(Lorg/apache/cassandra/streaming/StreamSession$State;)V
         1: .line 608
            aload 1 /* requests */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 4
            goto 4
      StackMap locals: org.apache.cassandra.streaming.StreamSession java.util.Collection java.util.Collection top java.util.Iterator
      StackMap stack:
         2: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.streaming.StreamRequest
            astore 3 /* request */
        start local 3 // org.apache.cassandra.streaming.StreamRequest request
         3: .line 609
            aload 0 /* this */
            aload 3 /* request */
            getfield org.apache.cassandra.streaming.StreamRequest.keyspace:Ljava/lang/String;
            aload 3 /* request */
            getfield org.apache.cassandra.streaming.StreamRequest.ranges:Ljava/util/Collection;
            aload 3 /* request */
            getfield org.apache.cassandra.streaming.StreamRequest.columnFamilies:Ljava/util/Collection;
            iconst_1
            aload 3 /* request */
            getfield org.apache.cassandra.streaming.StreamRequest.repairedAt:J
            invokevirtual org.apache.cassandra.streaming.StreamSession.addTransferRanges:(Ljava/lang/String;Ljava/util/Collection;Ljava/util/Collection;ZJ)V
        end local 3 // org.apache.cassandra.streaming.StreamRequest request
         4: .line 608
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 610
            aload 2 /* summaries */
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 4
            goto 8
      StackMap locals:
      StackMap stack:
         6: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.streaming.StreamSummary
            astore 3 /* summary */
        start local 3 // org.apache.cassandra.streaming.StreamSummary summary
         7: .line 611
            aload 0 /* this */
            aload 3 /* summary */
            invokevirtual org.apache.cassandra.streaming.StreamSession.prepareReceiving:(Lorg/apache/cassandra/streaming/StreamSummary;)V
        end local 3 // org.apache.cassandra.streaming.StreamSummary summary
         8: .line 610
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 6
         9: .line 614
            aload 1 /* requests */
            invokeinterface java.util.Collection.isEmpty:()Z
            ifne 16
        10: .line 616
            new org.apache.cassandra.streaming.messages.PrepareMessage
            dup
            invokespecial org.apache.cassandra.streaming.messages.PrepareMessage.<init>:()V
            astore 3 /* prepare */
        start local 3 // org.apache.cassandra.streaming.messages.PrepareMessage prepare
        11: .line 617
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.transfers:Ljava/util/concurrent/ConcurrentHashMap;
            invokevirtual java.util.concurrent.ConcurrentHashMap.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 5
            goto 14
      StackMap locals: org.apache.cassandra.streaming.StreamSession java.util.Collection java.util.Collection org.apache.cassandra.streaming.messages.PrepareMessage top java.util.Iterator
      StackMap stack:
        12: aload 5
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.streaming.StreamTransferTask
            astore 4 /* task */
        start local 4 // org.apache.cassandra.streaming.StreamTransferTask task
        13: .line 618
            aload 3 /* prepare */
            getfield org.apache.cassandra.streaming.messages.PrepareMessage.summaries:Ljava/util/Collection;
            aload 4 /* task */
            invokevirtual org.apache.cassandra.streaming.StreamTransferTask.getSummary:()Lorg/apache/cassandra/streaming/StreamSummary;
            invokeinterface java.util.Collection.add:(Ljava/lang/Object;)Z
            pop
        end local 4 // org.apache.cassandra.streaming.StreamTransferTask task
        14: .line 617
      StackMap locals:
      StackMap stack:
            aload 5
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 12
        15: .line 619
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.handler:Lorg/apache/cassandra/streaming/ConnectionHandler;
            aload 3 /* prepare */
            invokevirtual org.apache.cassandra.streaming.ConnectionHandler.sendMessage:(Lorg/apache/cassandra/streaming/messages/StreamMessage;)V
        end local 3 // org.apache.cassandra.streaming.messages.PrepareMessage prepare
        16: .line 623
      StackMap locals: org.apache.cassandra.streaming.StreamSession java.util.Collection java.util.Collection
      StackMap stack:
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.maybeCompleted:()Z
            ifne 18
        17: .line 624
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.startStreamingFiles:()V
        18: .line 625
      StackMap locals:
      StackMap stack:
            return
        end local 2 // java.util.Collection summaries
        end local 1 // java.util.Collection requests
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   19     0       this  Lorg/apache/cassandra/streaming/StreamSession;
            0   19     1   requests  Ljava/util/Collection<Lorg/apache/cassandra/streaming/StreamRequest;>;
            0   19     2  summaries  Ljava/util/Collection<Lorg/apache/cassandra/streaming/StreamSummary;>;
            3    4     3    request  Lorg/apache/cassandra/streaming/StreamRequest;
            7    8     3    summary  Lorg/apache/cassandra/streaming/StreamSummary;
           11   16     3    prepare  Lorg/apache/cassandra/streaming/messages/PrepareMessage;
           13   14     4       task  Lorg/apache/cassandra/streaming/StreamTransferTask;
    Signature: (Ljava/util/Collection<Lorg/apache/cassandra/streaming/StreamRequest;>;Ljava/util/Collection<Lorg/apache/cassandra/streaming/StreamSummary;>;)V
    MethodParameters:
           Name  Flags
      requests   
      summaries  

  public void fileSent(org.apache.cassandra.streaming.messages.FileMessageHeader);
    descriptor: (Lorg/apache/cassandra/streaming/messages/FileMessageHeader;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=5, args_size=2
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // org.apache.cassandra.streaming.messages.FileMessageHeader header
         0: .line 634
            aload 1 /* header */
            invokevirtual org.apache.cassandra.streaming.messages.FileMessageHeader.size:()J
            lstore 2 /* headerSize */
        start local 2 // long headerSize
         1: .line 635
            getstatic org.apache.cassandra.metrics.StreamingMetrics.totalOutgoingBytes:Lcom/codahale/metrics/Counter;
            lload 2 /* headerSize */
            invokevirtual com.codahale.metrics.Counter.inc:(J)V
         2: .line 636
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.metrics:Lorg/apache/cassandra/metrics/StreamingMetrics;
            getfield org.apache.cassandra.metrics.StreamingMetrics.outgoingBytes:Lcom/codahale/metrics/Counter;
            lload 2 /* headerSize */
            invokevirtual com.codahale.metrics.Counter.inc:(J)V
         3: .line 638
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.transfers:Ljava/util/concurrent/ConcurrentHashMap;
            aload 1 /* header */
            getfield org.apache.cassandra.streaming.messages.FileMessageHeader.cfId:Ljava/util/UUID;
            invokevirtual java.util.concurrent.ConcurrentHashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.streaming.StreamTransferTask
            astore 4 /* task */
        start local 4 // org.apache.cassandra.streaming.StreamTransferTask task
         4: .line 639
            aload 4 /* task */
            ifnull 6
         5: .line 641
            aload 4 /* task */
            aload 1 /* header */
            getfield org.apache.cassandra.streaming.messages.FileMessageHeader.sequenceNumber:I
            ldc 12
            getstatic java.util.concurrent.TimeUnit.HOURS:Ljava/util/concurrent/TimeUnit;
            invokevirtual org.apache.cassandra.streaming.StreamTransferTask.scheduleTimeout:(IJLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;
            pop
         6: .line 643
      StackMap locals: long org.apache.cassandra.streaming.StreamTransferTask
      StackMap stack:
            return
        end local 4 // org.apache.cassandra.streaming.StreamTransferTask task
        end local 2 // long headerSize
        end local 1 // org.apache.cassandra.streaming.messages.FileMessageHeader header
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    7     0        this  Lorg/apache/cassandra/streaming/StreamSession;
            0    7     1      header  Lorg/apache/cassandra/streaming/messages/FileMessageHeader;
            1    7     2  headerSize  J
            4    7     4        task  Lorg/apache/cassandra/streaming/StreamTransferTask;
    MethodParameters:
        Name  Flags
      header  

  public void receive(org.apache.cassandra.streaming.messages.IncomingFileMessage);
    descriptor: (Lorg/apache/cassandra/streaming/messages/IncomingFileMessage;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=2
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // org.apache.cassandra.streaming.messages.IncomingFileMessage message
         0: .line 652
            aload 1 /* message */
            getfield org.apache.cassandra.streaming.messages.IncomingFileMessage.header:Lorg/apache/cassandra/streaming/messages/FileMessageHeader;
            invokevirtual org.apache.cassandra.streaming.messages.FileMessageHeader.size:()J
            lstore 2 /* headerSize */
        start local 2 // long headerSize
         1: .line 653
            getstatic org.apache.cassandra.metrics.StreamingMetrics.totalIncomingBytes:Lcom/codahale/metrics/Counter;
            lload 2 /* headerSize */
            invokevirtual com.codahale.metrics.Counter.inc:(J)V
         2: .line 654
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.metrics:Lorg/apache/cassandra/metrics/StreamingMetrics;
            getfield org.apache.cassandra.metrics.StreamingMetrics.incomingBytes:Lcom/codahale/metrics/Counter;
            lload 2 /* headerSize */
            invokevirtual com.codahale.metrics.Counter.inc:(J)V
         3: .line 656
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.handler:Lorg/apache/cassandra/streaming/ConnectionHandler;
            new org.apache.cassandra.streaming.messages.ReceivedMessage
            dup
            aload 1 /* message */
            getfield org.apache.cassandra.streaming.messages.IncomingFileMessage.header:Lorg/apache/cassandra/streaming/messages/FileMessageHeader;
            getfield org.apache.cassandra.streaming.messages.FileMessageHeader.cfId:Ljava/util/UUID;
            aload 1 /* message */
            getfield org.apache.cassandra.streaming.messages.IncomingFileMessage.header:Lorg/apache/cassandra/streaming/messages/FileMessageHeader;
            getfield org.apache.cassandra.streaming.messages.FileMessageHeader.sequenceNumber:I
            invokespecial org.apache.cassandra.streaming.messages.ReceivedMessage.<init>:(Ljava/util/UUID;I)V
            invokevirtual org.apache.cassandra.streaming.ConnectionHandler.sendMessage:(Lorg/apache/cassandra/streaming/messages/StreamMessage;)V
         4: .line 657
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.receivers:Ljava/util/Map;
            aload 1 /* message */
            getfield org.apache.cassandra.streaming.messages.IncomingFileMessage.header:Lorg/apache/cassandra/streaming/messages/FileMessageHeader;
            getfield org.apache.cassandra.streaming.messages.FileMessageHeader.cfId:Ljava/util/UUID;
            invokeinterface java.util.Map.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.streaming.StreamReceiveTask
            aload 1 /* message */
            getfield org.apache.cassandra.streaming.messages.IncomingFileMessage.sstable:Lorg/apache/cassandra/io/sstable/SSTableMultiWriter;
            invokevirtual org.apache.cassandra.streaming.StreamReceiveTask.received:(Lorg/apache/cassandra/io/sstable/SSTableMultiWriter;)V
         5: .line 658
            return
        end local 2 // long headerSize
        end local 1 // org.apache.cassandra.streaming.messages.IncomingFileMessage message
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    6     0        this  Lorg/apache/cassandra/streaming/StreamSession;
            0    6     1     message  Lorg/apache/cassandra/streaming/messages/IncomingFileMessage;
            1    6     2  headerSize  J
    MethodParameters:
         Name  Flags
      message  

  public void progress(java.lang.String, org.apache.cassandra.streaming.ProgressInfo$Direction, long, long);
    descriptor: (Ljava/lang/String;Lorg/apache/cassandra/streaming/ProgressInfo$Direction;JJ)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=10, locals=8, args_size=5
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // java.lang.String filename
        start local 2 // org.apache.cassandra.streaming.ProgressInfo$Direction direction
        start local 3 // long bytes
        start local 5 // long total
         0: .line 662
            new org.apache.cassandra.streaming.ProgressInfo
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.peer:Ljava/net/InetAddress;
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.index:I
            aload 1 /* filename */
            aload 2 /* direction */
            lload 3 /* bytes */
            lload 5 /* total */
            invokespecial org.apache.cassandra.streaming.ProgressInfo.<init>:(Ljava/net/InetAddress;ILjava/lang/String;Lorg/apache/cassandra/streaming/ProgressInfo$Direction;JJ)V
            astore 7 /* progress */
        start local 7 // org.apache.cassandra.streaming.ProgressInfo progress
         1: .line 663
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.streamResult:Lorg/apache/cassandra/streaming/StreamResultFuture;
            aload 7 /* progress */
            invokevirtual org.apache.cassandra.streaming.StreamResultFuture.handleProgress:(Lorg/apache/cassandra/streaming/ProgressInfo;)V
         2: .line 664
            return
        end local 7 // org.apache.cassandra.streaming.ProgressInfo progress
        end local 5 // long total
        end local 3 // long bytes
        end local 2 // org.apache.cassandra.streaming.ProgressInfo$Direction direction
        end local 1 // java.lang.String filename
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    3     0       this  Lorg/apache/cassandra/streaming/StreamSession;
            0    3     1   filename  Ljava/lang/String;
            0    3     2  direction  Lorg/apache/cassandra/streaming/ProgressInfo$Direction;
            0    3     3      bytes  J
            0    3     5      total  J
            1    3     7   progress  Lorg/apache/cassandra/streaming/ProgressInfo;
    MethodParameters:
           Name  Flags
      filename   
      direction  
      bytes      
      total      

  public void received(java.util.UUID, int);
    descriptor: (Ljava/util/UUID;I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // java.util.UUID cfId
        start local 2 // int sequenceNumber
         0: .line 668
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.transfers:Ljava/util/concurrent/ConcurrentHashMap;
            aload 1 /* cfId */
            invokevirtual java.util.concurrent.ConcurrentHashMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast org.apache.cassandra.streaming.StreamTransferTask
            iload 2 /* sequenceNumber */
            invokevirtual org.apache.cassandra.streaming.StreamTransferTask.complete:(I)V
         1: .line 669
            return
        end local 2 // int sequenceNumber
        end local 1 // java.util.UUID cfId
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    2     0            this  Lorg/apache/cassandra/streaming/StreamSession;
            0    2     1            cfId  Ljava/util/UUID;
            0    2     2  sequenceNumber  I
    MethodParameters:
                Name  Flags
      cfId            
      sequenceNumber  

  public synchronized void complete();
    descriptor: ()V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // org.apache.cassandra.streaming.StreamSession this
         0: .line 676
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.state:Lorg/apache/cassandra/streaming/StreamSession$State;
            getstatic org.apache.cassandra.streaming.StreamSession$State.WAIT_COMPLETE:Lorg/apache/cassandra/streaming/StreamSession$State;
            if_acmpne 6
         1: .line 678
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.completeSent:Z
            ifne 4
         2: .line 680
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.handler:Lorg/apache/cassandra/streaming/ConnectionHandler;
            new org.apache.cassandra.streaming.messages.CompleteMessage
            dup
            invokespecial org.apache.cassandra.streaming.messages.CompleteMessage.<init>:()V
            invokevirtual org.apache.cassandra.streaming.ConnectionHandler.sendMessage:(Lorg/apache/cassandra/streaming/messages/StreamMessage;)V
         3: .line 681
            aload 0 /* this */
            iconst_1
            putfield org.apache.cassandra.streaming.StreamSession.completeSent:Z
         4: .line 683
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getstatic org.apache.cassandra.streaming.StreamSession$State.COMPLETE:Lorg/apache/cassandra/streaming/StreamSession$State;
            invokevirtual org.apache.cassandra.streaming.StreamSession.closeSession:(Lorg/apache/cassandra/streaming/StreamSession$State;)V
         5: .line 684
            goto 8
         6: .line 687
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getstatic org.apache.cassandra.streaming.StreamSession$State.WAIT_COMPLETE:Lorg/apache/cassandra/streaming/StreamSession$State;
            invokevirtual org.apache.cassandra.streaming.StreamSession.state:(Lorg/apache/cassandra/streaming/StreamSession$State;)V
         7: .line 688
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.handler:Lorg/apache/cassandra/streaming/ConnectionHandler;
            invokevirtual org.apache.cassandra.streaming.ConnectionHandler.closeIncoming:()Lcom/google/common/util/concurrent/ListenableFuture;
            pop
         8: .line 690
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    9     0  this  Lorg/apache/cassandra/streaming/StreamSession;

  private synchronized void scheduleKeepAliveTask();
    descriptor: ()V
    flags: (0x0022) ACC_PRIVATE, ACC_SYNCHRONIZED
    Code:
      stack=8, locals=2, args_size=1
        start local 0 // org.apache.cassandra.streaming.StreamSession this
         0: .line 694
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.keepAliveFuture:Ljava/util/concurrent/ScheduledFuture;
            ifnonnull 4
         1: .line 696
            invokestatic org.apache.cassandra.config.DatabaseDescriptor.getStreamingKeepAlivePeriod:()I
            istore 1 /* keepAlivePeriod */
        start local 1 // int keepAlivePeriod
         2: .line 697
            getstatic org.apache.cassandra.streaming.StreamSession.logger:Lorg/slf4j/Logger;
            ldc "[Stream #{}] Scheduling keep-alive task with {}s period."
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.planId:()Ljava/util/UUID;
            iload 1 /* keepAlivePeriod */
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokeinterface org.slf4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
         3: .line 698
            aload 0 /* this */
            getstatic org.apache.cassandra.streaming.StreamSession.keepAliveExecutor:Lorg/apache/cassandra/concurrent/DebuggableScheduledThreadPoolExecutor;
            new org.apache.cassandra.streaming.StreamSession$KeepAliveTask
            dup
            aload 0 /* this */
            invokespecial org.apache.cassandra.streaming.StreamSession$KeepAliveTask.<init>:(Lorg/apache/cassandra/streaming/StreamSession;)V
            lconst_0
            iload 1 /* keepAlivePeriod */
            i2l
            getstatic java.util.concurrent.TimeUnit.SECONDS:Ljava/util/concurrent/TimeUnit;
            invokevirtual org.apache.cassandra.concurrent.DebuggableScheduledThreadPoolExecutor.scheduleAtFixedRate:(Ljava/lang/Runnable;JJLjava/util/concurrent/TimeUnit;)Ljava/util/concurrent/ScheduledFuture;
            putfield org.apache.cassandra.streaming.StreamSession.keepAliveFuture:Ljava/util/concurrent/ScheduledFuture;
        end local 1 // int keepAlivePeriod
         4: .line 700
      StackMap locals:
      StackMap stack:
            return
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    5     0             this  Lorg/apache/cassandra/streaming/StreamSession;
            2    4     1  keepAlivePeriod  I

  public synchronized void sessionFailed();
    descriptor: ()V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // org.apache.cassandra.streaming.StreamSession this
         0: .line 707
            getstatic org.apache.cassandra.streaming.StreamSession.logger:Lorg/slf4j/Logger;
            ldc "[Stream #{}] Remote peer {} failed stream session."
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.planId:()Ljava/util/UUID;
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.peer:Ljava/net/InetAddress;
            invokevirtual java.net.InetAddress.getHostAddress:()Ljava/lang/String;
            invokeinterface org.slf4j.Logger.error:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
         1: .line 708
            aload 0 /* this */
            getstatic org.apache.cassandra.streaming.StreamSession$State.FAILED:Lorg/apache/cassandra/streaming/StreamSession$State;
            invokevirtual org.apache.cassandra.streaming.StreamSession.closeSession:(Lorg/apache/cassandra/streaming/StreamSession$State;)V
         2: .line 709
            return
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lorg/apache/cassandra/streaming/StreamSession;

  public org.apache.cassandra.streaming.SessionInfo getSessionInfo();
    descriptor: ()Lorg/apache/cassandra/streaming/SessionInfo;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=8, locals=5, args_size=1
        start local 0 // org.apache.cassandra.streaming.StreamSession this
         0: .line 716
            invokestatic com.google.common.collect.Lists.newArrayList:()Ljava/util/ArrayList;
            astore 1 /* receivingSummaries */
        start local 1 // java.util.List receivingSummaries
         1: .line 717
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.receivers: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.StreamSession java.util.List top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.streaming.StreamTask
            astore 2 /* receiver */
        start local 2 // org.apache.cassandra.streaming.StreamTask receiver
         3: .line 718
            aload 1 /* receivingSummaries */
            aload 2 /* receiver */
            invokevirtual org.apache.cassandra.streaming.StreamTask.getSummary:()Lorg/apache/cassandra/streaming/StreamSummary;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 2 // org.apache.cassandra.streaming.StreamTask receiver
         4: .line 717
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 719
            invokestatic com.google.common.collect.Lists.newArrayList:()Ljava/util/ArrayList;
            astore 2 /* transferSummaries */
        start local 2 // java.util.List transferSummaries
         6: .line 720
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.transfers:Ljava/util/concurrent/ConcurrentHashMap;
            invokevirtual java.util.concurrent.ConcurrentHashMap.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 4
            goto 9
      StackMap locals: org.apache.cassandra.streaming.StreamSession java.util.List java.util.List top java.util.Iterator
      StackMap stack:
         7: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.streaming.StreamTask
            astore 3 /* transfer */
        start local 3 // org.apache.cassandra.streaming.StreamTask transfer
         8: .line 721
            aload 2 /* transferSummaries */
            aload 3 /* transfer */
            invokevirtual org.apache.cassandra.streaming.StreamTask.getSummary:()Lorg/apache/cassandra/streaming/StreamSummary;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 3 // org.apache.cassandra.streaming.StreamTask transfer
         9: .line 720
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 7
        10: .line 722
            new org.apache.cassandra.streaming.SessionInfo
            dup
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.peer:Ljava/net/InetAddress;
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.index:I
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.connecting:Ljava/net/InetAddress;
            aload 1 /* receivingSummaries */
            aload 2 /* transferSummaries */
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.state:Lorg/apache/cassandra/streaming/StreamSession$State;
            invokespecial org.apache.cassandra.streaming.SessionInfo.<init>:(Ljava/net/InetAddress;ILjava/net/InetAddress;Ljava/util/Collection;Ljava/util/Collection;Lorg/apache/cassandra/streaming/StreamSession$State;)V
            areturn
        end local 2 // java.util.List transferSummaries
        end local 1 // java.util.List receivingSummaries
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0   11     0                this  Lorg/apache/cassandra/streaming/StreamSession;
            1   11     1  receivingSummaries  Ljava/util/List<Lorg/apache/cassandra/streaming/StreamSummary;>;
            3    4     2            receiver  Lorg/apache/cassandra/streaming/StreamTask;
            6   11     2   transferSummaries  Ljava/util/List<Lorg/apache/cassandra/streaming/StreamSummary;>;
            8    9     3            transfer  Lorg/apache/cassandra/streaming/StreamTask;

  public synchronized void taskCompleted(org.apache.cassandra.streaming.StreamReceiveTask);
    descriptor: (Lorg/apache/cassandra/streaming/StreamReceiveTask;)V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // org.apache.cassandra.streaming.StreamReceiveTask completedTask
         0: .line 727
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.receivers:Ljava/util/Map;
            aload 1 /* completedTask */
            getfield org.apache.cassandra.streaming.StreamReceiveTask.cfId:Ljava/util/UUID;
            invokeinterface java.util.Map.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         1: .line 728
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.maybeCompleted:()Z
            pop
         2: .line 729
            return
        end local 1 // org.apache.cassandra.streaming.StreamReceiveTask completedTask
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    3     0           this  Lorg/apache/cassandra/streaming/StreamSession;
            0    3     1  completedTask  Lorg/apache/cassandra/streaming/StreamReceiveTask;
    MethodParameters:
               Name  Flags
      completedTask  

  public synchronized void taskCompleted(org.apache.cassandra.streaming.StreamTransferTask);
    descriptor: (Lorg/apache/cassandra/streaming/StreamTransferTask;)V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // org.apache.cassandra.streaming.StreamTransferTask completedTask
         0: .line 733
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.transfers:Ljava/util/concurrent/ConcurrentHashMap;
            aload 1 /* completedTask */
            getfield org.apache.cassandra.streaming.StreamTransferTask.cfId:Ljava/util/UUID;
            invokevirtual java.util.concurrent.ConcurrentHashMap.remove:(Ljava/lang/Object;)Ljava/lang/Object;
            pop
         1: .line 734
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.maybeCompleted:()Z
            pop
         2: .line 735
            return
        end local 1 // org.apache.cassandra.streaming.StreamTransferTask completedTask
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    3     0           this  Lorg/apache/cassandra/streaming/StreamSession;
            0    3     1  completedTask  Lorg/apache/cassandra/streaming/StreamTransferTask;
    MethodParameters:
               Name  Flags
      completedTask  

  public void onJoin(java.net.InetAddress, org.apache.cassandra.gms.EndpointState);
    descriptor: (Ljava/net/InetAddress;Lorg/apache/cassandra/gms/EndpointState;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=0, locals=3, args_size=3
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // java.net.InetAddress endpoint
        start local 2 // org.apache.cassandra.gms.EndpointState epState
         0: .line 737
            return
        end local 2 // org.apache.cassandra.gms.EndpointState epState
        end local 1 // java.net.InetAddress endpoint
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    1     0      this  Lorg/apache/cassandra/streaming/StreamSession;
            0    1     1  endpoint  Ljava/net/InetAddress;
            0    1     2   epState  Lorg/apache/cassandra/gms/EndpointState;
    MethodParameters:
          Name  Flags
      endpoint  
      epState   

  public void beforeChange(java.net.InetAddress, org.apache.cassandra.gms.EndpointState, org.apache.cassandra.gms.ApplicationState, org.apache.cassandra.gms.VersionedValue);
    descriptor: (Ljava/net/InetAddress;Lorg/apache/cassandra/gms/EndpointState;Lorg/apache/cassandra/gms/ApplicationState;Lorg/apache/cassandra/gms/VersionedValue;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=0, locals=5, args_size=5
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // java.net.InetAddress endpoint
        start local 2 // org.apache.cassandra.gms.EndpointState currentState
        start local 3 // org.apache.cassandra.gms.ApplicationState newStateKey
        start local 4 // org.apache.cassandra.gms.VersionedValue newValue
         0: .line 738
            return
        end local 4 // org.apache.cassandra.gms.VersionedValue newValue
        end local 3 // org.apache.cassandra.gms.ApplicationState newStateKey
        end local 2 // org.apache.cassandra.gms.EndpointState currentState
        end local 1 // java.net.InetAddress endpoint
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0    1     0          this  Lorg/apache/cassandra/streaming/StreamSession;
            0    1     1      endpoint  Ljava/net/InetAddress;
            0    1     2  currentState  Lorg/apache/cassandra/gms/EndpointState;
            0    1     3   newStateKey  Lorg/apache/cassandra/gms/ApplicationState;
            0    1     4      newValue  Lorg/apache/cassandra/gms/VersionedValue;
    MethodParameters:
              Name  Flags
      endpoint      
      currentState  
      newStateKey   
      newValue      

  public void onChange(java.net.InetAddress, org.apache.cassandra.gms.ApplicationState, org.apache.cassandra.gms.VersionedValue);
    descriptor: (Ljava/net/InetAddress;Lorg/apache/cassandra/gms/ApplicationState;Lorg/apache/cassandra/gms/VersionedValue;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=0, locals=4, args_size=4
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // java.net.InetAddress endpoint
        start local 2 // org.apache.cassandra.gms.ApplicationState state
        start local 3 // org.apache.cassandra.gms.VersionedValue value
         0: .line 739
            return
        end local 3 // org.apache.cassandra.gms.VersionedValue value
        end local 2 // org.apache.cassandra.gms.ApplicationState state
        end local 1 // java.net.InetAddress endpoint
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    1     0      this  Lorg/apache/cassandra/streaming/StreamSession;
            0    1     1  endpoint  Ljava/net/InetAddress;
            0    1     2     state  Lorg/apache/cassandra/gms/ApplicationState;
            0    1     3     value  Lorg/apache/cassandra/gms/VersionedValue;
    MethodParameters:
          Name  Flags
      endpoint  
      state     
      value     

  public void onAlive(java.net.InetAddress, org.apache.cassandra.gms.EndpointState);
    descriptor: (Ljava/net/InetAddress;Lorg/apache/cassandra/gms/EndpointState;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=0, locals=3, args_size=3
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // java.net.InetAddress endpoint
        start local 2 // org.apache.cassandra.gms.EndpointState state
         0: .line 740
            return
        end local 2 // org.apache.cassandra.gms.EndpointState state
        end local 1 // java.net.InetAddress endpoint
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    1     0      this  Lorg/apache/cassandra/streaming/StreamSession;
            0    1     1  endpoint  Ljava/net/InetAddress;
            0    1     2     state  Lorg/apache/cassandra/gms/EndpointState;
    MethodParameters:
          Name  Flags
      endpoint  
      state     

  public void onDead(java.net.InetAddress, org.apache.cassandra.gms.EndpointState);
    descriptor: (Ljava/net/InetAddress;Lorg/apache/cassandra/gms/EndpointState;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=0, locals=3, args_size=3
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // java.net.InetAddress endpoint
        start local 2 // org.apache.cassandra.gms.EndpointState state
         0: .line 741
            return
        end local 2 // org.apache.cassandra.gms.EndpointState state
        end local 1 // java.net.InetAddress endpoint
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    1     0      this  Lorg/apache/cassandra/streaming/StreamSession;
            0    1     1  endpoint  Ljava/net/InetAddress;
            0    1     2     state  Lorg/apache/cassandra/gms/EndpointState;
    MethodParameters:
          Name  Flags
      endpoint  
      state     

  public void onRemove(java.net.InetAddress);
    descriptor: (Ljava/net/InetAddress;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // java.net.InetAddress endpoint
         0: .line 745
            getstatic org.apache.cassandra.streaming.StreamSession.logger:Lorg/slf4j/Logger;
            ldc "[Stream #{}] Session failed because remote peer {} has left."
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.planId:()Ljava/util/UUID;
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.peer:Ljava/net/InetAddress;
            invokevirtual java.net.InetAddress.getHostAddress:()Ljava/lang/String;
            invokeinterface org.slf4j.Logger.error:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
         1: .line 746
            aload 0 /* this */
            getstatic org.apache.cassandra.streaming.StreamSession$State.FAILED:Lorg/apache/cassandra/streaming/StreamSession$State;
            invokevirtual org.apache.cassandra.streaming.StreamSession.closeSession:(Lorg/apache/cassandra/streaming/StreamSession$State;)V
         2: .line 747
            return
        end local 1 // java.net.InetAddress endpoint
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    3     0      this  Lorg/apache/cassandra/streaming/StreamSession;
            0    3     1  endpoint  Ljava/net/InetAddress;
    MethodParameters:
          Name  Flags
      endpoint  

  public void onRestart(java.net.InetAddress, org.apache.cassandra.gms.EndpointState);
    descriptor: (Ljava/net/InetAddress;Lorg/apache/cassandra/gms/EndpointState;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // java.net.InetAddress endpoint
        start local 2 // org.apache.cassandra.gms.EndpointState epState
         0: .line 751
            getstatic org.apache.cassandra.streaming.StreamSession.logger:Lorg/slf4j/Logger;
            ldc "[Stream #{}] Session failed because remote peer {} was restarted."
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.planId:()Ljava/util/UUID;
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.peer:Ljava/net/InetAddress;
            invokevirtual java.net.InetAddress.getHostAddress:()Ljava/lang/String;
            invokeinterface org.slf4j.Logger.error:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
         1: .line 752
            aload 0 /* this */
            getstatic org.apache.cassandra.streaming.StreamSession$State.FAILED:Lorg/apache/cassandra/streaming/StreamSession$State;
            invokevirtual org.apache.cassandra.streaming.StreamSession.closeSession:(Lorg/apache/cassandra/streaming/StreamSession$State;)V
         2: .line 753
            return
        end local 2 // org.apache.cassandra.gms.EndpointState epState
        end local 1 // java.net.InetAddress endpoint
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    3     0      this  Lorg/apache/cassandra/streaming/StreamSession;
            0    3     1  endpoint  Ljava/net/InetAddress;
            0    3     2   epState  Lorg/apache/cassandra/gms/EndpointState;
    MethodParameters:
          Name  Flags
      endpoint  
      epState   

  private boolean maybeCompleted();
    descriptor: ()Z
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=2, args_size=1
        start local 0 // org.apache.cassandra.streaming.StreamSession this
         0: .line 757
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.receivers:Ljava/util/Map;
            invokeinterface java.util.Map.isEmpty:()Z
            ifeq 1
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.transfers:Ljava/util/concurrent/ConcurrentHashMap;
            invokevirtual java.util.concurrent.ConcurrentHashMap.isEmpty:()Z
            ifeq 1
            iconst_1
            goto 2
      StackMap locals:
      StackMap stack:
         1: iconst_0
      StackMap locals:
      StackMap stack: int
         2: istore 1 /* completed */
        start local 1 // boolean completed
         3: .line 758
            iload 1 /* completed */
            ifeq 14
         4: .line 760
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.state:Lorg/apache/cassandra/streaming/StreamSession$State;
            getstatic org.apache.cassandra.streaming.StreamSession$State.WAIT_COMPLETE:Lorg/apache/cassandra/streaming/StreamSession$State;
            if_acmpne 10
         5: .line 762
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.completeSent:Z
            ifne 8
         6: .line 764
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.handler:Lorg/apache/cassandra/streaming/ConnectionHandler;
            new org.apache.cassandra.streaming.messages.CompleteMessage
            dup
            invokespecial org.apache.cassandra.streaming.messages.CompleteMessage.<init>:()V
            invokevirtual org.apache.cassandra.streaming.ConnectionHandler.sendMessage:(Lorg/apache/cassandra/streaming/messages/StreamMessage;)V
         7: .line 765
            aload 0 /* this */
            iconst_1
            putfield org.apache.cassandra.streaming.StreamSession.completeSent:Z
         8: .line 767
      StackMap locals: int
      StackMap stack:
            aload 0 /* this */
            getstatic org.apache.cassandra.streaming.StreamSession$State.COMPLETE:Lorg/apache/cassandra/streaming/StreamSession$State;
            invokevirtual org.apache.cassandra.streaming.StreamSession.closeSession:(Lorg/apache/cassandra/streaming/StreamSession$State;)V
         9: .line 768
            goto 14
        10: .line 772
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.handler:Lorg/apache/cassandra/streaming/ConnectionHandler;
            new org.apache.cassandra.streaming.messages.CompleteMessage
            dup
            invokespecial org.apache.cassandra.streaming.messages.CompleteMessage.<init>:()V
            invokevirtual org.apache.cassandra.streaming.ConnectionHandler.sendMessage:(Lorg/apache/cassandra/streaming/messages/StreamMessage;)V
        11: .line 773
            aload 0 /* this */
            iconst_1
            putfield org.apache.cassandra.streaming.StreamSession.completeSent:Z
        12: .line 774
            aload 0 /* this */
            getstatic org.apache.cassandra.streaming.StreamSession$State.WAIT_COMPLETE:Lorg/apache/cassandra/streaming/StreamSession$State;
            invokevirtual org.apache.cassandra.streaming.StreamSession.state:(Lorg/apache/cassandra/streaming/StreamSession$State;)V
        13: .line 775
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.handler:Lorg/apache/cassandra/streaming/ConnectionHandler;
            invokevirtual org.apache.cassandra.streaming.ConnectionHandler.closeOutgoing:()Lcom/google/common/util/concurrent/ListenableFuture;
            pop
        14: .line 778
      StackMap locals:
      StackMap stack:
            iload 1 /* completed */
            ireturn
        end local 1 // boolean completed
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0   15     0       this  Lorg/apache/cassandra/streaming/StreamSession;
            3   15     1  completed  Z

  private void flushSSTables(java.lang.Iterable<org.apache.cassandra.db.ColumnFamilyStore>);
    descriptor: (Ljava/lang/Iterable;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=5, args_size=2
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // java.lang.Iterable stores
         0: .line 787
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 2 /* flushes */
        start local 2 // java.util.List flushes
         1: .line 788
            aload 1 /* stores */
            invokeinterface java.lang.Iterable.iterator:()Ljava/util/Iterator;
            astore 4
            goto 4
      StackMap locals: org.apache.cassandra.streaming.StreamSession java.lang.Iterable java.util.List top java.util.Iterator
      StackMap stack:
         2: aload 4
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.db.ColumnFamilyStore
            astore 3 /* cfs */
        start local 3 // org.apache.cassandra.db.ColumnFamilyStore cfs
         3: .line 789
            aload 2 /* flushes */
            aload 3 /* cfs */
            invokevirtual org.apache.cassandra.db.ColumnFamilyStore.forceFlush:()Lcom/google/common/util/concurrent/ListenableFuture;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 3 // org.apache.cassandra.db.ColumnFamilyStore cfs
         4: .line 788
      StackMap locals:
      StackMap stack:
            aload 4
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 790
            aload 2 /* flushes */
            invokestatic org.apache.cassandra.utils.FBUtilities.waitOnFutures:(Ljava/lang/Iterable;)Ljava/util/List;
            pop
         6: .line 791
            return
        end local 2 // java.util.List flushes
        end local 1 // java.lang.Iterable stores
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    7     0     this  Lorg/apache/cassandra/streaming/StreamSession;
            0    7     1   stores  Ljava/lang/Iterable<Lorg/apache/cassandra/db/ColumnFamilyStore;>;
            1    7     2  flushes  Ljava/util/List<Ljava/util/concurrent/Future<*>;>;
            3    4     3      cfs  Lorg/apache/cassandra/db/ColumnFamilyStore;
    Signature: (Ljava/lang/Iterable<Lorg/apache/cassandra/db/ColumnFamilyStore;>;)V
    MethodParameters:
        Name  Flags
      stores  

  private synchronized void prepareReceiving(org.apache.cassandra.streaming.StreamSummary);
    descriptor: (Lorg/apache/cassandra/streaming/StreamSummary;)V
    flags: (0x0022) ACC_PRIVATE, ACC_SYNCHRONIZED
    Code:
      stack=9, locals=2, args_size=2
        start local 0 // org.apache.cassandra.streaming.StreamSession this
        start local 1 // org.apache.cassandra.streaming.StreamSummary summary
         0: .line 795
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamSession.failIfFinished:()V
         1: .line 796
            aload 1 /* summary */
            getfield org.apache.cassandra.streaming.StreamSummary.files:I
            ifle 3
         2: .line 797
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.receivers:Ljava/util/Map;
            aload 1 /* summary */
            getfield org.apache.cassandra.streaming.StreamSummary.cfId:Ljava/util/UUID;
            new org.apache.cassandra.streaming.StreamReceiveTask
            dup
            aload 0 /* this */
            aload 1 /* summary */
            getfield org.apache.cassandra.streaming.StreamSummary.cfId:Ljava/util/UUID;
            aload 1 /* summary */
            getfield org.apache.cassandra.streaming.StreamSummary.files:I
            aload 1 /* summary */
            getfield org.apache.cassandra.streaming.StreamSummary.totalSize:J
            invokespecial org.apache.cassandra.streaming.StreamReceiveTask.<init>:(Lorg/apache/cassandra/streaming/StreamSession;Ljava/util/UUID;IJ)V
            invokeinterface java.util.Map.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         3: .line 798
      StackMap locals:
      StackMap stack:
            return
        end local 1 // org.apache.cassandra.streaming.StreamSummary summary
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    4     0     this  Lorg/apache/cassandra/streaming/StreamSession;
            0    4     1  summary  Lorg/apache/cassandra/streaming/StreamSummary;
    MethodParameters:
         Name  Flags
      summary  

  private void startStreamingFiles();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=4, args_size=1
        start local 0 // org.apache.cassandra.streaming.StreamSession this
         0: .line 802
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.streamResult:Lorg/apache/cassandra/streaming/StreamResultFuture;
            aload 0 /* this */
            invokevirtual org.apache.cassandra.streaming.StreamResultFuture.handleSessionPrepared:(Lorg/apache/cassandra/streaming/StreamSession;)V
         1: .line 804
            aload 0 /* this */
            getstatic org.apache.cassandra.streaming.StreamSession$State.STREAMING:Lorg/apache/cassandra/streaming/StreamSession$State;
            invokevirtual org.apache.cassandra.streaming.StreamSession.state:(Lorg/apache/cassandra/streaming/StreamSession$State;)V
         2: .line 805
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.transfers:Ljava/util/concurrent/ConcurrentHashMap;
            invokevirtual java.util.concurrent.ConcurrentHashMap.values:()Ljava/util/Collection;
            invokeinterface java.util.Collection.iterator:()Ljava/util/Iterator;
            astore 2
            goto 8
      StackMap locals: org.apache.cassandra.streaming.StreamSession top java.util.Iterator
      StackMap stack:
         3: aload 2
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.streaming.StreamTransferTask
            astore 1 /* task */
        start local 1 // org.apache.cassandra.streaming.StreamTransferTask task
         4: .line 807
            aload 1 /* task */
            invokevirtual org.apache.cassandra.streaming.StreamTransferTask.getFileMessages:()Ljava/util/Collection;
            astore 3 /* messages */
        start local 3 // java.util.Collection messages
         5: .line 808
            aload 3 /* messages */
            invokeinterface java.util.Collection.size:()I
            ifle 7
         6: .line 809
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.StreamSession.handler:Lorg/apache/cassandra/streaming/ConnectionHandler;
            aload 3 /* messages */
            invokevirtual org.apache.cassandra.streaming.ConnectionHandler.sendMessages:(Ljava/util/Collection;)V
            goto 8
         7: .line 811
      StackMap locals: org.apache.cassandra.streaming.StreamSession org.apache.cassandra.streaming.StreamTransferTask java.util.Iterator java.util.Collection
      StackMap stack:
            aload 0 /* this */
            aload 1 /* task */
            invokevirtual org.apache.cassandra.streaming.StreamSession.taskCompleted:(Lorg/apache/cassandra/streaming/StreamTransferTask;)V
        end local 3 // java.util.Collection messages
        end local 1 // org.apache.cassandra.streaming.StreamTransferTask task
         8: .line 805
      StackMap locals: org.apache.cassandra.streaming.StreamSession top java.util.Iterator
      StackMap stack:
            aload 2
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
         9: .line 813
            return
        end local 0 // org.apache.cassandra.streaming.StreamSession this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   10     0      this  Lorg/apache/cassandra/streaming/StreamSession;
            4    8     1      task  Lorg/apache/cassandra/streaming/StreamTransferTask;
            5    8     3  messages  Ljava/util/Collection<Lorg/apache/cassandra/streaming/messages/OutgoingFileMessage;>;

  public static void shutdownAndWait(long, java.util.concurrent.TimeUnit);
    descriptor: (JLjava/util/concurrent/TimeUnit;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=4, locals=4, args_size=2
        start local 0 // long timeout
        start local 2 // java.util.concurrent.TimeUnit unit
         0: .line 845
            getstatic org.apache.cassandra.streaming.StreamSession.keepAliveExecutor:Lorg/apache/cassandra/concurrent/DebuggableScheduledThreadPoolExecutor;
            invokestatic com.google.common.collect.ImmutableList.of:(Ljava/lang/Object;)Lcom/google/common/collect/ImmutableList;
            astore 3 /* executors */
        start local 3 // java.util.List executors
         1: .line 846
            aload 3 /* executors */
            invokestatic org.apache.cassandra.utils.ExecutorUtils.shutdownNow:(Ljava/lang/Iterable;)V
         2: .line 847
            lload 0 /* timeout */
            aload 2 /* unit */
            aload 3 /* executors */
            invokestatic org.apache.cassandra.utils.ExecutorUtils.awaitTermination:(JLjava/util/concurrent/TimeUnit;Ljava/util/Collection;)V
         3: .line 848
            return
        end local 3 // java.util.List executors
        end local 2 // java.util.concurrent.TimeUnit unit
        end local 0 // long timeout
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    4     0    timeout  J
            0    4     2       unit  Ljava/util/concurrent/TimeUnit;
            1    4     3  executors  Ljava/util/List<Ljava/util/concurrent/ExecutorService;>;
    Exceptions:
      throws java.lang.InterruptedException, java.util.concurrent.TimeoutException
    RuntimeInvisibleAnnotations: 
      com.google.common.annotations.VisibleForTesting()
    MethodParameters:
         Name  Flags
      timeout  
      unit     

  static int[] $SWITCH_TABLE$org$apache$cassandra$streaming$messages$StreamMessage$Type();
    descriptor: ()[I
    flags: (0x1008) ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=3, locals=1, args_size=0
         0: .line 120
            getstatic org.apache.cassandra.streaming.StreamSession.$SWITCH_TABLE$org$apache$cassandra$streaming$messages$StreamMessage$Type:[I
            dup
            ifnull 1
            areturn
      StackMap locals:
      StackMap stack: int[]
         1: pop
            invokestatic org.apache.cassandra.streaming.messages.StreamMessage$Type.values:()[Lorg/apache/cassandra/streaming/messages/StreamMessage$Type;
            arraylength
            newarray 10
            astore 0
         2: aload 0
            getstatic org.apache.cassandra.streaming.messages.StreamMessage$Type.COMPLETE:Lorg/apache/cassandra/streaming/messages/StreamMessage$Type;
            invokevirtual org.apache.cassandra.streaming.messages.StreamMessage$Type.ordinal:()I
            iconst_5
            iastore
         3: goto 5
      StackMap locals: int[]
      StackMap stack: java.lang.NoSuchFieldError
         4: pop
      StackMap locals:
      StackMap stack:
         5: aload 0
            getstatic org.apache.cassandra.streaming.messages.StreamMessage$Type.FILE:Lorg/apache/cassandra/streaming/messages/StreamMessage$Type;
            invokevirtual org.apache.cassandra.streaming.messages.StreamMessage$Type.ordinal:()I
            iconst_2
            iastore
         6: goto 8
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
         7: pop
      StackMap locals:
      StackMap stack:
         8: aload 0
            getstatic org.apache.cassandra.streaming.messages.StreamMessage$Type.KEEP_ALIVE:Lorg/apache/cassandra/streaming/messages/StreamMessage$Type;
            invokevirtual org.apache.cassandra.streaming.messages.StreamMessage$Type.ordinal:()I
            bipush 7
            iastore
         9: goto 11
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
        10: pop
      StackMap locals:
      StackMap stack:
        11: aload 0
            getstatic org.apache.cassandra.streaming.messages.StreamMessage$Type.PREPARE:Lorg/apache/cassandra/streaming/messages/StreamMessage$Type;
            invokevirtual org.apache.cassandra.streaming.messages.StreamMessage$Type.ordinal:()I
            iconst_1
            iastore
        12: goto 14
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
        13: pop
      StackMap locals:
      StackMap stack:
        14: aload 0
            getstatic org.apache.cassandra.streaming.messages.StreamMessage$Type.RECEIVED:Lorg/apache/cassandra/streaming/messages/StreamMessage$Type;
            invokevirtual org.apache.cassandra.streaming.messages.StreamMessage$Type.ordinal:()I
            iconst_3
            iastore
        15: goto 17
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
        16: pop
      StackMap locals:
      StackMap stack:
        17: aload 0
            getstatic org.apache.cassandra.streaming.messages.StreamMessage$Type.RETRY:Lorg/apache/cassandra/streaming/messages/StreamMessage$Type;
            invokevirtual org.apache.cassandra.streaming.messages.StreamMessage$Type.ordinal:()I
            iconst_4
            iastore
        18: goto 20
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
        19: pop
      StackMap locals:
      StackMap stack:
        20: aload 0
            getstatic org.apache.cassandra.streaming.messages.StreamMessage$Type.SESSION_FAILED:Lorg/apache/cassandra/streaming/messages/StreamMessage$Type;
            invokevirtual org.apache.cassandra.streaming.messages.StreamMessage$Type.ordinal:()I
            bipush 6
            iastore
        21: goto 23
      StackMap locals:
      StackMap stack: java.lang.NoSuchFieldError
        22: pop
      StackMap locals:
      StackMap stack:
        23: aload 0
            dup
            putstatic org.apache.cassandra.streaming.StreamSession.$SWITCH_TABLE$org$apache$cassandra$streaming$messages$StreamMessage$Type:[I
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
      Exception table:
        from    to  target  type
           2     3       4  Class java.lang.NoSuchFieldError
           5     6       7  Class java.lang.NoSuchFieldError
           8     9      10  Class java.lang.NoSuchFieldError
          11    12      13  Class java.lang.NoSuchFieldError
          14    15      16  Class java.lang.NoSuchFieldError
          17    18      19  Class java.lang.NoSuchFieldError
          20    21      22  Class java.lang.NoSuchFieldError

  private static java.lang.Iterable lambda$0(java.util.List, boolean, org.apache.cassandra.db.lifecycle.View);
    descriptor: (Ljava/util/List;ZLorg/apache/cassandra/db/lifecycle/View;)Ljava/lang/Iterable;
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=5, locals=9, args_size=3
        start local 2 // org.apache.cassandra.db.lifecycle.View view
         0: .line 370
            invokestatic com.google.common.collect.Sets.newHashSet:()Ljava/util/HashSet;
            astore 3 /* sstables */
        start local 3 // java.util.Set sstables
         1: .line 371
            aload 2 /* view */
            getstatic org.apache.cassandra.db.lifecycle.SSTableSet.CANONICAL:Lorg/apache/cassandra/db/lifecycle/SSTableSet;
            invokevirtual org.apache.cassandra.db.lifecycle.View.select:(Lorg/apache/cassandra/db/lifecycle/SSTableSet;)Ljava/lang/Iterable;
            invokestatic org.apache.cassandra.db.lifecycle.SSTableIntervalTree.build:(Ljava/lang/Iterable;)Lorg/apache/cassandra/db/lifecycle/SSTableIntervalTree;
            astore 4 /* intervalTree */
        start local 4 // org.apache.cassandra.db.lifecycle.SSTableIntervalTree intervalTree
         2: .line 372
            aload 0
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 6
            goto 9
      StackMap locals: java.util.List int org.apache.cassandra.db.lifecycle.View java.util.Set org.apache.cassandra.db.lifecycle.SSTableIntervalTree top java.util.Iterator
      StackMap stack:
         3: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.dht.Range
            astore 5 /* keyRange */
        start local 5 // org.apache.cassandra.dht.Range keyRange
         4: .line 380
            aload 5 /* keyRange */
            getfield org.apache.cassandra.dht.Range.left:Lorg/apache/cassandra/dht/RingPosition;
            checkcast org.apache.cassandra.db.PartitionPosition
            aload 5 /* keyRange */
            getfield org.apache.cassandra.dht.Range.right:Lorg/apache/cassandra/dht/RingPosition;
            checkcast org.apache.cassandra.db.PartitionPosition
            aload 4 /* intervalTree */
            invokestatic org.apache.cassandra.db.lifecycle.View.sstablesInBounds:(Lorg/apache/cassandra/db/PartitionPosition;Lorg/apache/cassandra/db/PartitionPosition;Lorg/apache/cassandra/db/lifecycle/SSTableIntervalTree;)Ljava/util/List;
            invokeinterface java.util.List.iterator:()Ljava/util/Iterator;
            astore 8
            goto 8
      StackMap locals: java.util.List int org.apache.cassandra.db.lifecycle.View java.util.Set org.apache.cassandra.db.lifecycle.SSTableIntervalTree org.apache.cassandra.dht.Range java.util.Iterator top java.util.Iterator
      StackMap stack:
         5: aload 8
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast org.apache.cassandra.io.sstable.format.SSTableReader
            astore 7 /* sstable */
        start local 7 // org.apache.cassandra.io.sstable.format.SSTableReader sstable
         6: .line 382
            iload 1
            ifeq 7
            aload 7 /* sstable */
            invokevirtual org.apache.cassandra.io.sstable.format.SSTableReader.isRepaired:()Z
            ifne 8
         7: .line 383
      StackMap locals: java.util.List int org.apache.cassandra.db.lifecycle.View java.util.Set org.apache.cassandra.db.lifecycle.SSTableIntervalTree org.apache.cassandra.dht.Range java.util.Iterator org.apache.cassandra.io.sstable.format.SSTableReader java.util.Iterator
      StackMap stack:
            aload 3 /* sstables */
            aload 7 /* sstable */
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
        end local 7 // org.apache.cassandra.io.sstable.format.SSTableReader sstable
         8: .line 380
      StackMap locals: java.util.List int org.apache.cassandra.db.lifecycle.View java.util.Set org.apache.cassandra.db.lifecycle.SSTableIntervalTree org.apache.cassandra.dht.Range java.util.Iterator top java.util.Iterator
      StackMap stack:
            aload 8
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 5
        end local 5 // org.apache.cassandra.dht.Range keyRange
         9: .line 372
      StackMap locals: java.util.List int org.apache.cassandra.db.lifecycle.View java.util.Set org.apache.cassandra.db.lifecycle.SSTableIntervalTree top java.util.Iterator
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 3
        10: .line 387
            getstatic org.apache.cassandra.streaming.StreamSession.logger:Lorg/slf4j/Logger;
            invokeinterface org.slf4j.Logger.isDebugEnabled:()Z
            ifeq 12
        11: .line 388
            getstatic org.apache.cassandra.streaming.StreamSession.logger:Lorg/slf4j/Logger;
            ldc "ViewFilter for {}/{} sstables"
            aload 3 /* sstables */
            invokeinterface java.util.Set.size:()I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            aload 2 /* view */
            getstatic org.apache.cassandra.db.lifecycle.SSTableSet.CANONICAL:Lorg/apache/cassandra/db/lifecycle/SSTableSet;
            invokevirtual org.apache.cassandra.db.lifecycle.View.select:(Lorg/apache/cassandra/db/lifecycle/SSTableSet;)Ljava/lang/Iterable;
            invokestatic com.google.common.collect.Iterables.size:(Ljava/lang/Iterable;)I
            invokestatic java.lang.Integer.valueOf:(I)Ljava/lang/Integer;
            invokeinterface org.slf4j.Logger.debug:(Ljava/lang/String;Ljava/lang/Object;Ljava/lang/Object;)V
        12: .line 389
      StackMap locals: java.util.List int org.apache.cassandra.db.lifecycle.View java.util.Set org.apache.cassandra.db.lifecycle.SSTableIntervalTree
      StackMap stack:
            aload 3 /* sstables */
            areturn
        end local 4 // org.apache.cassandra.db.lifecycle.SSTableIntervalTree intervalTree
        end local 3 // java.util.Set sstables
        end local 2 // org.apache.cassandra.db.lifecycle.View view
      LocalVariableTable:
        Start  End  Slot          Name  Signature
            0   13     2          view  Lorg/apache/cassandra/db/lifecycle/View;
            1   13     3      sstables  Ljava/util/Set<Lorg/apache/cassandra/io/sstable/format/SSTableReader;>;
            2   13     4  intervalTree  Lorg/apache/cassandra/db/lifecycle/SSTableIntervalTree;
            4    9     5      keyRange  Lorg/apache/cassandra/dht/Range<Lorg/apache/cassandra/db/PartitionPosition;>;
            6    8     7       sstable  Lorg/apache/cassandra/io/sstable/format/SSTableReader;
}
SourceFile: "StreamSession.java"
NestMembers:
  org.apache.cassandra.streaming.StreamSession$KeepAliveTask  org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections  org.apache.cassandra.streaming.StreamSession$State
InnerClasses:
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles
  public RefViewFragment = org.apache.cassandra.db.ColumnFamilyStore$RefViewFragment of org.apache.cassandra.db.ColumnFamilyStore
  public final Direction = org.apache.cassandra.streaming.ProgressInfo$Direction of org.apache.cassandra.streaming.ProgressInfo
  KeepAliveTask = org.apache.cassandra.streaming.StreamSession$KeepAliveTask of org.apache.cassandra.streaming.StreamSession
  public SSTableStreamingSections = org.apache.cassandra.streaming.StreamSession$SSTableStreamingSections of org.apache.cassandra.streaming.StreamSession
  public final State = org.apache.cassandra.streaming.StreamSession$State of org.apache.cassandra.streaming.StreamSession
  public final Type = org.apache.cassandra.streaming.messages.StreamMessage$Type of org.apache.cassandra.streaming.messages.StreamMessage