public final class com.mongodb.internal.connection.MultiServerCluster extends com.mongodb.internal.connection.AbstractMultiServerCluster
  minor version: 0
  major version: 59
  flags: flags: (0x0031) ACC_PUBLIC, ACC_FINAL, ACC_SUPER
  this_class: com.mongodb.internal.connection.MultiServerCluster
  super_class: com.mongodb.internal.connection.AbstractMultiServerCluster
{
  public void <init>(com.mongodb.connection.ClusterId, com.mongodb.connection.ClusterSettings, com.mongodb.internal.connection.ClusterableServerFactory);
    descriptor: (Lcom/mongodb/connection/ClusterId;Lcom/mongodb/connection/ClusterSettings;Lcom/mongodb/internal/connection/ClusterableServerFactory;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=4, locals=4, args_size=4
        start local 0 // com.mongodb.internal.connection.MultiServerCluster this
        start local 1 // com.mongodb.connection.ClusterId clusterId
        start local 2 // com.mongodb.connection.ClusterSettings settings
        start local 3 // com.mongodb.internal.connection.ClusterableServerFactory serverFactory
         0: .line 27
            aload 0 /* this */
            aload 1 /* clusterId */
            aload 2 /* settings */
            aload 3 /* serverFactory */
            invokespecial com.mongodb.internal.connection.AbstractMultiServerCluster.<init>:(Lcom/mongodb/connection/ClusterId;Lcom/mongodb/connection/ClusterSettings;Lcom/mongodb/internal/connection/ClusterableServerFactory;)V
         1: .line 28
            ldc "srvHost is null"
            aload 2 /* settings */
            invokevirtual com.mongodb.connection.ClusterSettings.getSrvHost:()Ljava/lang/String;
            ifnonnull 2
            iconst_1
            goto 3
      StackMap locals: com.mongodb.internal.connection.MultiServerCluster com.mongodb.connection.ClusterId com.mongodb.connection.ClusterSettings com.mongodb.internal.connection.ClusterableServerFactory
      StackMap stack: java.lang.String
         2: iconst_0
      StackMap locals: com.mongodb.internal.connection.MultiServerCluster com.mongodb.connection.ClusterId com.mongodb.connection.ClusterSettings com.mongodb.internal.connection.ClusterableServerFactory
      StackMap stack: java.lang.String int
         3: invokestatic com.mongodb.assertions.Assertions.isTrue:(Ljava/lang/String;Z)V
         4: .line 29
            aload 0 /* this */
            aload 2 /* settings */
            invokevirtual com.mongodb.connection.ClusterSettings.getHosts:()Ljava/util/List;
            invokevirtual com.mongodb.internal.connection.MultiServerCluster.initialize:(Ljava/util/Collection;)V
         5: .line 30
            return
        end local 3 // com.mongodb.internal.connection.ClusterableServerFactory serverFactory
        end local 2 // com.mongodb.connection.ClusterSettings settings
        end local 1 // com.mongodb.connection.ClusterId clusterId
        end local 0 // com.mongodb.internal.connection.MultiServerCluster this
      LocalVariableTable:
        Start  End  Slot           Name  Signature
            0    6     0           this  Lcom/mongodb/internal/connection/MultiServerCluster;
            0    6     1      clusterId  Lcom/mongodb/connection/ClusterId;
            0    6     2       settings  Lcom/mongodb/connection/ClusterSettings;
            0    6     3  serverFactory  Lcom/mongodb/internal/connection/ClusterableServerFactory;
    MethodParameters:
               Name  Flags
      clusterId      final
      settings       final
      serverFactory  final

  public void selectServerAsync(com.mongodb.selector.ServerSelector, com.mongodb.async.SingleResultCallback);
    descriptor: (Lcom/mongodb/selector/ServerSelector;Lcom/mongodb/async/SingleResultCallback;)V
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=3, locals=3, args_size=3
         0: .line 1
            aload 0
            aload 1
            aload 2
            invokespecial com.mongodb.internal.connection.AbstractMultiServerCluster.selectServerAsync:(Lcom/mongodb/selector/ServerSelector;Lcom/mongodb/async/SingleResultCallback;)V
            return
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public boolean isClosed();
    descriptor: ()Z
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokespecial com.mongodb.internal.connection.AbstractMultiServerCluster.isClosed:()Z
            ireturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public com.mongodb.connection.Server selectServer(com.mongodb.selector.ServerSelector);
    descriptor: (Lcom/mongodb/selector/ServerSelector;)Lcom/mongodb/connection/Server;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=2, locals=2, args_size=2
         0: .line 1
            aload 0
            aload 1
            invokespecial com.mongodb.internal.connection.AbstractMultiServerCluster.selectServer:(Lcom/mongodb/selector/ServerSelector;)Lcom/mongodb/connection/Server;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public com.mongodb.connection.ClusterSettings getSettings();
    descriptor: ()Lcom/mongodb/connection/ClusterSettings;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokespecial com.mongodb.internal.connection.AbstractMultiServerCluster.getSettings:()Lcom/mongodb/connection/ClusterSettings;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public org.bson.BsonTimestamp getClusterTime();
    descriptor: ()Lorg/bson/BsonTimestamp;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokespecial com.mongodb.internal.connection.AbstractMultiServerCluster.getClusterTime:()Lorg/bson/BsonTimestamp;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public com.mongodb.connection.ClusterDescription getCurrentDescription();
    descriptor: ()Lcom/mongodb/connection/ClusterDescription;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokespecial com.mongodb.internal.connection.AbstractMultiServerCluster.getCurrentDescription:()Lcom/mongodb/connection/ClusterDescription;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public com.mongodb.connection.ClusterDescription getDescription();
    descriptor: ()Lcom/mongodb/connection/ClusterDescription;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokespecial com.mongodb.internal.connection.AbstractMultiServerCluster.getDescription:()Lcom/mongodb/connection/ClusterDescription;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature

  public com.mongodb.internal.connection.ClusterableServerFactory getServerFactory();
    descriptor: ()Lcom/mongodb/internal/connection/ClusterableServerFactory;
    flags: (0x1041) ACC_PUBLIC, ACC_BRIDGE, ACC_SYNTHETIC
    Code:
      stack=1, locals=1, args_size=1
         0: .line 1
            aload 0
            invokespecial com.mongodb.internal.connection.AbstractMultiServerCluster.getServerFactory:()Lcom/mongodb/internal/connection/ClusterableServerFactory;
            areturn
      LocalVariableTable:
        Start  End  Slot  Name  Signature
}
SourceFile: "MultiServerCluster.java"