public class io.vertx.spi.cluster.hazelcast.HazelcastClusterManager implements io.vertx.core.spi.cluster.ClusterManager, com.hazelcast.cluster.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.impl.logging.Logger log;
    descriptor: Lio/vertx/core/impl/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 io.vertx.core.impl.VertxInternal vertx;
    descriptor: Lio/vertx/core/impl/VertxInternal;
    flags: (0x0002) ACC_PRIVATE

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

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

  private java.util.UUID nodeId;
    descriptor: Ljava/util/UUID;
    flags: (0x0002) ACC_PRIVATE

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

  private io.vertx.spi.cluster.hazelcast.impl.SubsMapHelper subsMapHelper;
    descriptor: Lio/vertx/spi/cluster/hazelcast/impl/SubsMapHelper;
    flags: (0x0002) ACC_PRIVATE

  private com.hazelcast.map.IMap<java.lang.String, io.vertx.spi.cluster.hazelcast.impl.HazelcastNodeInfo> nodeInfoMap;
    descriptor: Lcom/hazelcast/map/IMap;
    flags: (0x0002) ACC_PRIVATE
    Signature: Lcom/hazelcast/map/IMap<Ljava/lang/String;Lio/vertx/spi/cluster/hazelcast/impl/HazelcastNodeInfo;>;

  private java.util.UUID membershipListenerId;
    descriptor: Ljava/util/UUID;
    flags: (0x0002) ACC_PRIVATE

  private java.util.UUID lifecycleListenerId;
    descriptor: Ljava/util/UUID;
    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 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

  private java.util.concurrent.ExecutorService lockReleaseExec;
    descriptor: Ljava/util/concurrent/ExecutorService;
    flags: (0x0002) ACC_PRIVATE

  static void <clinit>();
    descriptor: ()V
    flags: (0x0008) ACC_STATIC
    Code:
      stack=1, locals=0, args_size=0
         0: .line 57
            ldc Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            invokestatic io.vertx.core.impl.logging.LoggerFactory.getLogger:(Ljava/lang/Class;)Lio/vertx/core/impl/logging/Logger;
            putstatic io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.log:Lio/vertx/core/impl/logging/Logger;
         1: .line 59
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
         0: .line 84
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 72
            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 85
            return
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     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=3, 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 92
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 72
            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 93
            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
         3: .line 94
            aload 0 /* this */
            aload 1 /* conf */
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.conf:Lcom/hazelcast/config/Config;
         4: .line 95
            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    5     0  this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0    5     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=3, 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 97
            aload 0 /* this */
            invokespecial java.lang.Object.<init>:()V
         1: .line 72
            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 98
            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
         3: .line 99
            aload 0 /* this */
            aload 1 /* instance */
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.hazelcast:Lcom/hazelcast/core/HazelcastInstance;
         4: .line 100
            aload 0 /* this */
            iconst_1
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.customHazelcastCluster:Z
         5: .line 101
            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    6     0      this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0    6     1  instance  Lcom/hazelcast/core/HazelcastInstance;
    MethodParameters:
          Name  Flags
      instance  

  public void init(io.vertx.core.Vertx, io.vertx.core.spi.cluster.NodeSelector);
    descriptor: (Lio/vertx/core/Vertx;Lio/vertx/core/spi/cluster/NodeSelector;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=3, args_size=3
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // io.vertx.core.Vertx vertx
        start local 2 // io.vertx.core.spi.cluster.NodeSelector nodeSelector
         0: .line 105
            aload 0 /* this */
            aload 1 /* vertx */
            checkcast io.vertx.core.impl.VertxInternal
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.vertx:Lio/vertx/core/impl/VertxInternal;
         1: .line 106
            aload 0 /* this */
            aload 2 /* nodeSelector */
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeSelector:Lio/vertx/core/spi/cluster/NodeSelector;
         2: .line 107
            return
        end local 2 // io.vertx.core.spi.cluster.NodeSelector nodeSelector
        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    3     0          this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0    3     1         vertx  Lio/vertx/core/Vertx;
            0    3     2  nodeSelector  Lio/vertx/core/spi/cluster/NodeSelector;
    MethodParameters:
              Name  Flags
      vertx         
      nodeSelector  

  public void join(io.vertx.core.Promise<java.lang.Void>);
    descriptor: (Lio/vertx/core/Promise;)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.Promise promise
         0: .line 111
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.vertx:Lio/vertx/core/impl/VertxInternal;
            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 144
            aload 1 /* promise */
         2: .line 111
            invokeinterface io.vertx.core.impl.VertxInternal.executeBlocking:(Lio/vertx/core/Handler;Lio/vertx/core/Handler;)V
         3: .line 145
            return
        end local 1 // io.vertx.core.Promise promise
        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  promise  Lio/vertx/core/Promise<Ljava/lang/Void;>;
    Signature: (Lio/vertx/core/Promise<Ljava/lang/Void;>;)V
    MethodParameters:
         Name  Flags
      promise  

  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 149
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeId:Ljava/util/UUID;
            invokevirtual java.util.UUID.toString:()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=4, args_size=1
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
         0: .line 154
            new java.util.ArrayList
            dup
            invokespecial java.util.ArrayList.<init>:()V
            astore 1 /* list */
        start local 1 // java.util.List list
         1: .line 155
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.hazelcast:Lcom/hazelcast/core/HazelcastInstance;
            invokeinterface com.hazelcast.core.HazelcastInstance.getCluster:()Lcom/hazelcast/cluster/Cluster;
            invokeinterface com.hazelcast.cluster.Cluster.getMembers:()Ljava/util/Set;
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 3
            goto 4
      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.cluster.Member
            astore 2 /* member */
        start local 2 // com.hazelcast.cluster.Member member
         3: .line 156
            aload 1 /* list */
            aload 2 /* member */
            invokeinterface com.hazelcast.cluster.Member.getUuid:()Ljava/util/UUID;
            invokevirtual java.util.UUID.toString:()Ljava/lang/String;
            invokeinterface java.util.List.add:(Ljava/lang/Object;)Z
            pop
        end local 2 // com.hazelcast.cluster.Member member
         4: .line 155
      StackMap locals:
      StackMap stack:
            aload 3
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 2
         5: .line 158
            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    6     0    this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            1    6     1    list  Ljava/util/List<Ljava/lang/String;>;
            3    4     2  member  Lcom/hazelcast/cluster/Member;
    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 163
            aload 0 /* this */
            aload 1 /* listener */
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeListener:Lio/vertx/core/spi/cluster/NodeListener;
         1: .line 164
            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 void setNodeInfo(io.vertx.core.spi.cluster.NodeInfo, io.vertx.core.Promise<java.lang.Void>);
    descriptor: (Lio/vertx/core/spi/cluster/NodeInfo;Lio/vertx/core/Promise;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=3
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // io.vertx.core.spi.cluster.NodeInfo nodeInfo
        start local 2 // io.vertx.core.Promise promise
         0: .line 168
            aload 0 /* this */
            dup
            astore 3
            monitorenter
         1: .line 169
            aload 0 /* this */
            aload 1 /* nodeInfo */
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeInfo:Lio/vertx/core/spi/cluster/NodeInfo;
         2: .line 168
            aload 3
            monitorexit
         3: goto 6
      StackMap locals: io.vertx.spi.cluster.hazelcast.HazelcastClusterManager io.vertx.core.spi.cluster.NodeInfo io.vertx.core.Promise io.vertx.spi.cluster.hazelcast.HazelcastClusterManager
      StackMap stack: java.lang.Throwable
         4: aload 3
            monitorexit
         5: athrow
         6: .line 171
      StackMap locals:
      StackMap stack:
            new io.vertx.spi.cluster.hazelcast.impl.HazelcastNodeInfo
            dup
            aload 1 /* nodeInfo */
            invokespecial io.vertx.spi.cluster.hazelcast.impl.HazelcastNodeInfo.<init>:(Lio/vertx/core/spi/cluster/NodeInfo;)V
            astore 3 /* value */
        start local 3 // io.vertx.spi.cluster.hazelcast.impl.HazelcastNodeInfo value
         7: .line 172
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.vertx:Lio/vertx/core/impl/VertxInternal;
            aload 0 /* this */
            aload 3 /* value */
            invokedynamic handle(Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;Lio/vertx/spi/cluster/hazelcast/impl/HazelcastNodeInfo;)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(Lio/vertx/spi/cluster/hazelcast/impl/HazelcastNodeInfo;Lio/vertx/core/Promise;)V (7)
                  (Lio/vertx/core/Promise;)V
         8: .line 175
            iconst_0
            aload 2 /* promise */
         9: .line 172
            invokeinterface io.vertx.core.impl.VertxInternal.executeBlocking:(Lio/vertx/core/Handler;ZLio/vertx/core/Handler;)V
        10: .line 176
            return
        end local 3 // io.vertx.spi.cluster.hazelcast.impl.HazelcastNodeInfo value
        end local 2 // io.vertx.core.Promise promise
        end local 1 // io.vertx.core.spi.cluster.NodeInfo nodeInfo
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0   11     0      this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0   11     1  nodeInfo  Lio/vertx/core/spi/cluster/NodeInfo;
            0   11     2   promise  Lio/vertx/core/Promise<Ljava/lang/Void;>;
            7   11     3     value  Lio/vertx/spi/cluster/hazelcast/impl/HazelcastNodeInfo;
      Exception table:
        from    to  target  type
           1     3       4  any
           4     5       4  any
    Signature: (Lio/vertx/core/spi/cluster/NodeInfo;Lio/vertx/core/Promise<Ljava/lang/Void;>;)V
    MethodParameters:
          Name  Flags
      nodeInfo  
      promise   

  public synchronized io.vertx.core.spi.cluster.NodeInfo getNodeInfo();
    descriptor: ()Lio/vertx/core/spi/cluster/NodeInfo;
    flags: (0x0021) ACC_PUBLIC, ACC_SYNCHRONIZED
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
         0: .line 180
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeInfo:Lio/vertx/core/spi/cluster/NodeInfo;
            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 getNodeInfo(java.lang.String, io.vertx.core.Promise<io.vertx.core.spi.cluster.NodeInfo>);
    descriptor: (Ljava/lang/String;Lio/vertx/core/Promise;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // java.lang.String nodeId
        start local 2 // io.vertx.core.Promise promise
         0: .line 185
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.vertx:Lio/vertx/core/impl/VertxInternal;
            aload 0 /* this */
            aload 1 /* nodeId */
            aload 2 /* promise */
            invokedynamic handle(Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;Ljava/lang/String;Lio/vertx/core/Promise;)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;Lio/vertx/core/Promise;Lio/vertx/core/Promise;)V (7)
                  (Lio/vertx/core/Promise;)V
         1: .line 192
            iconst_0
            aload 2 /* promise */
         2: .line 185
            invokeinterface io.vertx.core.impl.VertxInternal.executeBlocking:(Lio/vertx/core/Handler;ZLio/vertx/core/Handler;)V
         3: .line 193
            return
        end local 2 // io.vertx.core.Promise promise
        end local 1 // java.lang.String nodeId
        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   nodeId  Ljava/lang/String;
            0    4     2  promise  Lio/vertx/core/Promise<Lio/vertx/core/spi/cluster/NodeInfo;>;
    Signature: (Ljava/lang/String;Lio/vertx/core/Promise<Lio/vertx/core/spi/cluster/NodeInfo;>;)V
    MethodParameters:
         Name  Flags
      nodeId   
      promise  

  public <K, V> void getAsyncMap(java.lang.String, io.vertx.core.Promise<io.vertx.core.shareddata.AsyncMap<K, V>>);
    descriptor: (Ljava/lang/String;Lio/vertx/core/Promise;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, 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.Promise promise
         0: .line 197
            aload 2 /* promise */
            new io.vertx.spi.cluster.hazelcast.impl.HazelcastAsyncMap
            dup
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.vertx:Lio/vertx/core/impl/VertxInternal;
            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/map/IMap;
            invokespecial io.vertx.spi.cluster.hazelcast.impl.HazelcastAsyncMap.<init>:(Lio/vertx/core/impl/VertxInternal;Lcom/hazelcast/map/IMap;)V
            invokeinterface io.vertx.core.Promise.complete:(Ljava/lang/Object;)V
         1: .line 198
            return
        end local 2 // io.vertx.core.Promise promise
        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;
            0    2     2  promise  Lio/vertx/core/Promise<Lio/vertx/core/shareddata/AsyncMap<TK;TV;>;>;
    Signature: <K:Ljava/lang/Object;V:Ljava/lang/Object;>(Ljava/lang/String;Lio/vertx/core/Promise<Lio/vertx/core/shareddata/AsyncMap<TK;TV;>;>;)V
    MethodParameters:
         Name  Flags
      name     
      promise  

  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=2, args_size=2
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // java.lang.String name
         0: .line 202
            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/map/IMap;
            areturn
        end local 1 // java.lang.String name
        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  name  Ljava/lang/String;
    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.Promise<io.vertx.core.shareddata.Lock>);
    descriptor: (Ljava/lang/String;JLio/vertx/core/Promise;)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.Promise promise
         0: .line 207
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.vertx:Lio/vertx/core/impl/VertxInternal;
            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$4(Ljava/lang/String;JLio/vertx/core/Promise;)V (7)
                  (Lio/vertx/core/Promise;)V
         1: .line 225
            iconst_0
            aload 4 /* promise */
         2: .line 207
            invokeinterface io.vertx.core.impl.VertxInternal.executeBlocking:(Lio/vertx/core/Handler;ZLio/vertx/core/Handler;)V
         3: .line 226
            return
        end local 4 // io.vertx.core.Promise promise
        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  promise  Lio/vertx/core/Promise<Lio/vertx/core/shareddata/Lock;>;
    Signature: (Ljava/lang/String;JLio/vertx/core/Promise<Lio/vertx/core/shareddata/Lock;>;)V
    MethodParameters:
         Name  Flags
      name     
      timeout  
      promise  

  public void getCounter(java.lang.String, io.vertx.core.Promise<io.vertx.core.shareddata.Counter>);
    descriptor: (Ljava/lang/String;Lio/vertx/core/Promise;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=6, 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.Promise promise
         0: .line 230
            aload 2 /* promise */
            new io.vertx.spi.cluster.hazelcast.impl.HazelcastCounter
            dup
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.vertx:Lio/vertx/core/impl/VertxInternal;
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.hazelcast:Lcom/hazelcast/core/HazelcastInstance;
            invokeinterface com.hazelcast.core.HazelcastInstance.getCPSubsystem:()Lcom/hazelcast/cp/CPSubsystem;
            aload 1 /* name */
            invokeinterface com.hazelcast.cp.CPSubsystem.getAtomicLong:(Ljava/lang/String;)Lcom/hazelcast/cp/IAtomicLong;
            invokespecial io.vertx.spi.cluster.hazelcast.impl.HazelcastCounter.<init>:(Lio/vertx/core/impl/VertxInternal;Lcom/hazelcast/cp/IAtomicLong;)V
            invokeinterface io.vertx.core.Promise.complete:(Ljava/lang/Object;)V
         1: .line 231
            return
        end local 2 // io.vertx.core.Promise promise
        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;
            0    2     2  promise  Lio/vertx/core/Promise<Lio/vertx/core/shareddata/Counter;>;
    Signature: (Ljava/lang/String;Lio/vertx/core/Promise<Lio/vertx/core/shareddata/Counter;>;)V
    MethodParameters:
         Name  Flags
      name     
      promise  

  public void leave(io.vertx.core.Promise<java.lang.Void>);
    descriptor: (Lio/vertx/core/Promise;)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.Promise promise
         0: .line 235
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.vertx:Lio/vertx/core/impl/VertxInternal;
            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 272
            aload 1 /* promise */
         2: .line 235
            invokeinterface io.vertx.core.impl.VertxInternal.executeBlocking:(Lio/vertx/core/Handler;Lio/vertx/core/Handler;)V
         3: .line 273
            return
        end local 1 // io.vertx.core.Promise promise
        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  promise  Lio/vertx/core/Promise<Ljava/lang/Void;>;
    Signature: (Lio/vertx/core/Promise<Ljava/lang/Void;>;)V
    MethodParameters:
         Name  Flags
      promise  

  public synchronized void memberAdded(com.hazelcast.cluster.MembershipEvent);
    descriptor: (Lcom/hazelcast/cluster/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.cluster.MembershipEvent membershipEvent
         0: .line 277
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.active:Z
            ifne 2
         1: .line 278
            return
         2: .line 280
      StackMap locals:
      StackMap stack:
            aload 1 /* membershipEvent */
            invokevirtual com.hazelcast.cluster.MembershipEvent.getMember:()Lcom/hazelcast/cluster/Member;
            astore 2 /* member */
        start local 2 // com.hazelcast.cluster.Member member
         3: .line 281
            aload 2 /* member */
            invokeinterface com.hazelcast.cluster.Member.getUuid:()Ljava/util/UUID;
            invokevirtual java.util.UUID.toString:()Ljava/lang/String;
            astore 3 /* nid */
        start local 3 // java.lang.String nid
         4: .line 283
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeListener:Lio/vertx/core/spi/cluster/NodeListener;
            ifnull 10
         5: .line 284
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeIds:Ljava/util/Set;
            aload 3 /* nid */
            invokeinterface java.util.Set.add:(Ljava/lang/Object;)Z
            pop
         6: .line 285
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeListener:Lio/vertx/core/spi/cluster/NodeListener;
            aload 3 /* nid */
            invokeinterface io.vertx.core.spi.cluster.NodeListener.nodeAdded:(Ljava/lang/String;)V
         7: .line 287
            goto 10
      StackMap locals: io.vertx.spi.cluster.hazelcast.HazelcastClusterManager com.hazelcast.cluster.MembershipEvent com.hazelcast.cluster.Member java.lang.String
      StackMap stack: java.lang.Throwable
         8: astore 4 /* t */
        start local 4 // java.lang.Throwable t
         9: .line 288
            getstatic io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.log:Lio/vertx/core/impl/logging/Logger;
            ldc "Failed to handle memberAdded"
            aload 4 /* t */
            invokeinterface io.vertx.core.impl.logging.Logger.error:(Ljava/lang/Object;Ljava/lang/Throwable;)V
        end local 4 // java.lang.Throwable t
        10: .line 290
      StackMap locals:
      StackMap stack:
            return
        end local 3 // java.lang.String nid
        end local 2 // com.hazelcast.cluster.Member member
        end local 1 // com.hazelcast.cluster.MembershipEvent membershipEvent
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot             Name  Signature
            0   11     0             this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0   11     1  membershipEvent  Lcom/hazelcast/cluster/MembershipEvent;
            3   11     2           member  Lcom/hazelcast/cluster/Member;
            4   11     3              nid  Ljava/lang/String;
            9   10     4                t  Ljava/lang/Throwable;
      Exception table:
        from    to  target  type
           4     7       8  Class java.lang.Throwable
    MethodParameters:
                 Name  Flags
      membershipEvent  

  public synchronized void memberRemoved(com.hazelcast.cluster.MembershipEvent);
    descriptor: (Lcom/hazelcast/cluster/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.cluster.MembershipEvent membershipEvent
         0: .line 294
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.active:Z
            ifne 2
         1: .line 295
            return
         2: .line 297
      StackMap locals:
      StackMap stack:
            aload 1 /* membershipEvent */
            invokevirtual com.hazelcast.cluster.MembershipEvent.getMember:()Lcom/hazelcast/cluster/Member;
            astore 2 /* member */
        start local 2 // com.hazelcast.cluster.Member member
         3: .line 298
            aload 2 /* member */
            invokeinterface com.hazelcast.cluster.Member.getUuid:()Ljava/util/UUID;
            invokevirtual java.util.UUID.toString:()Ljava/lang/String;
            astore 3 /* nid */
        start local 3 // java.lang.String nid
         4: .line 300
            aload 0 /* this */
            aload 3 /* nid */
            invokestatic java.util.Collections.singleton:(Ljava/lang/Object;)Ljava/util/Set;
            invokevirtual io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.membersRemoved:(Ljava/util/Set;)V
         5: .line 301
            goto 8
      StackMap locals: io.vertx.spi.cluster.hazelcast.HazelcastClusterManager com.hazelcast.cluster.MembershipEvent com.hazelcast.cluster.Member java.lang.String
      StackMap stack: java.lang.Throwable
         6: astore 4 /* t */
        start local 4 // java.lang.Throwable t
         7: .line 302
            getstatic io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.log:Lio/vertx/core/impl/logging/Logger;
            ldc "Failed to handle memberRemoved"
            aload 4 /* t */
            invokeinterface io.vertx.core.impl.logging.Logger.error:(Ljava/lang/Object;Ljava/lang/Throwable;)V
        end local 4 // java.lang.Throwable t
         8: .line 304
      StackMap locals:
      StackMap stack:
            return
        end local 3 // java.lang.String nid
        end local 2 // com.hazelcast.cluster.Member member
        end local 1 // com.hazelcast.cluster.MembershipEvent membershipEvent
        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;
            0    9     1  membershipEvent  Lcom/hazelcast/cluster/MembershipEvent;
            3    9     2           member  Lcom/hazelcast/cluster/Member;
            4    9     3              nid  Ljava/lang/String;
            7    8     4                t  Ljava/lang/Throwable;
      Exception table:
        from    to  target  type
           4     5       6  Class java.lang.Throwable
    MethodParameters:
                 Name  Flags
      membershipEvent  

  private synchronized void membersRemoved(java.util.Set<java.lang.String>);
    descriptor: (Ljava/util/Set;)V
    flags: (0x0022) ACC_PRIVATE, ACC_SYNCHRONIZED
    Code:
      stack=5, locals=2, args_size=2
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // java.util.Set ids
         0: .line 307
            aload 0 /* this */
            aload 1 /* ids */
            invokevirtual io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.cleanSubs:(Ljava/util/Set;)V
         1: .line 308
            aload 0 /* this */
            aload 1 /* ids */
            invokevirtual io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.cleanNodeInfos:(Ljava/util/Set;)V
         2: .line 309
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeInfoMap:Lcom/hazelcast/map/IMap;
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeId:Ljava/util/UUID;
            invokevirtual java.util.UUID.toString:()Ljava/lang/String;
            new io.vertx.spi.cluster.hazelcast.impl.HazelcastNodeInfo
            dup
            aload 0 /* this */
            invokevirtual io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.getNodeInfo:()Lio/vertx/core/spi/cluster/NodeInfo;
            invokespecial io.vertx.spi.cluster.hazelcast.impl.HazelcastNodeInfo.<init>:(Lio/vertx/core/spi/cluster/NodeInfo;)V
            invokeinterface com.hazelcast.map.IMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         3: .line 310
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeSelector:Lio/vertx/core/spi/cluster/NodeSelector;
            invokeinterface io.vertx.core.spi.cluster.NodeSelector.registrationsLost:()V
         4: .line 311
            aload 0 /* this */
            invokevirtual io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.republishOwnSubs:()V
         5: .line 312
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeListener:Lio/vertx/core/spi/cluster/NodeListener;
            ifnull 8
         6: .line 313
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeIds:Ljava/util/Set;
            aload 1 /* ids */
            invokeinterface java.util.Set.removeAll:(Ljava/util/Collection;)Z
            pop
         7: .line 314
            aload 1 /* ids */
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeListener:Lio/vertx/core/spi/cluster/NodeListener;
            dup
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            pop
            invokedynamic accept(Lio/vertx/core/spi/cluster/NodeListener;)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/core/spi/cluster/NodeListener.nodeLeft(Ljava/lang/String;)V (9 itf)
                  (Ljava/lang/String;)V
            invokeinterface java.util.Set.forEach:(Ljava/util/function/Consumer;)V
         8: .line 316
      StackMap locals:
      StackMap stack:
            return
        end local 1 // java.util.Set ids
        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;
            0    9     1   ids  Ljava/util/Set<Ljava/lang/String;>;
    Signature: (Ljava/util/Set<Ljava/lang/String;>;)V
    MethodParameters:
      Name  Flags
      ids   

  private void cleanSubs(java.util.Set<java.lang.String>);
    descriptor: (Ljava/util/Set;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // java.util.Set ids
         0: .line 319
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.subsMapHelper:Lio/vertx/spi/cluster/hazelcast/impl/SubsMapHelper;
            aload 1 /* ids */
            invokevirtual io.vertx.spi.cluster.hazelcast.impl.SubsMapHelper.removeAllForNodes:(Ljava/util/Set;)V
         1: .line 320
            return
        end local 1 // java.util.Set ids
        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   ids  Ljava/util/Set<Ljava/lang/String;>;
    Signature: (Ljava/util/Set<Ljava/lang/String;>;)V
    MethodParameters:
      Name  Flags
      ids   

  private void cleanNodeInfos(java.util.Set<java.lang.String>);
    descriptor: (Ljava/util/Set;)V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=2, args_size=2
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // java.util.Set ids
         0: .line 323
            aload 1 /* ids */
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeInfoMap:Lcom/hazelcast/map/IMap;
            dup
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            pop
            invokedynamic accept(Lcom/hazelcast/map/IMap;)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
                  com/hazelcast/map/IMap.remove(Ljava/lang/Object;)Ljava/lang/Object; (9 itf)
                  (Ljava/lang/String;)V
            invokeinterface java.util.Set.forEach:(Ljava/util/function/Consumer;)V
         1: .line 324
            return
        end local 1 // java.util.Set ids
        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   ids  Ljava/util/Set<Ljava/lang/String;>;
    Signature: (Ljava/util/Set<Ljava/lang/String;>;)V
    MethodParameters:
      Name  Flags
      ids   

  private void republishOwnSubs();
    descriptor: ()V
    flags: (0x0002) ACC_PRIVATE
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
         0: .line 327
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.vertx:Lio/vertx/core/impl/VertxInternal;
            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$8(Lio/vertx/core/Promise;)V (7)
                  (Lio/vertx/core/Promise;)V
         1: .line 330
            iconst_0
         2: .line 327
            invokeinterface io.vertx.core.impl.VertxInternal.executeBlocking:(Lio/vertx/core/Handler;Z)Lio/vertx/core/Future;
            pop
         3: .line 331
            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 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 335
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.active:Z
            ifne 2
         1: .line 336
            return
         2: .line 339
      StackMap locals:
      StackMap stack:
            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 14
         3: .line 340
            aload 0 /* this */
            invokevirtual io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.getNodes:()Ljava/util/List;
            astore 2 /* currentNodes */
        start local 2 // java.util.List currentNodes
         4: .line 341
            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
         5: .line 342
            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
         6: .line 343
            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
         7: .line 344
            aload 4 /* removedMembers */
            aload 2 /* currentNodes */
            invokeinterface java.util.Set.removeAll:(Ljava/util/Collection;)Z
            pop
         8: .line 345
            aload 3 /* newNodes */
            invokeinterface java.util.Set.iterator:()Ljava/util/Iterator;
            astore 6
            goto 11
      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:
         9: aload 6
            invokeinterface java.util.Iterator.next:()Ljava/lang/Object;
            checkcast java.lang.String
            astore 5 /* nodeId */
        start local 5 // java.lang.String nodeId
        10: .line 346
            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
        11: .line 345
      StackMap locals:
      StackMap stack:
            aload 6
            invokeinterface java.util.Iterator.hasNext:()Z
            ifne 9
        12: .line 348
            aload 0 /* this */
            aload 4 /* removedMembers */
            invokevirtual io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.membersRemoved:(Ljava/util/Set;)V
        13: .line 349
            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
        14: .line 351
      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   15     0            this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0   15     1  lifecycleEvent  Lcom/hazelcast/core/LifecycleEvent;
            4   14     2    currentNodes  Ljava/util/List<Ljava/lang/String;>;
            5   14     3        newNodes  Ljava/util/Set<Ljava/lang/String;>;
            7   14     4  removedMembers  Ljava/util/Set<Ljava/lang/String;>;
           10   11     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 355
            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 addRegistration(java.lang.String, io.vertx.core.spi.cluster.RegistrationInfo, io.vertx.core.Promise<java.lang.Void>);
    descriptor: (Ljava/lang/String;Lio/vertx/core/spi/cluster/RegistrationInfo;Lio/vertx/core/Promise;)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 address
        start local 2 // io.vertx.core.spi.cluster.RegistrationInfo registrationInfo
        start local 3 // io.vertx.core.Promise promise
         0: .line 360
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.vertx:Lio/vertx/core/impl/VertxInternal;
            invokeinterface io.vertx.core.impl.VertxInternal.getOrCreateContext:()Lio/vertx/core/impl/ContextInternal;
            invokestatic io.vertx.spi.cluster.hazelcast.impl.SubsOpSerializer.get:(Lio/vertx/core/impl/ContextInternal;)Lio/vertx/spi/cluster/hazelcast/impl/SubsOpSerializer;
            astore 4 /* serializer */
        start local 4 // io.vertx.spi.cluster.hazelcast.impl.SubsOpSerializer serializer
         1: .line 361
            aload 4 /* serializer */
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.subsMapHelper:Lio/vertx/spi/cluster/hazelcast/impl/SubsMapHelper;
            dup
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            pop
            invokedynamic accept(Lio/vertx/spi/cluster/hazelcast/impl/SubsMapHelper;)Ljava/util/function/BiConsumer;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  (Ljava/lang/Object;Ljava/lang/Object;)V
                  io/vertx/spi/cluster/hazelcast/impl/SubsMapHelper.put(Ljava/lang/String;Lio/vertx/core/spi/cluster/RegistrationInfo;)V (5)
                  (Ljava/lang/String;Lio/vertx/core/spi/cluster/RegistrationInfo;)V
            aload 1 /* address */
            aload 2 /* registrationInfo */
            aload 3 /* promise */
            invokevirtual io.vertx.spi.cluster.hazelcast.impl.SubsOpSerializer.execute:(Ljava/util/function/BiConsumer;Ljava/lang/String;Lio/vertx/core/spi/cluster/RegistrationInfo;Lio/vertx/core/Promise;)V
         2: .line 362
            return
        end local 4 // io.vertx.spi.cluster.hazelcast.impl.SubsOpSerializer serializer
        end local 3 // io.vertx.core.Promise promise
        end local 2 // io.vertx.core.spi.cluster.RegistrationInfo registrationInfo
        end local 1 // java.lang.String address
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    3     0              this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0    3     1           address  Ljava/lang/String;
            0    3     2  registrationInfo  Lio/vertx/core/spi/cluster/RegistrationInfo;
            0    3     3           promise  Lio/vertx/core/Promise<Ljava/lang/Void;>;
            1    3     4        serializer  Lio/vertx/spi/cluster/hazelcast/impl/SubsOpSerializer;
    Signature: (Ljava/lang/String;Lio/vertx/core/spi/cluster/RegistrationInfo;Lio/vertx/core/Promise<Ljava/lang/Void;>;)V
    MethodParameters:
                  Name  Flags
      address           
      registrationInfo  
      promise           

  public void removeRegistration(java.lang.String, io.vertx.core.spi.cluster.RegistrationInfo, io.vertx.core.Promise<java.lang.Void>);
    descriptor: (Ljava/lang/String;Lio/vertx/core/spi/cluster/RegistrationInfo;Lio/vertx/core/Promise;)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 address
        start local 2 // io.vertx.core.spi.cluster.RegistrationInfo registrationInfo
        start local 3 // io.vertx.core.Promise promise
         0: .line 366
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.vertx:Lio/vertx/core/impl/VertxInternal;
            invokeinterface io.vertx.core.impl.VertxInternal.getOrCreateContext:()Lio/vertx/core/impl/ContextInternal;
            invokestatic io.vertx.spi.cluster.hazelcast.impl.SubsOpSerializer.get:(Lio/vertx/core/impl/ContextInternal;)Lio/vertx/spi/cluster/hazelcast/impl/SubsOpSerializer;
            astore 4 /* serializer */
        start local 4 // io.vertx.spi.cluster.hazelcast.impl.SubsOpSerializer serializer
         1: .line 367
            aload 4 /* serializer */
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.subsMapHelper:Lio/vertx/spi/cluster/hazelcast/impl/SubsMapHelper;
            dup
            invokevirtual java.lang.Object.getClass:()Ljava/lang/Class;
            pop
            invokedynamic accept(Lio/vertx/spi/cluster/hazelcast/impl/SubsMapHelper;)Ljava/util/function/BiConsumer;
              Bootstrap: invokestatic java.lang.invoke.LambdaMetafactory.metafactory:(Ljava/lang/invoke/MethodHandles$Lookup;Ljava/lang/String;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodType;Ljava/lang/invoke/MethodHandle;Ljava/lang/invoke/MethodType;)Ljava/lang/invoke/CallSite;
                Method arguments:
                  (Ljava/lang/Object;Ljava/lang/Object;)V
                  io/vertx/spi/cluster/hazelcast/impl/SubsMapHelper.remove(Ljava/lang/String;Lio/vertx/core/spi/cluster/RegistrationInfo;)V (5)
                  (Ljava/lang/String;Lio/vertx/core/spi/cluster/RegistrationInfo;)V
            aload 1 /* address */
            aload 2 /* registrationInfo */
            aload 3 /* promise */
            invokevirtual io.vertx.spi.cluster.hazelcast.impl.SubsOpSerializer.execute:(Ljava/util/function/BiConsumer;Ljava/lang/String;Lio/vertx/core/spi/cluster/RegistrationInfo;Lio/vertx/core/Promise;)V
         2: .line 368
            return
        end local 4 // io.vertx.spi.cluster.hazelcast.impl.SubsOpSerializer serializer
        end local 3 // io.vertx.core.Promise promise
        end local 2 // io.vertx.core.spi.cluster.RegistrationInfo registrationInfo
        end local 1 // java.lang.String address
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot              Name  Signature
            0    3     0              this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0    3     1           address  Ljava/lang/String;
            0    3     2  registrationInfo  Lio/vertx/core/spi/cluster/RegistrationInfo;
            0    3     3           promise  Lio/vertx/core/Promise<Ljava/lang/Void;>;
            1    3     4        serializer  Lio/vertx/spi/cluster/hazelcast/impl/SubsOpSerializer;
    Signature: (Ljava/lang/String;Lio/vertx/core/spi/cluster/RegistrationInfo;Lio/vertx/core/Promise<Ljava/lang/Void;>;)V
    MethodParameters:
                  Name  Flags
      address           
      registrationInfo  
      promise           

  public void getRegistrations(java.lang.String, io.vertx.core.Promise<java.util.List<io.vertx.core.spi.cluster.RegistrationInfo>>);
    descriptor: (Ljava/lang/String;Lio/vertx/core/Promise;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=3, args_size=3
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // java.lang.String address
        start local 2 // io.vertx.core.Promise promise
         0: .line 372
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.vertx:Lio/vertx/core/impl/VertxInternal;
            aload 0 /* this */
            aload 1 /* address */
            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$11(Ljava/lang/String;Lio/vertx/core/Promise;)V (7)
                  (Lio/vertx/core/Promise;)V
         1: .line 374
            iconst_0
            aload 2 /* promise */
         2: .line 372
            invokeinterface io.vertx.core.impl.VertxInternal.executeBlocking:(Lio/vertx/core/Handler;ZLio/vertx/core/Handler;)V
         3: .line 375
            return
        end local 2 // io.vertx.core.Promise promise
        end local 1 // java.lang.String address
        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  address  Ljava/lang/String;
            0    4     2  promise  Lio/vertx/core/Promise<Ljava/util/List<Lio/vertx/core/spi/cluster/RegistrationInfo;>;>;
    Signature: (Ljava/lang/String;Lio/vertx/core/Promise<Ljava/util/List<Lio/vertx/core/spi/cluster/RegistrationInfo;>;>;)V
    MethodParameters:
         Name  Flags
      address  
      promise  

  public java.lang.String clusterHost();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
         0: .line 380
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.customHazelcastCluster:Z
            ifne 3
            ldc "hazelcast.local.localAddress"
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            dup
            astore 1 /* host */
        start local 1 // java.lang.String host
         1: ifnull 3
         2: .line 381
            aload 1 /* host */
            areturn
        end local 1 // java.lang.String host
         3: .line 383
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.customHazelcastCluster:Z
            ifne 5
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.conf:Lcom/hazelcast/config/Config;
            invokevirtual com.hazelcast.config.Config.getNetworkConfig:()Lcom/hazelcast/config/NetworkConfig;
            invokevirtual com.hazelcast.config.NetworkConfig.getPublicAddress:()Ljava/lang/String;
            ifnonnull 5
         4: .line 384
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.hazelcast:Lcom/hazelcast/core/HazelcastInstance;
            invokeinterface com.hazelcast.core.HazelcastInstance.getCluster:()Lcom/hazelcast/cluster/Cluster;
            invokeinterface com.hazelcast.cluster.Cluster.getLocalMember:()Lcom/hazelcast/cluster/Member;
            invokeinterface com.hazelcast.cluster.Member.getAddress:()Lcom/hazelcast/cluster/Address;
            invokevirtual com.hazelcast.cluster.Address.getHost:()Ljava/lang/String;
            areturn
         5: .line 386
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        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;
            1    3     1  host  Ljava/lang/String;

  public java.lang.String clusterPublicHost();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=1
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
         0: .line 392
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.customHazelcastCluster:Z
            ifne 3
            ldc "hazelcast.local.publicAddress"
            invokestatic java.lang.System.getProperty:(Ljava/lang/String;)Ljava/lang/String;
            dup
            astore 1 /* host */
        start local 1 // java.lang.String host
         1: ifnull 3
         2: .line 393
            aload 1 /* host */
            areturn
        end local 1 // java.lang.String host
         3: .line 395
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.customHazelcastCluster:Z
            ifne 6
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.conf:Lcom/hazelcast/config/Config;
            invokevirtual com.hazelcast.config.Config.getNetworkConfig:()Lcom/hazelcast/config/NetworkConfig;
            invokevirtual com.hazelcast.config.NetworkConfig.getPublicAddress:()Ljava/lang/String;
            dup
            astore 1 /* host */
        start local 1 // java.lang.String host
         4: ifnull 6
         5: .line 396
            aload 1 /* host */
            areturn
        end local 1 // java.lang.String host
         6: .line 398
      StackMap locals:
      StackMap stack:
            aconst_null
            areturn
        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;
            1    3     1  host  Ljava/lang/String;
            4    6     1  host  Ljava/lang/String;

  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 407
            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 416
            aload 0 /* this */
            aload 1 /* config */
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.conf:Lcom/hazelcast/config/Config;
         1: .line 417
            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 438
            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 442
            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=6, locals=3, args_size=2
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // io.vertx.core.Promise prom
         0: .line 112
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.active:Z
            ifne 18
         1: .line 113
            aload 0 /* this */
            iconst_1
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.active:Z
         2: .line 115
            aload 0 /* this */
            invokedynamic newThread()Ljava/util/concurrent/ThreadFactory;
              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/Runnable;)Ljava/lang/Thread;
                  io/vertx/spi/cluster/hazelcast/HazelcastClusterManager.lambda$1(Ljava/lang/Runnable;)Ljava/lang/Thread; (6)
                  (Ljava/lang/Runnable;)Ljava/lang/Thread;
            invokestatic java.util.concurrent.Executors.newCachedThreadPool:(Ljava/util/concurrent/ThreadFactory;)Ljava/util/concurrent/ExecutorService;
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.lockReleaseExec:Ljava/util/concurrent/ExecutorService;
         3: .line 118
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.customHazelcastCluster:Z
            ifne 11
         4: .line 119
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.conf:Lcom/hazelcast/config/Config;
            ifnonnull 9
         5: .line 120
            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;
         6: .line 121
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.conf:Lcom/hazelcast/config/Config;
            ifnonnull 9
         7: .line 122
            getstatic io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.log:Lio/vertx/core/impl/logging/Logger;
            ldc "Cannot find cluster configuration on 'vertx.hazelcast.config' system property, on the classpath, or specified programmatically. Using default hazelcast configuration"
            invokeinterface io.vertx.core.impl.logging.Logger.warn:(Ljava/lang/Object;)V
         8: .line 124
            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;
         9: .line 129
      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
        10: .line 131
            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;
        11: .line 134
      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/cluster/Cluster;
            invokeinterface com.hazelcast.cluster.Cluster.getLocalMember:()Lcom/hazelcast/cluster/Member;
            astore 2 /* localMember */
        start local 2 // com.hazelcast.cluster.Member localMember
        12: .line 135
            aload 0 /* this */
            aload 2 /* localMember */
            invokeinterface com.hazelcast.cluster.Member.getUuid:()Ljava/util/UUID;
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeId:Ljava/util/UUID;
        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/cluster/Cluster;
            aload 0 /* this */
            invokeinterface com.hazelcast.cluster.Cluster.addMembershipListener:(Lcom/hazelcast/cluster/MembershipListener;)Ljava/util/UUID;
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.membershipListenerId:Ljava/util/UUID;
        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/util/UUID;
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.lifecycleListenerId:Ljava/util/UUID;
        15: .line 139
            aload 0 /* this */
            new io.vertx.spi.cluster.hazelcast.impl.SubsMapHelper
            dup
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.vertx:Lio/vertx/core/impl/VertxInternal;
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.hazelcast:Lcom/hazelcast/core/HazelcastInstance;
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeSelector:Lio/vertx/core/spi/cluster/NodeSelector;
            invokespecial io.vertx.spi.cluster.hazelcast.impl.SubsMapHelper.<init>:(Lio/vertx/core/impl/VertxInternal;Lcom/hazelcast/core/HazelcastInstance;Lio/vertx/core/spi/cluster/NodeSelector;)V
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.subsMapHelper:Lio/vertx/spi/cluster/hazelcast/impl/SubsMapHelper;
        16: .line 140
            aload 0 /* this */
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.hazelcast:Lcom/hazelcast/core/HazelcastInstance;
            ldc "__vertx.nodeInfo"
            invokeinterface com.hazelcast.core.HazelcastInstance.getMap:(Ljava/lang/String;)Lcom/hazelcast/map/IMap;
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeInfoMap:Lcom/hazelcast/map/IMap;
        17: .line 142
            aload 1 /* prom */
            invokeinterface io.vertx.core.Promise.complete:()V
        end local 2 // com.hazelcast.cluster.Member localMember
        18: .line 144
      StackMap locals:
      StackMap stack:
            return
        end local 1 // io.vertx.core.Promise prom
        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         prom  Lio/vertx/core/Promise<Ljava/lang/Void;>;
           12   18     2  localMember  Lcom/hazelcast/cluster/Member;

  private void lambda$2(io.vertx.spi.cluster.hazelcast.impl.HazelcastNodeInfo, io.vertx.core.Promise);
    descriptor: (Lio/vertx/spi/cluster/hazelcast/impl/HazelcastNodeInfo;Lio/vertx/core/Promise;)V
    flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 2 // io.vertx.core.Promise prom
         0: .line 173
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeInfoMap:Lcom/hazelcast/map/IMap;
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeId:Ljava/util/UUID;
            invokevirtual java.util.UUID.toString:()Ljava/lang/String;
            aload 1
            invokeinterface com.hazelcast.map.IMap.put:(Ljava/lang/Object;Ljava/lang/Object;)Ljava/lang/Object;
            pop
         1: .line 174
            aload 2 /* prom */
            invokeinterface io.vertx.core.Promise.complete:()V
         2: .line 175
            return
        end local 2 // io.vertx.core.Promise prom
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0    3     2  prom  Lio/vertx/core/Promise<Ljava/lang/Void;>;

  private void lambda$3(java.lang.String, io.vertx.core.Promise, io.vertx.core.Promise);
    descriptor: (Ljava/lang/String;Lio/vertx/core/Promise;Lio/vertx/core/Promise;)V
    flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
    Code:
      stack=2, locals=5, args_size=4
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 3 // io.vertx.core.Promise prom
         0: .line 186
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.nodeInfoMap:Lcom/hazelcast/map/IMap;
            aload 1
            invokeinterface com.hazelcast.map.IMap.get:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast io.vertx.spi.cluster.hazelcast.impl.HazelcastNodeInfo
            astore 4 /* value */
        start local 4 // io.vertx.spi.cluster.hazelcast.impl.HazelcastNodeInfo value
         1: .line 187
            aload 4 /* value */
            ifnull 4
         2: .line 188
            aload 3 /* prom */
            aload 4 /* value */
            invokevirtual io.vertx.spi.cluster.hazelcast.impl.HazelcastNodeInfo.unwrap:()Lio/vertx/core/spi/cluster/NodeInfo;
            invokeinterface io.vertx.core.Promise.complete:(Ljava/lang/Object;)V
         3: .line 189
            goto 5
         4: .line 190
      StackMap locals: io.vertx.spi.cluster.hazelcast.impl.HazelcastNodeInfo
      StackMap stack:
            aload 2
            ldc "Not a member of the cluster"
            invokeinterface io.vertx.core.Promise.fail:(Ljava/lang/String;)V
        end local 4 // io.vertx.spi.cluster.hazelcast.impl.HazelcastNodeInfo value
         5: .line 192
      StackMap locals:
      StackMap stack:
            return
        end local 3 // io.vertx.core.Promise prom
        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     3   prom  Lio/vertx/core/Promise<Lio/vertx/core/spi/cluster/NodeInfo;>;
            1    5     4  value  Lio/vertx/spi/cluster/hazelcast/impl/HazelcastNodeInfo;

  private void lambda$4(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 prom
         0: .line 208
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.hazelcast:Lcom/hazelcast/core/HazelcastInstance;
            invokeinterface com.hazelcast.core.HazelcastInstance.getCPSubsystem:()Lcom/hazelcast/cp/CPSubsystem;
            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.cp.CPSubsystem.getSemaphore:(Ljava/lang/String;)Lcom/hazelcast/cp/ISemaphore;
            astore 5 /* iSemaphore */
        start local 5 // com.hazelcast.cp.ISemaphore iSemaphore
         1: .line 209
            iconst_0
            istore 6 /* locked */
        start local 6 // boolean locked
         2: .line 210
            lload 2
            lstore 7 /* remaining */
        start local 7 // long remaining
         3: .line 212
      StackMap locals: com.hazelcast.cp.ISemaphore int long
      StackMap stack:
            invokestatic java.lang.System.nanoTime:()J
            lstore 9 /* start */
        start local 9 // long start
         4: .line 214
            aload 5 /* iSemaphore */
            lload 7 /* remaining */
            getstatic java.util.concurrent.TimeUnit.MILLISECONDS:Ljava/util/concurrent/TimeUnit;
            invokeinterface com.hazelcast.cp.ISemaphore.tryAcquire:(JLjava/util/concurrent/TimeUnit;)Z
            istore 6 /* locked */
         5: .line 215
            goto 7
      StackMap locals: io.vertx.spi.cluster.hazelcast.HazelcastClusterManager java.lang.String long io.vertx.core.Promise com.hazelcast.cp.ISemaphore int long long
      StackMap stack: java.lang.InterruptedException
         6: pop
         7: .line 218
      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 219
            iload 6 /* locked */
            ifne 10
            lload 7 /* remaining */
            lconst_0
         9: .line 211
            lcmp
            ifgt 3
        10: .line 220
      StackMap locals:
      StackMap stack:
            iload 6 /* locked */
            ifeq 13
        11: .line 221
            aload 4 /* prom */
            new io.vertx.spi.cluster.hazelcast.impl.HazelcastLock
            dup
            aload 5 /* iSemaphore */
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.lockReleaseExec:Ljava/util/concurrent/ExecutorService;
            invokespecial io.vertx.spi.cluster.hazelcast.impl.HazelcastLock.<init>:(Lcom/hazelcast/cp/ISemaphore;Ljava/util/concurrent/Executor;)V
            invokeinterface io.vertx.core.Promise.complete:(Ljava/lang/Object;)V
        12: .line 222
            goto 14
        13: .line 223
      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.cp.ISemaphore iSemaphore
        14: .line 225
      StackMap locals:
      StackMap stack:
            return
        end local 4 // io.vertx.core.Promise prom
        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        prom  Lio/vertx/core/Promise<Lio/vertx/core/shareddata/Lock;>;
            1   14     5  iSemaphore  Lcom/hazelcast/cp/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$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 prom
         0: .line 238
            aload 0 /* this */
            dup
            astore 2
            monitorenter
         1: .line 239
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.active:Z
            ifeq 22
         2: .line 241
            aload 0 /* this */
            iconst_0
            putfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.active:Z
         3: .line 242
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.lockReleaseExec:Ljava/util/concurrent/ExecutorService;
            invokeinterface java.util.concurrent.ExecutorService.shutdown:()V
         4: .line 243
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.subsMapHelper:Lio/vertx/spi/cluster/hazelcast/impl/SubsMapHelper;
            invokevirtual io.vertx.spi.cluster.hazelcast.impl.SubsMapHelper.close:()V
         5: .line 244
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.hazelcast:Lcom/hazelcast/core/HazelcastInstance;
            invokeinterface com.hazelcast.core.HazelcastInstance.getCluster:()Lcom/hazelcast/cluster/Cluster;
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.membershipListenerId:Ljava/util/UUID;
            invokeinterface com.hazelcast.cluster.Cluster.removeMembershipListener:(Ljava/util/UUID;)Z
            istore 3 /* left */
        start local 3 // boolean left
         6: .line 245
            iload 3 /* left */
            ifne 8
         7: .line 246
            getstatic io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.log:Lio/vertx/core/impl/logging/Logger;
            ldc "No membership listener"
            invokeinterface io.vertx.core.impl.logging.Logger.warn:(Ljava/lang/Object;)V
         8: .line 248
      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/util/UUID;
            invokeinterface com.hazelcast.core.LifecycleService.removeLifecycleListener:(Ljava/util/UUID;)Z
            pop
         9: .line 251
            goto 18
        10: .line 254
      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
        11: .line 255
            goto 14
      StackMap locals:
      StackMap stack: java.util.concurrent.RejectedExecutionException
        12: pop
        13: .line 256
            getstatic io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.log:Lio/vertx/core/impl/logging/Logger;
            ldc "Rejected execution of the shutdown operation, retrying"
            invokeinterface io.vertx.core.impl.logging.Logger.debug:(Ljava/lang/Object;)V
        14: .line 259
      StackMap locals:
      StackMap stack:
            lconst_1
            invokestatic java.lang.Thread.sleep:(J)V
        15: .line 260
            goto 18
      StackMap locals:
      StackMap stack: java.lang.InterruptedException
        16: pop
        17: .line 262
            invokestatic java.lang.Thread.currentThread:()Ljava/lang/Thread;
            invokevirtual java.lang.Thread.interrupt:()V
        18: .line 251
      StackMap locals:
      StackMap stack:
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.customHazelcastCluster:Z
            ifne 22
            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 10
        end local 3 // boolean left
        19: .line 266
            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 267
            aload 1 /* prom */
            aload 3 /* t */
            invokeinterface io.vertx.core.Promise.fail:(Ljava/lang/Throwable;)V
        end local 3 // java.lang.Throwable t
        22: .line 238
      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 271
      StackMap locals:
      StackMap stack:
            aload 1 /* prom */
            invokeinterface io.vertx.core.Promise.complete:()V
        27: .line 272
            return
        end local 1 // io.vertx.core.Promise prom
        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  prom  Lio/vertx/core/Promise<Ljava/lang/Void;>;
            6   19     3  left  Z
           21   22     3     t  Ljava/lang/Throwable;
      Exception table:
        from    to  target  type
          10    11      12  Class java.util.concurrent.RejectedExecutionException
          14    15      16  Class java.lang.InterruptedException
           2    19      20  Class java.lang.Throwable
           1    23      24  any
          24    25      24  any

  private void lambda$8(io.vertx.core.Promise);
    descriptor: (Lio/vertx/core/Promise;)V
    flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
    Code:
      stack=1, locals=2, args_size=2
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 1 // io.vertx.core.Promise prom
         0: .line 328
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.subsMapHelper:Lio/vertx/spi/cluster/hazelcast/impl/SubsMapHelper;
            invokevirtual io.vertx.spi.cluster.hazelcast.impl.SubsMapHelper.republishOwnSubs:()V
         1: .line 329
            aload 1 /* prom */
            invokeinterface io.vertx.core.Promise.complete:()V
         2: .line 330
            return
        end local 1 // io.vertx.core.Promise prom
        end local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    3     0  this  Lio/vertx/spi/cluster/hazelcast/HazelcastClusterManager;
            0    3     1  prom  Lio/vertx/core/Promise<Ljava/lang/Object;>;

  private void lambda$11(java.lang.String, io.vertx.core.Promise);
    descriptor: (Ljava/lang/String;Lio/vertx/core/Promise;)V
    flags: (0x1002) ACC_PRIVATE, ACC_SYNTHETIC
    Code:
      stack=3, locals=3, args_size=3
        start local 0 // io.vertx.spi.cluster.hazelcast.HazelcastClusterManager this
        start local 2 // io.vertx.core.Promise prom
         0: .line 373
            aload 2 /* prom */
            aload 0 /* this */
            getfield io.vertx.spi.cluster.hazelcast.HazelcastClusterManager.subsMapHelper:Lio/vertx/spi/cluster/hazelcast/impl/SubsMapHelper;
            aload 1
            invokevirtual io.vertx.spi.cluster.hazelcast.impl.SubsMapHelper.get:(Ljava/lang/String;)Ljava/util/List;
            invokeinterface io.vertx.core.Promise.complete:(Ljava/lang/Object;)V
         1: .line 374
            return
        end local 2 // io.vertx.core.Promise prom
        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     2  prom  Lio/vertx/core/Promise<Ljava/util/List<Lio/vertx/core/spi/cluster/RegistrationInfo;>;>;

  private static java.lang.Thread lambda$1(java.lang.Runnable);
    descriptor: (Ljava/lang/Runnable;)Ljava/lang/Thread;
    flags: (0x100a) ACC_PRIVATE, ACC_STATIC, ACC_SYNTHETIC
    Code:
      stack=4, locals=1, args_size=1
        start local 0 // java.lang.Runnable r
         0: .line 115
            new java.lang.Thread
            dup
            aload 0 /* r */
            ldc "vertx-hazelcast-service-release-lock-thread"
            invokespecial java.lang.Thread.<init>:(Ljava/lang/Runnable;Ljava/lang/String;)V
            areturn
        end local 0 // java.lang.Runnable r
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0     r  Ljava/lang/Runnable;
}
SourceFile: "HazelcastClusterManager.java"
InnerClasses:
  public final LifecycleState = com.hazelcast.core.LifecycleEvent$LifecycleState of com.hazelcast.core.LifecycleEvent
  public final Lookup = java.lang.invoke.MethodHandles$Lookup of java.lang.invoke.MethodHandles