public class io.vertx.spi.cluster.hazelcast.HazelcastClusterManager implements io.vertx.core.spi.cluster.ClusterManager, com.hazelcast.core.MembershipListener, com.hazelcast.core.LifecycleListener
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: io.vertx.spi.cluster.hazelcast.HazelcastClusterManager
  super_class: java.lang.Object
{
  private static final io.vertx.core.logging.Logger log;
    descriptor: Lio/vertx/core/logging/Logger;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private static final java.lang.String LOCK_SEMAPHORE_PREFIX;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "__vertx."

  private static final java.lang.String NODE_ID_ATTRIBUTE;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "__vertx.nodeId"

  private static final java.lang.String OPTION_USE_HZ_ASYNC_API;
    descriptor: Ljava/lang/String;
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL
    ConstantValue: "vertx.hazelcast.async-api"

  private static final boolean USE_HZ_ASYNC_API;
    descriptor: Z
    flags: (0x001a) ACC_PRIVATE, ACC_STATIC, ACC_FINAL

  private io.vertx.core.Vertx vertx;
    descriptor: Lio/vertx/core/Vertx;
    flags: (0x0002) ACC_PRIVATE

  private com.hazelcast.core.HazelcastInstance hazelcast;
    descriptor: Lcom/hazelcast/core/HazelcastInstance;
    flags: (0x0002) ACC_PRIVATE

  private java.lang.String nodeID;
    descriptor: Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE

  private java.lang.String membershipListenerId;
    descriptor: Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE

  private java.lang.String lifecycleListenerId;
    descriptor: Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE

  private boolean customHazelcastCluster;
    descriptor: Z
    flags: (0x0002) ACC_PRIVATE

  private java.util.Set<java.lang.String> nodeIds;
    descriptor: Ljava/util/Set;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/Set<Ljava/lang/String;>;

  private java.util.Set<io.vertx.spi.cluster.hazelcast.impl.HazelcastAsyncMultiMap> multimaps;
    descriptor: Ljava/util/Set;
    flags: (0x0002) ACC_PRIVATE
    Signature: Ljava/util/Set<Lio/vertx/spi/cluster/hazelcast/impl/HazelcastAsyncMultiMap;>;

  private io.vertx.core.spi.cluster.NodeListener nodeListener;
    descriptor: Lio/vertx/core/spi/cluster/NodeListener;
    flags: (0x0002) ACC_PRIVATE

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

  private com.hazelcast.config.Config conf;
    descriptor: Lcom/hazelcast/config/Config;
    flags: (0x0002) ACC_PRIVATE

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 53
            ldc Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            invokestatic io.vertx.core.logging.LoggerFactory.getLogger:(Ljava/lang/Class;)Lio/vertx/core/logging/Logger;
            putstatic io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.log:Lio/vertx/core/logging/Logger;
         1: .line 67
            ldc "vertx.hazelcast.async-api"
            invokestatic java.lang.Boolean.getBoolean:(Ljava/lang/String;)Z
            putstatic io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.USE_HZ_ASYNC_API:Z
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
         0: .line 88
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 76
            aload 0 /* this */
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeIds:Ljava/util/Set;
         2: .line 78
            aload 0 /* this */
            new java.util.WeakHashMap
            dup
            iconst_1
            invokespecial java.util.WeakHashMap.<init>:(I)V
            invokestatic java.util.Collections.newSetFromMap:(Ljava/util/Map;)Ljava/util/Set;
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.multimaps:Ljava/util/Set;
         3: .line 89
            return
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;

  public void <init>(com.hazelcast.config.Config);
    descriptor: (Lcom/hazelcast/config/Config;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // com.hazelcast.config.Config conf
         0: .line 96
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 76
            aload 0 /* this */
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeIds:Ljava/util/Set;
         2: .line 78
            aload 0 /* this */
            new java.util.WeakHashMap
            dup
            iconst_1
            invokespecial java.util.WeakHashMap.<init>:(I)V
            invokestatic java.util.Collections.newSetFromMap:(Ljava/util/Map;)Ljava/util/Set;
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.multimaps:Ljava/util/Set;
         3: .line 97
            aload 1 /* conf */
            ldc "The Hazelcast config cannot be null."
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            pop
         4: .line 98
            aload 0 /* this */
            aload 1 /* conf */
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.conf:Lcom/hazelcast/config/Config;
         5: .line 99
            return
        end local 1 // com.hazelcast.config.Config conf
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0    6     1  conf  Lcom/hazelcast/config/Config;
    MethodParameters:
      Name  Flags
      conf  

  public void <init>(com.hazelcast.core.HazelcastInstance);
    descriptor: (Lcom/hazelcast/core/HazelcastInstance;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=2, args_size=2
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // com.hazelcast.core.HazelcastInstance instance
         0: .line 101
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 76
            aload 0 /* this */
            new java.util.HashSet
            dup
            invokespecial java.util.HashSet.<init>:()V
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeIds:Ljava/util/Set;
         2: .line 78
            aload 0 /* this */
            new java.util.WeakHashMap
            dup
            iconst_1
            invokespecial java.util.WeakHashMap.<init>:(I)V
            invokestatic java.util.Collections.newSetFromMap:(Ljava/util/Map;)Ljava/util/Set;
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.multimaps:Ljava/util/Set;
         3: .line 102
            aload 1 /* instance */
            ldc "The Hazelcast instance cannot be null."
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;Ljava/lang/String;)Ljava/lang/Object;
            pop
         4: .line 103
            aload 0 /* this */
            aload 1 /* instance */
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.hazelcast:Lcom/hazelcast/core/HazelcastInstance;
         5: .line 104
            aload 0 /* this */
            iconst_1
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.customHazelcastCluster:Z
         6: .line 105
            return
        end local 1 // com.hazelcast.core.HazelcastInstance instance
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    7     0      this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0    7     1  instance  Lcom/hazelcast/core/HazelcastInstance;
    MethodParameters:
          Name  Flags
      instance  

  public void setVertx(io.vertx.core.Vertx);
    descriptor: (Lio/vertx/core/Vertx;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // io.vertx.core.Vertx vertx
         0: .line 108
            aload 0 /* this */
            aload 1 /* vertx */
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.vertx:Lio/vertx/core/Vertx;
         1: .line 109
            return
        end local 1 // io.vertx.core.Vertx vertx
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot   Name  Signature
            0    2     0   this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0    2     1  vertx  Lio/vertx/core/Vertx;
    MethodParameters:
       Name  Flags
      vertx  

  public synchronized void join(io.vertx.core.Handler<io.vertx.core.AsyncResult<java.lang.Void>>);
    descriptor: (Lio/vertx/core/Handler;)V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // io.vertx.core.Handler resultHandler
         0: .line 112
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.vertx:Lio/vertx/core/Vertx;
            aload 0 /* this */
            invokedynamic handle(Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;)Lio/vertx/core/Handler;
              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;)V
                  io/vertx/spi/cluster/hazelcast/HazelcastClusterManager.lambda$0(Lio/vertx/core/Promise;)V (7)
                  (Lio/vertx/core/Promise;)V
         1: .line 140
            aload 1 /* resultHandler */
         2: .line 112
            invokeinterface io.vertx.core.Vertx.executeBlocking:(Lio/vertx/core/Handler;Lio/vertx/core/Handler;)V
         3: .line 141
            return
        end local 1 // io.vertx.core.Handler resultHandler
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    4     0           this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0    4     1  resultHandler  Lio/vertx/core/Handler<Lio/vertx/core/AsyncResult<Ljava/lang/Void;>;>;
    Signature: (Lio/vertx/core/Handler<Lio/vertx/core/AsyncResult<Ljava/lang/Void;>;>;)V
    MethodParameters:
               Name  Flags
      resultHandler  

  public <K, V> void getAsyncMultiMap(java.lang.String, io.vertx.core.Handler<io.vertx.core.AsyncResult<io.vertx.core.spi.cluster.AsyncMultiMap<K, V>>>);
    descriptor: (Ljava/lang/String;Lio/vertx/core/Handler;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // java.lang.String name
        start local 2 // io.vertx.core.Handler resultHandler
         0: .line 155
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.vertx:Lio/vertx/core/Vertx;
            aload 0 /* this */
            aload 1 /* name */
            invokedynamic handle(Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;Ljava/lang/String;)Lio/vertx/core/Handler;
              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;)V
                  io/vertx/spi/cluster/hazelcast/HazelcastClusterManager.lambda$1(Ljava/lang/String;Lio/vertx/core/Promise;)V (7)
                  (Lio/vertx/core/Promise;)V
         1: .line 162
            aload 2 /* resultHandler */
         2: .line 155
            invokeinterface io.vertx.core.Vertx.executeBlocking:(Lio/vertx/core/Handler;Lio/vertx/core/Handler;)V
         3: .line 163
            return
        end local 2 // io.vertx.core.Handler resultHandler
        end local 1 // java.lang.String name
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    4     0           this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0    4     1           name  Ljava/lang/String;
            0    4     2  resultHandler  Lio/vertx/core/Handler<Lio/vertx/core/AsyncResult<Lio/vertx/core/spi/cluster/AsyncMultiMap<TK;TV;>;>;>;
    Signature: <K:Ljava/lang/Object;V:Ljava/lang/Object;>(Ljava/lang/String;Lio/vertx/core/Handler<Lio/vertx/core/AsyncResult<Lio/vertx/core/spi/cluster/AsyncMultiMap<TK;TV;>;>;>;)V
    MethodParameters:
               Name  Flags
      name           
      resultHandler  

  public java.lang.String getNodeID();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
         0: .line 167
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeID:Ljava/lang/String;
            areturn
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;

  public java.util.List<java.lang.String> getNodes();
    descriptor: ()Ljava/util/List;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=5, args_size=1
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
         0: .line 172
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 1 /* list */
        start local 1 // java.util.List list
         1: .line 173
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.hazelcast:Lcom/hazelcast/core/HazelcastInstance;
            invokeinterface com.hazelcast.core.HazelcastInstance.getCluster:()Lcom/hazelcast/core/Cluster;
            invokeinterface com.hazelcast.core.Cluster.getMembers:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 7
      StackMap locals: io.vertx.spi.cluster.hazelcast.HazelcastClusterManager java.util.List top java.util.Iterator
      StackMap stack:
         2: aload 3
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast com.hazelcast.core.Member
            astore 2 /* member */
        start local 2 // com.hazelcast.core.Member member
         3: .line 174
            aload 2 /* member */
            ldc "__vertx.nodeId"
            invokeinterface com.hazelcast.core.Member.getStringAttribute:(Ljava/lang/String;)Ljava/lang/String;
            astore 4 /* nodeIdAttribute */
        start local 4 // java.lang.String nodeIdAttribute
         4: .line 175
            aload 1 /* list */
            aload 4 /* nodeIdAttribute */
            ifnull 5
            aload 4 /* nodeIdAttribute */
            goto 6
      StackMap locals: io.vertx.spi.cluster.hazelcast.HazelcastClusterManager java.util.List com.hazelcast.core.Member java.util.Iterator java.lang.String
      StackMap stack: java.util.List
         5: aload 2 /* member */
            invokeinterface com.hazelcast.core.Member.getUuid:()Ljava/lang/String;
      StackMap locals: io.vertx.spi.cluster.hazelcast.HazelcastClusterManager java.util.List com.hazelcast.core.Member java.util.Iterator java.lang.String
      StackMap stack: java.util.List java.lang.String
         6: invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 4 // java.lang.String nodeIdAttribute
        end local 2 // com.hazelcast.core.Member member
         7: .line 173
      StackMap locals: io.vertx.spi.cluster.hazelcast.HazelcastClusterManager java.util.List top java.util.Iterator
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         8: .line 177
            aload 1 /* list */
            areturn
        end local 1 // java.util.List list
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0    9     0             this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            1    9     1             list  Ljava/util/List<Ljava/lang/String;>;
            3    7     2           member  Lcom/hazelcast/core/Member;
            4    7     4  nodeIdAttribute  Ljava/lang/String;
    Signature: ()Ljava/util/List<Ljava/lang/String;>;

  public void nodeListener(io.vertx.core.spi.cluster.NodeListener);
    descriptor: (Lio/vertx/core/spi/cluster/NodeListener;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // io.vertx.core.spi.cluster.NodeListener listener
         0: .line 182
            aload 0 /* this */
            aload 1 /* listener */
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeListener:Lio/vertx/core/spi/cluster/NodeListener;
         1: .line 183
            return
        end local 1 // io.vertx.core.spi.cluster.NodeListener listener
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    2     0      this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0    2     1  listener  Lio/vertx/core/spi/cluster/NodeListener;
    MethodParameters:
          Name  Flags
      listener  

  public <K, V> void getAsyncMap(java.lang.String, io.vertx.core.Handler<io.vertx.core.AsyncResult<io.vertx.core.shareddata.AsyncMap<K, V>>>);
    descriptor: (Ljava/lang/String;Lio/vertx/core/Handler;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // java.lang.String name
        start local 2 // io.vertx.core.Handler resultHandler
         0: .line 187
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.vertx:Lio/vertx/core/Vertx;
            aload 0 /* this */
            aload 1 /* name */
            invokedynamic handle(Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;Ljava/lang/String;)Lio/vertx/core/Handler;
              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;)V
                  io/vertx/spi/cluster/hazelcast/HazelcastClusterManager.lambda$2(Ljava/lang/String;Lio/vertx/core/Promise;)V (7)
                  (Lio/vertx/core/Promise;)V
         1: .line 190
            aload 2 /* resultHandler */
         2: .line 187
            invokeinterface io.vertx.core.Vertx.executeBlocking:(Lio/vertx/core/Handler;Lio/vertx/core/Handler;)V
         3: .line 191
            return
        end local 2 // io.vertx.core.Handler resultHandler
        end local 1 // java.lang.String name
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    4     0           this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0    4     1           name  Ljava/lang/String;
            0    4     2  resultHandler  Lio/vertx/core/Handler<Lio/vertx/core/AsyncResult<Lio/vertx/core/shareddata/AsyncMap<TK;TV;>;>;>;
    Signature: <K:Ljava/lang/Object;V:Ljava/lang/Object;>(Ljava/lang/String;Lio/vertx/core/Handler<Lio/vertx/core/AsyncResult<Lio/vertx/core/shareddata/AsyncMap<TK;TV;>;>;>;)V
    MethodParameters:
               Name  Flags
      name           
      resultHandler  

  public <K, V> java.util.Map<K, V> getSyncMap(java.lang.String);
    descriptor: (Ljava/lang/String;)Ljava/util/Map;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // java.lang.String name
         0: .line 195
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.hazelcast:Lcom/hazelcast/core/HazelcastInstance;
            aload 1 /* name */
            invokeinterface com.hazelcast.core.HazelcastInstance.getMap:(Ljava/lang/String;)Lcom/hazelcast/core/IMap;
            astore 2 /* map */
        start local 2 // com.hazelcast.core.IMap map
         1: .line 196
            aload 2 /* map */
            areturn
        end local 2 // com.hazelcast.core.IMap map
        end local 1 // java.lang.String name
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0    2     1  name  Ljava/lang/String;
            1    2     2   map  Lcom/hazelcast/core/IMap<TK;TV;>;
    Signature: <K:Ljava/lang/Object;V:Ljava/lang/Object;>(Ljava/lang/String;)Ljava/util/Map<TK;TV;>;
    MethodParameters:
      Name  Flags
      name  

  public void getLockWithTimeout(java.lang.String, long, io.vertx.core.Handler<io.vertx.core.AsyncResult<io.vertx.core.shareddata.Lock>>);
    descriptor: (Ljava/lang/String;JLio/vertx/core/Handler;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=5, locals=5, args_size=4
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // java.lang.String name
        start local 2 // long timeout
        start local 4 // io.vertx.core.Handler resultHandler
         0: .line 201
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.vertx:Lio/vertx/core/Vertx;
            aload 0 /* this */
            aload 1 /* name */
            lload 2 /* timeout */
            invokedynamic handle(Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;Ljava/lang/String;J)Lio/vertx/core/Handler;
              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;)V
                  io/vertx/spi/cluster/hazelcast/HazelcastClusterManager.lambda$3(Ljava/lang/String;JLio/vertx/core/Promise;)V (7)
                  (Lio/vertx/core/Promise;)V
         1: .line 219
            iconst_0
            aload 4 /* resultHandler */
         2: .line 201
            invokeinterface io.vertx.core.Vertx.executeBlocking:(Lio/vertx/core/Handler;ZLio/vertx/core/Handler;)V
         3: .line 220
            return
        end local 4 // io.vertx.core.Handler resultHandler
        end local 2 // long timeout
        end local 1 // java.lang.String name
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    4     0           this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0    4     1           name  Ljava/lang/String;
            0    4     2        timeout  J
            0    4     4  resultHandler  Lio/vertx/core/Handler<Lio/vertx/core/AsyncResult<Lio/vertx/core/shareddata/Lock;>;>;
    Signature: (Ljava/lang/String;JLio/vertx/core/Handler<Lio/vertx/core/AsyncResult<Lio/vertx/core/shareddata/Lock;>;>;)V
    MethodParameters:
               Name  Flags
      name           
      timeout        
      resultHandler  

  public void getCounter(java.lang.String, io.vertx.core.Handler<io.vertx.core.AsyncResult<io.vertx.core.shareddata.Counter>>);
    descriptor: (Ljava/lang/String;Lio/vertx/core/Handler;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // java.lang.String name
        start local 2 // io.vertx.core.Handler resultHandler
         0: .line 224
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.vertx:Lio/vertx/core/Vertx;
            aload 0 /* this */
            aload 1 /* name */
            invokedynamic handle(Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;Ljava/lang/String;)Lio/vertx/core/Handler;
              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;)V
                  io/vertx/spi/cluster/hazelcast/HazelcastClusterManager.lambda$4(Ljava/lang/String;Lio/vertx/core/Promise;)V (7)
                  (Lio/vertx/core/Promise;)V
         1: .line 230
            aload 2 /* resultHandler */
         2: .line 224
            invokeinterface io.vertx.core.Vertx.executeBlocking:(Lio/vertx/core/Handler;Lio/vertx/core/Handler;)V
         3: .line 231
            return
        end local 2 // io.vertx.core.Handler resultHandler
        end local 1 // java.lang.String name
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    4     0           this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0    4     1           name  Ljava/lang/String;
            0    4     2  resultHandler  Lio/vertx/core/Handler<Lio/vertx/core/AsyncResult<Lio/vertx/core/shareddata/Counter;>;>;
    Signature: (Ljava/lang/String;Lio/vertx/core/Handler<Lio/vertx/core/AsyncResult<Lio/vertx/core/shareddata/Counter;>;>;)V
    MethodParameters:
               Name  Flags
      name           
      resultHandler  

  public void leave(io.vertx.core.Handler<io.vertx.core.AsyncResult<java.lang.Void>>);
    descriptor: (Lio/vertx/core/Handler;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // io.vertx.core.Handler resultHandler
         0: .line 234
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.vertx:Lio/vertx/core/Vertx;
            aload 0 /* this */
            invokedynamic handle(Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;)Lio/vertx/core/Handler;
              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;)V
                  io/vertx/spi/cluster/hazelcast/HazelcastClusterManager.lambda$5(Lio/vertx/core/Promise;)V (7)
                  (Lio/vertx/core/Promise;)V
         1: .line 273
            aload 1 /* resultHandler */
         2: .line 234
            invokeinterface io.vertx.core.Vertx.executeBlocking:(Lio/vertx/core/Handler;Lio/vertx/core/Handler;)V
         3: .line 274
            return
        end local 1 // io.vertx.core.Handler resultHandler
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    4     0           this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0    4     1  resultHandler  Lio/vertx/core/Handler<Lio/vertx/core/AsyncResult<Ljava/lang/Void;>;>;
    Signature: (Lio/vertx/core/Handler<Lio/vertx/core/AsyncResult<Ljava/lang/Void;>;>;)V
    MethodParameters:
               Name  Flags
      resultHandler  

  public synchronized void memberAdded(com.hazelcast.core.MembershipEvent);
    descriptor: (Lcom/hazelcast/core/MembershipEvent;)V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=3, locals=5, args_size=2
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // com.hazelcast.core.MembershipEvent membershipEvent
         0: .line 278
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.active:Z
            ifne 2
         1: .line 279
            return
         2: .line 281
      StackMap locals:
      StackMap stack:
            aload 1 /* membershipEvent */
            invokevirtual com.hazelcast.core.MembershipEvent.getMember:()Lcom/hazelcast/core/Member;
            astore 2 /* member */
        start local 2 // com.hazelcast.core.Member member
         3: .line 282
            aload 2 /* member */
            ldc "__vertx.nodeId"
            invokeinterface com.hazelcast.core.Member.getStringAttribute:(Ljava/lang/String;)Ljava/lang/String;
            astore 3 /* memberNodeId */
        start local 3 // java.lang.String memberNodeId
         4: .line 283
            aload 3 /* memberNodeId */
            ifnonnull 6
         5: .line 284
            aload 2 /* member */
            invokeinterface com.hazelcast.core.Member.getUuid:()Ljava/lang/String;
            astore 3 /* memberNodeId */
         6: .line 287
      StackMap locals: com.hazelcast.core.Member java.lang.String
      StackMap stack:
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.multimaps:Ljava/util/Set;
            invokedynamic accept()Ljava/util/function/Consumer;
              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;)V
                  io/vertx/spi/cluster/hazelcast/impl/HazelcastAsyncMultiMap.clearCache()V (5)
                  (Lio/vertx/spi/cluster/hazelcast/impl/HazelcastAsyncMultiMap;)V
            invokeinterface java.util.Set.forEach:(Ljava/util/function/Consumer;)V
         7: .line 288
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeListener:Lio/vertx/core/spi/cluster/NodeListener;
            ifnull 13
         8: .line 289
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeIds:Ljava/util/Set;
            aload 3 /* memberNodeId */
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
         9: .line 290
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeListener:Lio/vertx/core/spi/cluster/NodeListener;
            aload 3 /* memberNodeId */
            invokeinterface io.vertx.core.spi.cluster.NodeListener.nodeAdded:(Ljava/lang/String;)V
        10: .line 292
            goto 13
      StackMap locals:
      StackMap stack: java.lang.Throwable
        11: astore 4 /* t */
        start local 4 // java.lang.Throwable t
        12: .line 293
            getstatic io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.log:Lio/vertx/core/logging/Logger;
            ldc "Failed to handle memberAdded"
            aload 4 /* t */
            invokevirtual io.vertx.core.logging.Logger.error:(Ljava/lang/Object;Ljava/lang/Throwable;)V
        end local 4 // java.lang.Throwable t
        13: .line 295
      StackMap locals:
      StackMap stack:
            return
        end local 3 // java.lang.String memberNodeId
        end local 2 // com.hazelcast.core.Member member
        end local 1 // com.hazelcast.core.MembershipEvent membershipEvent
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   14     0             this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0   14     1  membershipEvent  Lcom/hazelcast/core/MembershipEvent;
            3   14     2           member  Lcom/hazelcast/core/Member;
            4   14     3     memberNodeId  Ljava/lang/String;
           12   13     4                t  Ljava/lang/Throwable;
      Exception table:
        from    to  target  type
           6    10      11  Class java.lang.Throwable
    MethodParameters:
                 Name  Flags
      membershipEvent  

  public synchronized void memberRemoved(com.hazelcast.core.MembershipEvent);
    descriptor: (Lcom/hazelcast/core/MembershipEvent;)V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=3, locals=5, args_size=2
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // com.hazelcast.core.MembershipEvent membershipEvent
         0: .line 299
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.active:Z
            ifne 2
         1: .line 300
            return
         2: .line 302
      StackMap locals:
      StackMap stack:
            aload 1 /* membershipEvent */
            invokevirtual com.hazelcast.core.MembershipEvent.getMember:()Lcom/hazelcast/core/Member;
            astore 2 /* member */
        start local 2 // com.hazelcast.core.Member member
         3: .line 303
            aload 2 /* member */
            ldc "__vertx.nodeId"
            invokeinterface com.hazelcast.core.Member.getStringAttribute:(Ljava/lang/String;)Ljava/lang/String;
            astore 3 /* memberNodeId */
        start local 3 // java.lang.String memberNodeId
         4: .line 304
            aload 3 /* memberNodeId */
            ifnonnull 6
         5: .line 305
            aload 2 /* member */
            invokeinterface com.hazelcast.core.Member.getUuid:()Ljava/lang/String;
            astore 3 /* memberNodeId */
         6: .line 308
      StackMap locals: com.hazelcast.core.Member java.lang.String
      StackMap stack:
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.multimaps:Ljava/util/Set;
            invokedynamic accept()Ljava/util/function/Consumer;
              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;)V
                  io/vertx/spi/cluster/hazelcast/impl/HazelcastAsyncMultiMap.clearCache()V (5)
                  (Lio/vertx/spi/cluster/hazelcast/impl/HazelcastAsyncMultiMap;)V
            invokeinterface java.util.Set.forEach:(Ljava/util/function/Consumer;)V
         7: .line 309
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeListener:Lio/vertx/core/spi/cluster/NodeListener;
            ifnull 13
         8: .line 310
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeIds:Ljava/util/Set;
            aload 3 /* memberNodeId */
            invokeinterface java.util.Set.remove:(Ljava/lang/Object;)Z
            pop
         9: .line 311
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeListener:Lio/vertx/core/spi/cluster/NodeListener;
            aload 3 /* memberNodeId */
            invokeinterface io.vertx.core.spi.cluster.NodeListener.nodeLeft:(Ljava/lang/String;)V
        10: .line 313
            goto 13
      StackMap locals:
      StackMap stack: java.lang.Throwable
        11: astore 4 /* t */
        start local 4 // java.lang.Throwable t
        12: .line 314
            getstatic io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.log:Lio/vertx/core/logging/Logger;
            ldc "Failed to handle memberRemoved"
            aload 4 /* t */
            invokevirtual io.vertx.core.logging.Logger.error:(Ljava/lang/Object;Ljava/lang/Throwable;)V
        end local 4 // java.lang.Throwable t
        13: .line 316
      StackMap locals:
      StackMap stack:
            return
        end local 3 // java.lang.String memberNodeId
        end local 2 // com.hazelcast.core.Member member
        end local 1 // com.hazelcast.core.MembershipEvent membershipEvent
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   14     0             this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0   14     1  membershipEvent  Lcom/hazelcast/core/MembershipEvent;
            3   14     2           member  Lcom/hazelcast/core/Member;
            4   14     3     memberNodeId  Ljava/lang/String;
           12   13     4                t  Ljava/lang/Throwable;
      Exception table:
        from    to  target  type
           6    10      11  Class java.lang.Throwable
    MethodParameters:
                 Name  Flags
      membershipEvent  

  public synchronized void stateChanged(com.hazelcast.core.LifecycleEvent);
    descriptor: (Lcom/hazelcast/core/LifecycleEvent;)V
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=3, locals=7, args_size=2
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // com.hazelcast.core.LifecycleEvent lifecycleEvent
         0: .line 320
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.active:Z
            ifne 2
         1: .line 321
            return
         2: .line 323
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.multimaps:Ljava/util/Set;
            invokedynamic accept()Ljava/util/function/Consumer;
              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;)V
                  io/vertx/spi/cluster/hazelcast/impl/HazelcastAsyncMultiMap.clearCache()V (5)
                  (Lio/vertx/spi/cluster/hazelcast/impl/HazelcastAsyncMultiMap;)V
            invokeinterface java.util.Set.forEach:(Ljava/util/function/Consumer;)V
         3: .line 325
            aload 1 /* lifecycleEvent */
            invokevirtual com.hazelcast.core.LifecycleEvent.getState:()Lcom/hazelcast/core/LifecycleEvent$LifecycleState;
            getstatic com.hazelcast.core.LifecycleEvent$LifecycleState.MERGED:Lcom/hazelcast/core/LifecycleEvent$LifecycleState;
            if_acmpne 18
         4: .line 326
            aload 0 /* this */
            invokevirtual io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.getNodes:()Ljava/util/List;
            astore 2 /* currentNodes */
        start local 2 // java.util.List currentNodes
         5: .line 327
            new java.util.HashSet
            dup
            aload 2 /* currentNodes */
            invokespecial java.util.HashSet.<init>:(Ljava/util/Collection;)V
            astore 3 /* newNodes */
        start local 3 // java.util.Set newNodes
         6: .line 328
            aload 3 /* newNodes */
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeIds:Ljava/util/Set;
            invokeinterface java.util.Set.removeAll:(Ljava/util/Collection;)Z
            pop
         7: .line 329
            new java.util.HashSet
            dup
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeIds:Ljava/util/Set;
            invokespecial java.util.HashSet.<init>:(Ljava/util/Collection;)V
            astore 4 /* removedMembers */
        start local 4 // java.util.Set removedMembers
         8: .line 330
            aload 4 /* removedMembers */
            aload 2 /* currentNodes */
            invokeinterface java.util.Set.removeAll:(Ljava/util/Collection;)Z
            pop
         9: .line 331
            aload 3 /* newNodes */
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 6
            goto 12
      StackMap locals: io.vertx.spi.cluster.hazelcast.HazelcastClusterManager com.hazelcast.core.LifecycleEvent java.util.List java.util.Set java.util.Set top java.util.Iterator
      StackMap stack:
        10: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 5 /* nodeId */
        start local 5 // java.lang.String nodeId
        11: .line 332
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeListener:Lio/vertx/core/spi/cluster/NodeListener;
            aload 5 /* nodeId */
            invokeinterface io.vertx.core.spi.cluster.NodeListener.nodeAdded:(Ljava/lang/String;)V
        end local 5 // java.lang.String nodeId
        12: .line 331
      StackMap locals:
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 10
        13: .line 334
            aload 4 /* removedMembers */
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 6
            goto 16
      StackMap locals:
      StackMap stack:
        14: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 5 /* nodeId */
        start local 5 // java.lang.String nodeId
        15: .line 335
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeListener:Lio/vertx/core/spi/cluster/NodeListener;
            aload 5 /* nodeId */
            invokeinterface io.vertx.core.spi.cluster.NodeListener.nodeLeft:(Ljava/lang/String;)V
        end local 5 // java.lang.String nodeId
        16: .line 334
      StackMap locals:
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 14
        17: .line 337
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeIds:Ljava/util/Set;
            aload 2 /* currentNodes */
            invokeinterface java.util.Set.retainAll:(Ljava/util/Collection;)Z
            pop
        end local 4 // java.util.Set removedMembers
        end local 3 // java.util.Set newNodes
        end local 2 // java.util.List currentNodes
        18: .line 339
      StackMap locals: io.vertx.spi.cluster.hazelcast.HazelcastClusterManager com.hazelcast.core.LifecycleEvent
      StackMap stack:
            return
        end local 1 // com.hazelcast.core.LifecycleEvent lifecycleEvent
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0   19     0            this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0   19     1  lifecycleEvent  Lcom/hazelcast/core/LifecycleEvent;
            5   18     2    currentNodes  Ljava/util/List<Ljava/lang/String;>;
            6   18     3        newNodes  Ljava/util/Set<Ljava/lang/String;>;
            8   18     4  removedMembers  Ljava/util/Set<Ljava/lang/String;>;
           11   12     5          nodeId  Ljava/lang/String;
           15   16     5          nodeId  Ljava/lang/String;
    MethodParameters:
                Name  Flags
      lifecycleEvent  

  public boolean isActive();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
         0: .line 343
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.active:Z
            ireturn
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;

  public void memberAttributeChanged(com.hazelcast.core.MemberAttributeEvent);
    descriptor: (Lcom/hazelcast/core/MemberAttributeEvent;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=0, locals=2, args_size=2
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // com.hazelcast.core.MemberAttributeEvent memberAttributeEvent
         0: .line 348
            return
        end local 1 // com.hazelcast.core.MemberAttributeEvent memberAttributeEvent
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot                  Name  Signature
            0    1     0                  this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0    1     1  memberAttributeEvent  Lcom/hazelcast/core/MemberAttributeEvent;
    MethodParameters:
                      Name  Flags
      memberAttributeEvent  

  public com.hazelcast.config.Config getConfig();
    descriptor: ()Lcom/hazelcast/config/Config;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
         0: .line 356
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.conf:Lcom/hazelcast/config/Config;
            areturn
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;

  public void setConfig(com.hazelcast.config.Config);
    descriptor: (Lcom/hazelcast/config/Config;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // com.hazelcast.config.Config config
         0: .line 365
            aload 0 /* this */
            aload 1 /* config */
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.conf:Lcom/hazelcast/config/Config;
         1: .line 366
            return
        end local 1 // com.hazelcast.config.Config config
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot    Name  Signature
            0    2     0    this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0    2     1  config  Lcom/hazelcast/config/Config;
    MethodParameters:
        Name  Flags
      config  

  public com.hazelcast.config.Config loadConfig();
    descriptor: ()Lcom/hazelcast/config/Config;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
         0: .line 387
            invokestatic io.vertx.spi.cluster.hazelcast.ConfigUtil.loadConfig:()Lcom/hazelcast/config/Config;
            areturn
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;

  public com.hazelcast.core.HazelcastInstance getHazelcastInstance();
    descriptor: ()Lcom/hazelcast/core/HazelcastInstance;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
         0: .line 391
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.hazelcast:Lcom/hazelcast/core/HazelcastInstance;
            areturn
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;

  private void lambda$0(io.vertx.core.Promise);
    descriptor: (Lio/vertx/core/Promise;)V
    flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
    Code:
      stack=3, locals=3, args_size=2
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // io.vertx.core.Promise fut
         0: .line 113
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.active:Z
            ifne 16
         1: .line 114
            aload 0 /* this */
            iconst_1
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.active:Z
         2: .line 117
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.customHazelcastCluster:Z
            ifne 10
         3: .line 118
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.conf:Lcom/hazelcast/config/Config;
            ifnonnull 8
         4: .line 119
            aload 0 /* this */
            aload 0 /* this */
            invokevirtual io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.loadConfig:()Lcom/hazelcast/config/Config;
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.conf:Lcom/hazelcast/config/Config;
         5: .line 120
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.conf:Lcom/hazelcast/config/Config;
            ifnonnull 8
         6: .line 121
            getstatic io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.log:Lio/vertx/core/logging/Logger;
            ldc "Cannot find cluster configuration on 'vertx.hazelcast.config' system property, on the classpath, or specified programmatically. Using default hazelcast configuration"
            invokevirtual io.vertx.core.logging.Logger.warn:(Ljava/lang/Object;)V
         7: .line 123
            aload 0 /* this */
            new com.hazelcast.config.Config
            dup
            invokespecial com.hazelcast.config.Config.<init>:()V
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.conf:Lcom/hazelcast/config/Config;
         8: .line 128
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.conf:Lcom/hazelcast/config/Config;
            ldc "hazelcast.shutdownhook.enabled"
            ldc "false"
            invokevirtual com.hazelcast.config.Config.setProperty:(Ljava/lang/String;Ljava/lang/String;)Lcom/hazelcast/config/Config;
            pop
         9: .line 130
            aload 0 /* this */
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.conf:Lcom/hazelcast/config/Config;
            invokestatic com.hazelcast.core.Hazelcast.newHazelcastInstance:(Lcom/hazelcast/config/Config;)Lcom/hazelcast/core/HazelcastInstance;
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.hazelcast:Lcom/hazelcast/core/HazelcastInstance;
        10: .line 133
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.hazelcast:Lcom/hazelcast/core/HazelcastInstance;
            invokeinterface com.hazelcast.core.HazelcastInstance.getCluster:()Lcom/hazelcast/core/Cluster;
            invokeinterface com.hazelcast.core.Cluster.getLocalMember:()Lcom/hazelcast/core/Member;
            astore 2 /* localMember */
        start local 2 // com.hazelcast.core.Member localMember
        11: .line 134
            aload 0 /* this */
            aload 2 /* localMember */
            invokeinterface com.hazelcast.core.Member.getUuid:()Ljava/lang/String;
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeID:Ljava/lang/String;
        12: .line 135
            aload 2 /* localMember */
            ldc "__vertx.nodeId"
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeID:Ljava/lang/String;
            invokeinterface com.hazelcast.core.Member.setStringAttribute:(Ljava/lang/String;Ljava/lang/String;)V
        13: .line 136
            aload 0 /* this */
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.hazelcast:Lcom/hazelcast/core/HazelcastInstance;
            invokeinterface com.hazelcast.core.HazelcastInstance.getCluster:()Lcom/hazelcast/core/Cluster;
            aload 0 /* this */
            invokeinterface com.hazelcast.core.Cluster.addMembershipListener:(Lcom/hazelcast/core/MembershipListener;)Ljava/lang/String;
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.membershipListenerId:Ljava/lang/String;
        14: .line 137
            aload 0 /* this */
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.hazelcast:Lcom/hazelcast/core/HazelcastInstance;
            invokeinterface com.hazelcast.core.HazelcastInstance.getLifecycleService:()Lcom/hazelcast/core/LifecycleService;
            aload 0 /* this */
            invokeinterface com.hazelcast.core.LifecycleService.addLifecycleListener:(Lcom/hazelcast/core/LifecycleListener;)Ljava/lang/String;
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.lifecycleListenerId:Ljava/lang/String;
        15: .line 138
            aload 1 /* fut */
            invokeinterface io.vertx.core.Promise.complete:()V
        end local 2 // com.hazelcast.core.Member localMember
        16: .line 140
      StackMap locals:
      StackMap stack:
            return
        end local 1 // io.vertx.core.Promise fut
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0   17     0         this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0   17     1          fut  Lio/vertx/core/Promise<Ljava/lang/Void;>;
           11   16     2  localMember  Lcom/hazelcast/core/Member;

  private void lambda$1(java.lang.String, io.vertx.core.Promise);
    descriptor: (Ljava/lang/String;Lio/vertx/core/Promise;)V
    flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
    Code:
      stack=4, locals=6, args_size=3
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 2 // io.vertx.core.Promise fut
         0: .line 156
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.hazelcast:Lcom/hazelcast/core/HazelcastInstance;
            aload 1
            invokeinterface com.hazelcast.core.HazelcastInstance.getMultiMap:(Ljava/lang/String;)Lcom/hazelcast/core/MultiMap;
            astore 3 /* multiMap */
        start local 3 // com.hazelcast.core.MultiMap multiMap
         1: .line 157
            new io.vertx.spi.cluster.hazelcast.impl.HazelcastAsyncMultiMap
            dup
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.vertx:Lio/vertx/core/Vertx;
            aload 3 /* multiMap */
            invokespecial io.vertx.spi.cluster.hazelcast.impl.HazelcastAsyncMultiMap.<init>:(Lio/vertx/core/Vertx;Lcom/hazelcast/core/MultiMap;)V
            astore 4 /* asyncMultiMap */
        start local 4 // io.vertx.spi.cluster.hazelcast.impl.HazelcastAsyncMultiMap asyncMultiMap
         2: .line 158
            aload 0 /* this */
            dup
            astore 5
            monitorenter
         3: .line 159
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.multimaps:Ljava/util/Set;
            aload 4 /* asyncMultiMap */
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
         4: .line 158
            aload 5
            monitorexit
         5: goto 8
      StackMap locals: io.vertx.spi.cluster.hazelcast.HazelcastClusterManager java.lang.String io.vertx.core.Promise com.hazelcast.core.MultiMap io.vertx.spi.cluster.hazelcast.impl.HazelcastAsyncMultiMap io.vertx.spi.cluster.hazelcast.HazelcastClusterManager
      StackMap stack: java.lang.Throwable
         6: aload 5
            monitorexit
         7: athrow
         8: .line 161
      StackMap locals:
      StackMap stack:
            aload 2 /* fut */
            aload 4 /* asyncMultiMap */
            invokeinterface io.vertx.core.Promise.complete:(Ljava/lang/Object;)V
        end local 4 // io.vertx.spi.cluster.hazelcast.impl.HazelcastAsyncMultiMap asyncMultiMap
        end local 3 // com.hazelcast.core.MultiMap multiMap
         9: .line 162
            return
        end local 2 // io.vertx.core.Promise fut
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0   10     0           this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0   10     2            fut  Lio/vertx/core/Promise<Lio/vertx/core/spi/cluster/AsyncMultiMap<TK;TV;>;>;
            1    9     3       multiMap  Lcom/hazelcast/core/MultiMap<TK;TV;>;
            2    9     4  asyncMultiMap  Lio/vertx/spi/cluster/hazelcast/impl/HazelcastAsyncMultiMap<TK;TV;>;
      Exception table:
        from    to  target  type
           3     5       6  any
           6     7       6  any

  private void lambda$2(java.lang.String, io.vertx.core.Promise);
    descriptor: (Ljava/lang/String;Lio/vertx/core/Promise;)V
    flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
    Code:
      stack=5, locals=4, args_size=3
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 2 // io.vertx.core.Promise fut
         0: .line 188
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.hazelcast:Lcom/hazelcast/core/HazelcastInstance;
            aload 1
            invokeinterface com.hazelcast.core.HazelcastInstance.getMap:(Ljava/lang/String;)Lcom/hazelcast/core/IMap;
            astore 3 /* map */
        start local 3 // com.hazelcast.core.IMap map
         1: .line 189
            aload 2 /* fut */
            getstatic io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.USE_HZ_ASYNC_API:Z
            ifeq 2
            new io.vertx.spi.cluster.hazelcast.impl.HazelcastInternalAsyncMap
            dup
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.vertx:Lio/vertx/core/Vertx;
            aload 3 /* map */
            invokespecial io.vertx.spi.cluster.hazelcast.impl.HazelcastInternalAsyncMap.<init>:(Lio/vertx/core/Vertx;Lcom/hazelcast/core/IMap;)V
            goto 3
      StackMap locals: io.vertx.spi.cluster.hazelcast.HazelcastClusterManager java.lang.String io.vertx.core.Promise com.hazelcast.core.IMap
      StackMap stack: io.vertx.core.Promise
         2: new io.vertx.spi.cluster.hazelcast.impl.HazelcastAsyncMap
            dup
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.vertx:Lio/vertx/core/Vertx;
            aload 3 /* map */
            invokespecial io.vertx.spi.cluster.hazelcast.impl.HazelcastAsyncMap.<init>:(Lio/vertx/core/Vertx;Lcom/hazelcast/core/IMap;)V
      StackMap locals: io.vertx.spi.cluster.hazelcast.HazelcastClusterManager java.lang.String io.vertx.core.Promise com.hazelcast.core.IMap
      StackMap stack: io.vertx.core.Promise io.vertx.core.shareddata.AsyncMap
         3: invokeinterface io.vertx.core.Promise.complete:(Ljava/lang/Object;)V
        end local 3 // com.hazelcast.core.IMap map
         4: .line 190
            return
        end local 2 // io.vertx.core.Promise fut
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    5     0  this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0    5     2   fut  Lio/vertx/core/Promise<Lio/vertx/core/shareddata/AsyncMap<TK;TV;>;>;
            1    4     3   map  Lcom/hazelcast/core/IMap<TK;TV;>;

  private void lambda$3(java.lang.String, long, io.vertx.core.Promise);
    descriptor: (Ljava/lang/String;JLio/vertx/core/Promise;)V
    flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
    Code:
      stack=7, locals=11, args_size=4
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 4 // io.vertx.core.Promise fut
         0: .line 202
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.hazelcast:Lcom/hazelcast/core/HazelcastInstance;
            new java.lang.StringBuilder
            dup
            ldc "__vertx."
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokeinterface com.hazelcast.core.HazelcastInstance.getSemaphore:(Ljava/lang/String;)Lcom/hazelcast/core/ISemaphore;
            astore 5 /* iSemaphore */
        start local 5 // com.hazelcast.core.ISemaphore iSemaphore
         1: .line 203
            iconst_0
            istore 6 /* locked */
        start local 6 // boolean locked
         2: .line 204
            lload 2
            lstore 7 /* remaining */
        start local 7 // long remaining
         3: .line 206
      StackMap locals: com.hazelcast.core.ISemaphore int long
      StackMap stack:
            invokestatic java.lang.System.nanoTime:()J
            lstore 9 /* start */
        start local 9 // long start
         4: .line 208
            aload 5 /* iSemaphore */
            lload 7 /* remaining */
            getstatic java.util.concurrent.TimeUnit.MILLISECONDS:Ljava/util/concurrent/TimeUnit;
            invokeinterface com.hazelcast.core.ISemaphore.tryAcquire:(JLjava/util/concurrent/TimeUnit;)Z
            istore 6 /* locked */
         5: .line 209
            goto 7
      StackMap locals: io.vertx.spi.cluster.hazelcast.HazelcastClusterManager java.lang.String long io.vertx.core.Promise com.hazelcast.core.ISemaphore int long long
      StackMap stack: java.lang.InterruptedException
         6: pop
         7: .line 212
      StackMap locals:
      StackMap stack:
            lload 7 /* remaining */
            getstatic java.util.concurrent.TimeUnit.MILLISECONDS:Ljava/util/concurrent/TimeUnit;
            invokestatic java.lang.System.nanoTime:()J
            lload 9 /* start */
            lsub
            getstatic java.util.concurrent.TimeUnit.NANOSECONDS:Ljava/util/concurrent/TimeUnit;
            invokevirtual java.util.concurrent.TimeUnit.convert:(JLjava/util/concurrent/TimeUnit;)J
            lsub
            lstore 7 /* remaining */
        end local 9 // long start
         8: .line 213
            iload 6 /* locked */
            ifne 10
            lload 7 /* remaining */
            lconst_0
         9: .line 205
            lcmp
            ifgt 3
        10: .line 214
      StackMap locals:
      StackMap stack:
            iload 6 /* locked */
            ifeq 13
        11: .line 215
            aload 4 /* fut */
            new io.vertx.spi.cluster.hazelcast.HazelcastClusterManager$HazelcastLock
            dup
            aload 0 /* this */
            aload 5 /* iSemaphore */
            invokespecial io.vertx.spi.cluster.hazelcast.HazelcastClusterManager$HazelcastLock.<init>:(Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;Lcom/hazelcast/core/ISemaphore;)V
            invokeinterface io.vertx.core.Promise.complete:(Ljava/lang/Object;)V
        12: .line 216
            goto 14
        13: .line 217
      StackMap locals:
      StackMap stack:
            new io.vertx.core.VertxException
            dup
            new java.lang.StringBuilder
            dup
            ldc "Timed out waiting to get lock "
            invokespecial java.lang.StringBuilder.<init>:(Ljava/lang/String;)V
            aload 1
            invokevirtual java.lang.StringBuilder.append:(Ljava/lang/String;)Ljava/lang/StringBuilder;
            invokevirtual java.lang.StringBuilder.toString:()Ljava/lang/String;
            invokespecial io.vertx.core.VertxException.<init>:(Ljava/lang/String;)V
            athrow
        end local 7 // long remaining
        end local 6 // boolean locked
        end local 5 // com.hazelcast.core.ISemaphore iSemaphore
        14: .line 219
      StackMap locals:
      StackMap stack:
            return
        end local 4 // io.vertx.core.Promise fut
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0   15     0        this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0   15     4         fut  Lio/vertx/core/Promise<Lio/vertx/core/shareddata/Lock;>;
            1   14     5  iSemaphore  Lcom/hazelcast/core/ISemaphore;
            2   14     6      locked  Z
            3   14     7   remaining  J
            4    8     9       start  J
      Exception table:
        from    to  target  type
           4     5       6  Class java.lang.InterruptedException

  private void lambda$4(java.lang.String, io.vertx.core.Promise);
    descriptor: (Ljava/lang/String;Lio/vertx/core/Promise;)V
    flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
    Code:
      stack=6, locals=3, args_size=3
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 2 // io.vertx.core.Promise fut
         0: .line 225
            aload 2 /* fut */
         1: .line 226
            getstatic io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.USE_HZ_ASYNC_API:Z
            ifeq 3
         2: .line 227
            new io.vertx.spi.cluster.hazelcast.impl.HazelcastInternalAsyncCounter
            dup
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.vertx:Lio/vertx/core/Vertx;
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.hazelcast:Lcom/hazelcast/core/HazelcastInstance;
            aload 1
            invokeinterface com.hazelcast.core.HazelcastInstance.getAtomicLong:(Ljava/lang/String;)Lcom/hazelcast/core/IAtomicLong;
            invokespecial io.vertx.spi.cluster.hazelcast.impl.HazelcastInternalAsyncCounter.<init>:(Lio/vertx/core/Vertx;Lcom/hazelcast/core/IAtomicLong;)V
            goto 4
         3: .line 228
      StackMap locals:
      StackMap stack: io.vertx.core.Promise
            new io.vertx.spi.cluster.hazelcast.HazelcastClusterManager$HazelcastCounter
            dup
            aload 0 /* this */
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.hazelcast:Lcom/hazelcast/core/HazelcastInstance;
            aload 1
            invokeinterface com.hazelcast.core.HazelcastInstance.getAtomicLong:(Ljava/lang/String;)Lcom/hazelcast/core/IAtomicLong;
            invokespecial io.vertx.spi.cluster.hazelcast.HazelcastClusterManager$HazelcastCounter.<init>:(Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;Lcom/hazelcast/core/IAtomicLong;)V
         4: .line 225
      StackMap locals: io.vertx.spi.cluster.hazelcast.HazelcastClusterManager java.lang.String io.vertx.core.Promise
      StackMap stack: io.vertx.core.Promise io.vertx.core.shareddata.Counter
            invokeinterface io.vertx.core.Promise.complete:(Ljava/lang/Object;)V
         5: .line 229
            return
        end local 2 // io.vertx.core.Promise fut
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0    6     2   fut  Lio/vertx/core/Promise<Lio/vertx/core/shareddata/Counter;>;

  private void lambda$5(io.vertx.core.Promise);
    descriptor: (Lio/vertx/core/Promise;)V
    flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
    Code:
      stack=2, locals=4, args_size=2
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // io.vertx.core.Promise fut
         0: .line 237
            aload 0 /* this */
            dup
            astore 2
            monitorenter
         1: .line 238
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.active:Z
            ifeq 22
         2: .line 240
            aload 0 /* this */
            iconst_0
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.active:Z
         3: .line 241
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.hazelcast:Lcom/hazelcast/core/HazelcastInstance;
            invokeinterface com.hazelcast.core.HazelcastInstance.getCluster:()Lcom/hazelcast/core/Cluster;
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.membershipListenerId:Ljava/lang/String;
            invokeinterface com.hazelcast.core.Cluster.removeMembershipListener:(Ljava/lang/String;)Z
            istore 3 /* left */
        start local 3 // boolean left
         4: .line 242
            iload 3 /* left */
            ifne 6
         5: .line 243
            getstatic io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.log:Lio/vertx/core/logging/Logger;
            ldc "No membership listener"
            invokevirtual io.vertx.core.logging.Logger.warn:(Ljava/lang/Object;)V
         6: .line 245
      StackMap locals: io.vertx.spi.cluster.hazelcast.HazelcastClusterManager int
      StackMap stack:
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.hazelcast:Lcom/hazelcast/core/HazelcastInstance;
            invokeinterface com.hazelcast.core.HazelcastInstance.getLifecycleService:()Lcom/hazelcast/core/LifecycleService;
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.lifecycleListenerId:Ljava/lang/String;
            invokeinterface com.hazelcast.core.LifecycleService.removeLifecycleListener:(Ljava/lang/String;)Z
            pop
         7: .line 248
            goto 16
         8: .line 251
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.hazelcast:Lcom/hazelcast/core/HazelcastInstance;
            invokeinterface com.hazelcast.core.HazelcastInstance.getLifecycleService:()Lcom/hazelcast/core/LifecycleService;
            invokeinterface com.hazelcast.core.LifecycleService.shutdown:()V
         9: .line 252
            goto 12
      StackMap locals:
      StackMap stack: java.util.concurrent.RejectedExecutionException
        10: pop
        11: .line 253
            getstatic io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.log:Lio/vertx/core/logging/Logger;
            ldc "Rejected execution of the shutdown operation, retrying"
            invokevirtual io.vertx.core.logging.Logger.debug:(Ljava/lang/Object;)V
        12: .line 256
      StackMap locals:
      StackMap stack:
            lconst_1
            invokestatic java.lang.Thread.sleep:(J)V
        13: .line 257
            goto 16
      StackMap locals:
      StackMap stack: java.lang.InterruptedException
        14: pop
        15: .line 259
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokevirtual java.lang.Thread.interrupt:()V
        16: .line 248
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.customHazelcastCluster:Z
            ifne 17
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.hazelcast:Lcom/hazelcast/core/HazelcastInstance;
            invokeinterface com.hazelcast.core.HazelcastInstance.getLifecycleService:()Lcom/hazelcast/core/LifecycleService;
            invokeinterface com.hazelcast.core.LifecycleService.isRunning:()Z
            ifne 8
        17: .line 263
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.customHazelcastCluster:Z
            ifeq 22
        18: .line 264
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.hazelcast:Lcom/hazelcast/core/HazelcastInstance;
            invokeinterface com.hazelcast.core.HazelcastInstance.getCluster:()Lcom/hazelcast/core/Cluster;
            invokeinterface com.hazelcast.core.Cluster.getLocalMember:()Lcom/hazelcast/core/Member;
            ldc "__vertx.nodeId"
            invokeinterface com.hazelcast.core.Member.removeAttribute:(Ljava/lang/String;)V
        end local 3 // boolean left
        19: .line 267
            goto 22
      StackMap locals: io.vertx.spi.cluster.hazelcast.HazelcastClusterManager io.vertx.core.Promise io.vertx.spi.cluster.hazelcast.HazelcastClusterManager
      StackMap stack: java.lang.Throwable
        20: astore 3 /* t */
        start local 3 // java.lang.Throwable t
        21: .line 268
            aload 1 /* fut */
            aload 3 /* t */
            invokeinterface io.vertx.core.Promise.fail:(Ljava/lang/Throwable;)V
        end local 3 // java.lang.Throwable t
        22: .line 237
      StackMap locals:
      StackMap stack:
            aload 2
            monitorexit
        23: goto 26
      StackMap locals:
      StackMap stack: java.lang.Throwable
        24: aload 2
            monitorexit
        25: athrow
        26: .line 272
      StackMap locals:
      StackMap stack:
            aload 1 /* fut */
            invokeinterface io.vertx.core.Promise.complete:()V
        27: .line 273
            return
        end local 1 // io.vertx.core.Promise fut
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0   28     0  this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0   28     1   fut  Lio/vertx/core/Promise<Ljava/lang/Void;>;
            4   19     3  left  Z
           21   22     3     t  Ljava/lang/Throwable;
      Exception table:
        from    to  target  type
           8     9      10  Class java.util.concurrent.RejectedExecutionException
          12    13      14  Class java.lang.InterruptedException
           2    19      20  Class java.lang.Throwable
           1    23      24  any
          24    25      24  any
}
SourceFile: "HazelcastClusterManager.java"
NestMembers:
  io.vertx.spi.cluster.hazelcast.HazelcastClusterManager$HazelcastCounter  io.vertx.spi.cluster.hazelcast.HazelcastClusterManager$HazelcastLock
InnerClasses:
  public final LifecycleState = com.hazelcast.core.LifecycleEvent$LifecycleState of com.hazelcast.core.LifecycleEvent
  private HazelcastCounter = io.vertx.spi.cluster.hazelcast.HazelcastClusterManager$HazelcastCounter of io.vertx.spi.cluster.hazelcast.HazelcastClusterManager
  private HazelcastLock = io.vertx.spi.cluster.hazelcast.HazelcastClusterManager$HazelcastLock of io.vertx.spi.cluster.hazelcast.HazelcastClusterManager
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles