public abstract class org.apache.cassandra.streaming.messages.StreamMessage
  minor version: 0
  major version: 59
  flags: flags: (0x0421) ACC_PUBLIC, ACC_SUPER, ACC_ABSTRACT
  this_class: org.apache.cassandra.streaming.messages.StreamMessage
  super_class: java.lang.Object
{
  public static final int VERSION_20;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: 2

  public static final int VERSION_22;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: 3

  public static final int VERSION_30;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: 4

  public static final int CURRENT_VERSION;
    descriptor: I
    flags: (0x0019) ACC_PUBLIC, ACC_STATIC, ACC_FINAL
    ConstantValue: 4

  private volatile transient boolean sent;
    descriptor: Z
    flags: (0x00c2) ACC_PRIVATE, ACC_VOLATILE, ACC_TRANSIENT

  public final org.apache.cassandra.streaming.messages.StreamMessage$Type type;
    descriptor: Lorg/apache/cassandra/streaming/messages/StreamMessage$Type;
    flags: (0x0011) ACC_PUBLIC, ACC_FINAL

  public static void serialize(org.apache.cassandra.streaming.messages.StreamMessage, org.apache.cassandra.io.util.DataOutputStreamPlus, int, org.apache.cassandra.streaming.StreamSession);
    descriptor: (Lorg/apache/cassandra/streaming/messages/StreamMessage;Lorg/apache/cassandra/io/util/DataOutputStreamPlus;ILorg/apache/cassandra/streaming/StreamSession;)V
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=5, locals=5, args_size=4
        start local 0 // org.apache.cassandra.streaming.messages.StreamMessage message
        start local 1 // org.apache.cassandra.io.util.DataOutputStreamPlus out
        start local 2 // int version
        start local 3 // org.apache.cassandra.streaming.StreamSession session
         0: .line 45
            iconst_1
            invokestatic java.nio.ByteBuffer.allocate:(I)Ljava/nio/ByteBuffer;
            astore 4 /* buff */
        start local 4 // java.nio.ByteBuffer buff
         1: .line 47
            aload 4 /* buff */
            aload 0 /* message */
            getfield org.apache.cassandra.streaming.messages.StreamMessage.type:Lorg/apache/cassandra/streaming/messages/StreamMessage$Type;
            getfield org.apache.cassandra.streaming.messages.StreamMessage$Type.type:B
            invokevirtual java.nio.ByteBuffer.put:(B)Ljava/nio/ByteBuffer;
            pop
         2: .line 48
            aload 4 /* buff */
            invokevirtual java.nio.ByteBuffer.flip:()Ljava/nio/Buffer;
            pop
         3: .line 49
            aload 1 /* out */
            aload 4 /* buff */
            invokevirtual org.apache.cassandra.io.util.DataOutputStreamPlus.write:(Ljava/nio/ByteBuffer;)V
         4: .line 50
            aload 0 /* message */
            getfield org.apache.cassandra.streaming.messages.StreamMessage.type:Lorg/apache/cassandra/streaming/messages/StreamMessage$Type;
            getfield org.apache.cassandra.streaming.messages.StreamMessage$Type.outSerializer:Lorg/apache/cassandra/streaming/messages/StreamMessage$Serializer;
            aload 0 /* message */
            aload 1 /* out */
            iload 2 /* version */
            aload 3 /* session */
            invokeinterface org.apache.cassandra.streaming.messages.StreamMessage$Serializer.serialize:(Lorg/apache/cassandra/streaming/messages/StreamMessage;Lorg/apache/cassandra/io/util/DataOutputStreamPlus;ILorg/apache/cassandra/streaming/StreamSession;)V
         5: .line 51
            return
        end local 4 // java.nio.ByteBuffer buff
        end local 3 // org.apache.cassandra.streaming.StreamSession session
        end local 2 // int version
        end local 1 // org.apache.cassandra.io.util.DataOutputStreamPlus out
        end local 0 // org.apache.cassandra.streaming.messages.StreamMessage message
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    6     0  message  Lorg/apache/cassandra/streaming/messages/StreamMessage;
            0    6     1      out  Lorg/apache/cassandra/io/util/DataOutputStreamPlus;
            0    6     2  version  I
            0    6     3  session  Lorg/apache/cassandra/streaming/StreamSession;
            1    6     4     buff  Ljava/nio/ByteBuffer;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
         Name  Flags
      message  
      out      
      version  
      session  

  public static org.apache.cassandra.streaming.messages.StreamMessage deserialize(java.nio.channels.ReadableByteChannel, int, org.apache.cassandra.streaming.StreamSession);
    descriptor: (Ljava/nio/channels/ReadableByteChannel;ILorg/apache/cassandra/streaming/StreamSession;)Lorg/apache/cassandra/streaming/messages/StreamMessage;
    flags: (0x0009) ACC_PUBLIC, ACC_STATIC
    Code:
      stack=4, locals=6, args_size=3
        start local 0 // java.nio.channels.ReadableByteChannel in
        start local 1 // int version
        start local 2 // org.apache.cassandra.streaming.StreamSession session
         0: .line 55
            iconst_1
            invokestatic java.nio.ByteBuffer.allocate:(I)Ljava/nio/ByteBuffer;
            astore 3 /* buff */
        start local 3 // java.nio.ByteBuffer buff
         1: .line 56
            aload 0 /* in */
            aload 3 /* buff */
            invokeinterface java.nio.channels.ReadableByteChannel.read:(Ljava/nio/ByteBuffer;)I
            istore 4 /* readBytes */
        start local 4 // int readBytes
         2: .line 57
            iload 4 /* readBytes */
            ifle 6
         3: .line 59
            aload 3 /* buff */
            invokevirtual java.nio.ByteBuffer.flip:()Ljava/nio/Buffer;
            pop
         4: .line 60
            aload 3 /* buff */
            invokevirtual java.nio.ByteBuffer.get:()B
            invokestatic org.apache.cassandra.streaming.messages.StreamMessage$Type.get:(B)Lorg/apache/cassandra/streaming/messages/StreamMessage$Type;
            astore 5 /* type */
        start local 5 // org.apache.cassandra.streaming.messages.StreamMessage$Type type
         5: .line 61
            aload 5 /* type */
            getfield org.apache.cassandra.streaming.messages.StreamMessage$Type.inSerializer:Lorg/apache/cassandra/streaming/messages/StreamMessage$Serializer;
            aload 0 /* in */
            iload 1 /* version */
            aload 2 /* session */
            invokeinterface org.apache.cassandra.streaming.messages.StreamMessage$Serializer.deserialize:(Ljava/nio/channels/ReadableByteChannel;ILorg/apache/cassandra/streaming/StreamSession;)Lorg/apache/cassandra/streaming/messages/StreamMessage;
            areturn
        end local 5 // org.apache.cassandra.streaming.messages.StreamMessage$Type type
         6: .line 63
      StackMap locals: java.nio.ByteBuffer int
      StackMap stack:
            iload 4 /* readBytes */
            ifne 8
         7: .line 66
            aconst_null
            areturn
         8: .line 71
      StackMap locals:
      StackMap stack:
            new java.net.SocketException
            dup
            ldc "End-of-stream reached"
            invokespecial java.net.SocketException.<init>:(Ljava/lang/String;)V
            athrow
        end local 4 // int readBytes
        end local 3 // java.nio.ByteBuffer buff
        end local 2 // org.apache.cassandra.streaming.StreamSession session
        end local 1 // int version
        end local 0 // java.nio.channels.ReadableByteChannel in
      LocalVariableTable:
        Start  End  Slot       Name  Signature
            0    9     0         in  Ljava/nio/channels/ReadableByteChannel;
            0    9     1    version  I
            0    9     2    session  Lorg/apache/cassandra/streaming/StreamSession;
            1    9     3       buff  Ljava/nio/ByteBuffer;
            2    9     4  readBytes  I
            5    6     5       type  Lorg/apache/cassandra/streaming/messages/StreamMessage$Type;
    Exceptions:
      throws java.io.IOException
    MethodParameters:
         Name  Flags
      in       
      version  
      session  

  public void sent();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // org.apache.cassandra.streaming.messages.StreamMessage this
         0: .line 77
            aload 0 /* this */
            iconst_1
            putfield org.apache.cassandra.streaming.messages.StreamMessage.sent:Z
         1: .line 78
            return
        end local 0 // org.apache.cassandra.streaming.messages.StreamMessage this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lorg/apache/cassandra/streaming/messages/StreamMessage;

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

  protected void <init>(org.apache.cassandra.streaming.messages.StreamMessage$Type);
    descriptor: (Lorg/apache/cassandra/streaming/messages/StreamMessage$Type;)V
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.streaming.messages.StreamMessage this
        start local 1 // org.apache.cassandra.streaming.messages.StreamMessage$Type type
         0: .line 136
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 41
            aload 0 /* this */
            iconst_0
            putfield org.apache.cassandra.streaming.messages.StreamMessage.sent:Z
         2: .line 138
            aload 0 /* this */
            aload 1 /* type */
            putfield org.apache.cassandra.streaming.messages.StreamMessage.type:Lorg/apache/cassandra/streaming/messages/StreamMessage$Type;
         3: .line 139
            return
        end local 1 // org.apache.cassandra.streaming.messages.StreamMessage$Type type
        end local 0 // org.apache.cassandra.streaming.messages.StreamMessage this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lorg/apache/cassandra/streaming/messages/StreamMessage;
            0    4     1  type  Lorg/apache/cassandra/streaming/messages/StreamMessage$Type;
    MethodParameters:
      Name  Flags
      type  

  public int getPriority();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // org.apache.cassandra.streaming.messages.StreamMessage this
         0: .line 146
            aload 0 /* this */
            getfield org.apache.cassandra.streaming.messages.StreamMessage.type:Lorg/apache/cassandra/streaming/messages/StreamMessage$Type;
            getfield org.apache.cassandra.streaming.messages.StreamMessage$Type.priority:I
            ireturn
        end local 0 // org.apache.cassandra.streaming.messages.StreamMessage this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/streaming/messages/StreamMessage;
}
SourceFile: "StreamMessage.java"
NestMembers:
  org.apache.cassandra.streaming.messages.StreamMessage$Serializer  org.apache.cassandra.streaming.messages.StreamMessage$Type
InnerClasses:
  public abstract Serializer = org.apache.cassandra.streaming.messages.StreamMessage$Serializer of org.apache.cassandra.streaming.messages.StreamMessage
  public final Type = org.apache.cassandra.streaming.messages.StreamMessage$Type of org.apache.cassandra.streaming.messages.StreamMessage