class org.apache.cassandra.net.MessagingService$5 implements com.google.common.base.Function<org.apache.cassandra.utils.Pair<java.lang.Integer, org.apache.cassandra.utils.ExpiringMap$CacheableObject<org.apache.cassandra.net.CallbackInfo>>, java.lang.Object>
  minor version: 0
  major version: 59
  flags: flags: (0x0020) ACC_SUPER
  this_class: org.apache.cassandra.net.MessagingService$5
  super_class: java.lang.Object
{
  final org.apache.cassandra.net.MessagingService this$0;
    descriptor: Lorg/apache/cassandra/net/MessagingService;
    flags: (0x1010) ACC_FINAL, ACC_SYNTHETIC

  void <init>(org.apache.cassandra.net.MessagingService);
    descriptor: (Lorg/apache/cassandra/net/MessagingService;)V
    flags: (0x0000) 
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService$5 this
         0: .line 518
            aload 0 /* this */
            aload 1
            putfield org.apache.cassandra.net.MessagingService$5.this$0:Lorg/apache/cassandra/net/MessagingService;
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
            return
        end local 0 // org.apache.cassandra.net.MessagingService$5 this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lorg/apache/cassandra/net/MessagingService$5;
    MethodParameters:
        Name  Flags
      this$0  final

  public  apply(org.apache.cassandra.utils.Pair<java.lang.Integer, org.apache.cassandra.utils.ExpiringMap$CacheableObject<org.apache.cassandra.net.CallbackInfo>>);
    descriptor: (Lorg/apache/cassandra/utils/Pair;)Ljava/lang/Object;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=4, args_size=2
        start local 0 // org.apache.cassandra.net.MessagingService$5 this
        start local 1 // org.apache.cassandra.utils.Pair pair
         0: .line 522
            aload 1 /* pair */
            getfield org.apache.cassandra.utils.Pair.right:Ljava/lang/Object;
            checkcast org.apache.cassandra.utils.ExpiringMap$CacheableObject
            getfield org.apache.cassandra.utils.ExpiringMap$CacheableObject.value:Ljava/lang/Object;
            checkcast org.apache.cassandra.net.CallbackInfo
            astore 2 /* expiredCallbackInfo */
        start local 2 // org.apache.cassandra.net.CallbackInfo expiredCallbackInfo
         1: .line 524
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService$5.this$0:Lorg/apache/cassandra/net/MessagingService;
            aload 2 /* expiredCallbackInfo */
            getfield org.apache.cassandra.net.CallbackInfo.callback:Lorg/apache/cassandra/net/IAsyncCallback;
            aload 2 /* expiredCallbackInfo */
            getfield org.apache.cassandra.net.CallbackInfo.target:Ljava/net/InetAddress;
            aload 1 /* pair */
            getfield org.apache.cassandra.utils.Pair.right:Ljava/lang/Object;
            checkcast org.apache.cassandra.utils.ExpiringMap$CacheableObject
            getfield org.apache.cassandra.utils.ExpiringMap$CacheableObject.timeout:J
            invokevirtual org.apache.cassandra.net.MessagingService.maybeAddLatency:(Lorg/apache/cassandra/net/IAsyncCallback;Ljava/net/InetAddress;J)V
         2: .line 526
            getstatic org.apache.cassandra.metrics.ConnectionMetrics.totalTimeouts:Lcom/codahale/metrics/Meter;
            invokevirtual com.codahale.metrics.Meter.mark:()V
         3: .line 527
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService$5.this$0:Lorg/apache/cassandra/net/MessagingService;
            aload 2 /* expiredCallbackInfo */
            getfield org.apache.cassandra.net.CallbackInfo.target:Ljava/net/InetAddress;
            invokevirtual org.apache.cassandra.net.MessagingService.getConnectionPool:(Ljava/net/InetAddress;)Lorg/apache/cassandra/net/OutboundTcpConnectionPool;
            invokevirtual org.apache.cassandra.net.OutboundTcpConnectionPool.incrementTimeout:()V
         4: .line 529
            aload 2 /* expiredCallbackInfo */
            getfield org.apache.cassandra.net.CallbackInfo.callback:Lorg/apache/cassandra/net/IAsyncCallback;
            invokeinterface org.apache.cassandra.net.IAsyncCallback.supportsBackPressure:()Z
            ifeq 6
         5: .line 531
            aload 0 /* this */
            getfield org.apache.cassandra.net.MessagingService$5.this$0:Lorg/apache/cassandra/net/MessagingService;
            aload 2 /* expiredCallbackInfo */
            getfield org.apache.cassandra.net.CallbackInfo.target:Ljava/net/InetAddress;
            aload 2 /* expiredCallbackInfo */
            getfield org.apache.cassandra.net.CallbackInfo.callback:Lorg/apache/cassandra/net/IAsyncCallback;
            iconst_1
            invokevirtual org.apache.cassandra.net.MessagingService.updateBackPressureOnReceive:(Ljava/net/InetAddress;Lorg/apache/cassandra/net/IAsyncCallback;Z)V
         6: .line 534
      StackMap locals: org.apache.cassandra.net.CallbackInfo
      StackMap stack:
            aload 2 /* expiredCallbackInfo */
            invokevirtual org.apache.cassandra.net.CallbackInfo.isFailureCallback:()Z
            ifeq 8
         7: .line 536
            getstatic org.apache.cassandra.concurrent.Stage.INTERNAL_RESPONSE:Lorg/apache/cassandra/concurrent/Stage;
            invokestatic org.apache.cassandra.concurrent.StageManager.getStage:(Lorg/apache/cassandra/concurrent/Stage;)Lorg/apache/cassandra/concurrent/LocalAwareExecutorService;
            new org.apache.cassandra.net.MessagingService$5$1
            dup
            aload 0 /* this */
            aload 2 /* expiredCallbackInfo */
            invokespecial org.apache.cassandra.net.MessagingService$5$1.<init>:(Lorg/apache/cassandra/net/MessagingService$5;Lorg/apache/cassandra/net/CallbackInfo;)V
            invokeinterface org.apache.cassandra.concurrent.LocalAwareExecutorService.submit:(Ljava/lang/Runnable;)Ljava/util/concurrent/Future;
            pop
         8: .line 546
      StackMap locals:
      StackMap stack:
            aload 2 /* expiredCallbackInfo */
            invokevirtual org.apache.cassandra.net.CallbackInfo.shouldHint:()Z
            ifeq 11
         9: .line 548
            aload 2 /* expiredCallbackInfo */
            checkcast org.apache.cassandra.net.WriteCallbackInfo
            invokevirtual org.apache.cassandra.net.WriteCallbackInfo.mutation:()Lorg/apache/cassandra/db/Mutation;
            astore 3 /* mutation */
        start local 3 // org.apache.cassandra.db.Mutation mutation
        10: .line 549
            aload 3 /* mutation */
            aload 2 /* expiredCallbackInfo */
            getfield org.apache.cassandra.net.CallbackInfo.target:Ljava/net/InetAddress;
            aconst_null
            invokestatic org.apache.cassandra.service.StorageProxy.submitHint:(Lorg/apache/cassandra/db/Mutation;Ljava/net/InetAddress;Lorg/apache/cassandra/service/AbstractWriteResponseHandler;)Ljava/util/concurrent/Future;
            areturn
        end local 3 // org.apache.cassandra.db.Mutation mutation
        11: .line 552
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        end local 2 // org.apache.cassandra.net.CallbackInfo expiredCallbackInfo
        end local 1 // org.apache.cassandra.utils.Pair pair
        end local 0 // org.apache.cassandra.net.MessagingService$5 this
      LocalVariableTable:
        Start  End  Slot                 Name  Signature
            0   12     0                 this  Lorg/apache/cassandra/net/MessagingService$5;
            0   12     1                 pair  Lorg/apache/cassandra/utils/Pair<Ljava/lang/Integer;Lorg/apache/cassandra/utils/ExpiringMap$CacheableObject<Lorg/apache/cassandra/net/CallbackInfo;>;>;
            1   12     2  expiredCallbackInfo  Lorg/apache/cassandra/net/CallbackInfo;
           10   11     3             mutation  Lorg/apache/cassandra/db/Mutation;
    Signature: (Lorg/apache/cassandra/utils/Pair<Ljava/lang/Integer;Lorg/apache/cassandra/utils/ExpiringMap$CacheableObject<Lorg/apache/cassandra/net/CallbackInfo;>;>;)Ljava/lang/Object;
    MethodParameters:
      Name  Flags
      pair  

  public java.lang.Object apply(java.lang.Object);
    descriptor: (Ljava/lang/Object;)Ljava/lang/Object;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=2, locals=2, args_size=2
         0: .line 1
            aload 0
            aload 1
            checkcast org.apache.cassandra.utils.Pair
            invokevirtual org.apache.cassandra.net.MessagingService$5.apply:(Lorg/apache/cassandra/utils/Pair;)Ljava/lang/Object;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
}
Signature: Ljava/lang/Object;Lcom/google/common/base/Function<Lorg/apache/cassandra/utils/Pair<Ljava/lang/Integer;Lorg/apache/cassandra/utils/ExpiringMap$CacheableObject<Lorg/apache/cassandra/net/CallbackInfo;>;>;Ljava/lang/Object;>;
SourceFile: "MessagingService.java"
EnclosingMethod: org.apache.cassandra.net.MessagingService.<init>:(Z)V
NestHost: org.apache.cassandra.net.MessagingService
InnerClasses:
  org.apache.cassandra.net.MessagingService$5
  org.apache.cassandra.net.MessagingService$5$1
  public CacheableObject = org.apache.cassandra.utils.ExpiringMap$CacheableObject of org.apache.cassandra.utils.ExpiringMap