public class io.dropwizard.logging.FileAppenderFactory<E extends ch.qos.logback.core.spi.DeferredProcessingAware> extends io.dropwizard.logging.AbstractOutputStreamAppenderFactory<E>
  minor version: 0
  major version: 59
  flags: flags: (0x0021) ACC_PUBLIC, ACC_SUPER
  this_class: io.dropwizard.logging.FileAppenderFactory
  super_class: io.dropwizard.logging.AbstractOutputStreamAppenderFactory
{
  private java.lang.String currentLogFilename;
    descriptor: Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE
    RuntimeVisibleAnnotations: 
      javax.annotation.Nullable()

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

  private java.lang.String archivedLogFilenamePattern;
    descriptor: Ljava/lang/String;
    flags: (0x0002) ACC_PRIVATE
    RuntimeVisibleAnnotations: 
      javax.annotation.Nullable()

  private int archivedFileCount;
    descriptor: I
    flags: (0x0002) ACC_PRIVATE
    RuntimeVisibleAnnotations: 
      javax.validation.constraints.Min(value = 0)

  private io.dropwizard.util.Size maxFileSize;
    descriptor: Lio/dropwizard/util/Size;
    flags: (0x0002) ACC_PRIVATE
    RuntimeVisibleAnnotations: 
      javax.annotation.Nullable()

  private io.dropwizard.util.Size bufferSize;
    descriptor: Lio/dropwizard/util/Size;
    flags: (0x0002) ACC_PRIVATE
    RuntimeVisibleAnnotations: 
      io.dropwizard.validation.MinSize(value = 1)
    RuntimeVisibleTypeAnnotations: 
      FIELD
        io.dropwizard.validation.MinSize(value = 1)

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

  public void <init>();
    descriptor: ()V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=3, locals=1, args_size=1
        start local 0 // io.dropwizard.logging.FileAppenderFactory this
         0: .line 128
            aload 0 /* this */
            invokespecial io.dropwizard.logging.AbstractOutputStreamAppenderFactory.<init>:()V
         1: .line 133
            aload 0 /* this */
            iconst_1
            putfield io.dropwizard.logging.FileAppenderFactory.archive:Z
         2: .line 139
            aload 0 /* this */
            iconst_5
            putfield io.dropwizard.logging.FileAppenderFactory.archivedFileCount:I
         3: .line 145
            aload 0 /* this */
            ldc 8192
            invokestatic io.dropwizard.util.Size.bytes:(J)Lio/dropwizard/util/Size;
            putfield io.dropwizard.logging.FileAppenderFactory.bufferSize:Lio/dropwizard/util/Size;
         4: .line 147
            aload 0 /* this */
            iconst_1
            putfield io.dropwizard.logging.FileAppenderFactory.immediateFlush:Z
         5: .line 128
            return
        end local 0 // io.dropwizard.logging.FileAppenderFactory this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    6     0  this  Lio/dropwizard/logging/FileAppenderFactory<TE;>;

  public java.lang.String getCurrentLogFilename();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.dropwizard.logging.FileAppenderFactory this
         0: .line 152
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.currentLogFilename:Ljava/lang/String;
            areturn
        end local 0 // io.dropwizard.logging.FileAppenderFactory this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/dropwizard/logging/FileAppenderFactory<TE;>;
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonProperty()
      javax.annotation.Nullable()
    RuntimeVisibleTypeAnnotations: 
      METHOD_RETURN
        javax.annotation.Nullable()

  public void setCurrentLogFilename(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.dropwizard.logging.FileAppenderFactory this
        start local 1 // java.lang.String currentLogFilename
         0: .line 157
            aload 0 /* this */
            aload 1 /* currentLogFilename */
            putfield io.dropwizard.logging.FileAppenderFactory.currentLogFilename:Ljava/lang/String;
         1: .line 158
            return
        end local 1 // java.lang.String currentLogFilename
        end local 0 // io.dropwizard.logging.FileAppenderFactory this
      LocalVariableTable:
        Start  End  Slot                Name  Signature
            0    2     0                this  Lio/dropwizard/logging/FileAppenderFactory<TE;>;
            0    2     1  currentLogFilename  Ljava/lang/String;
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonProperty()
    RuntimeVisibleTypeAnnotations: 
      METHOD_FORMAL_PARAMETER
        javax.annotation.Nullable()
    RuntimeVisibleParameterAnnotations: 
      0:
        javax.annotation.Nullable()
    MethodParameters:
                    Name  Flags
      currentLogFilename  

  public boolean isArchive();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.dropwizard.logging.FileAppenderFactory this
         0: .line 162
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.archive:Z
            ireturn
        end local 0 // io.dropwizard.logging.FileAppenderFactory this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/dropwizard/logging/FileAppenderFactory<TE;>;
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonProperty()

  public void setArchive(boolean);
    descriptor: (Z)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.dropwizard.logging.FileAppenderFactory this
        start local 1 // boolean archive
         0: .line 167
            aload 0 /* this */
            iload 1 /* archive */
            putfield io.dropwizard.logging.FileAppenderFactory.archive:Z
         1: .line 168
            return
        end local 1 // boolean archive
        end local 0 // io.dropwizard.logging.FileAppenderFactory this
      LocalVariableTable:
        Start  End  Slot     Name  Signature
            0    2     0     this  Lio/dropwizard/logging/FileAppenderFactory<TE;>;
            0    2     1  archive  Z
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonProperty()
    MethodParameters:
         Name  Flags
      archive  

  public java.lang.String getArchivedLogFilenamePattern();
    descriptor: ()Ljava/lang/String;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.dropwizard.logging.FileAppenderFactory this
         0: .line 173
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.archivedLogFilenamePattern:Ljava/lang/String;
            areturn
        end local 0 // io.dropwizard.logging.FileAppenderFactory this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/dropwizard/logging/FileAppenderFactory<TE;>;
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonProperty()
      javax.annotation.Nullable()
    RuntimeVisibleTypeAnnotations: 
      METHOD_RETURN
        javax.annotation.Nullable()

  public void setArchivedLogFilenamePattern(java.lang.String);
    descriptor: (Ljava/lang/String;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.dropwizard.logging.FileAppenderFactory this
        start local 1 // java.lang.String archivedLogFilenamePattern
         0: .line 178
            aload 0 /* this */
            aload 1 /* archivedLogFilenamePattern */
            putfield io.dropwizard.logging.FileAppenderFactory.archivedLogFilenamePattern:Ljava/lang/String;
         1: .line 179
            return
        end local 1 // java.lang.String archivedLogFilenamePattern
        end local 0 // io.dropwizard.logging.FileAppenderFactory this
      LocalVariableTable:
        Start  End  Slot                        Name  Signature
            0    2     0                        this  Lio/dropwizard/logging/FileAppenderFactory<TE;>;
            0    2     1  archivedLogFilenamePattern  Ljava/lang/String;
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonProperty()
    MethodParameters:
                            Name  Flags
      archivedLogFilenamePattern  

  public int getArchivedFileCount();
    descriptor: ()I
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.dropwizard.logging.FileAppenderFactory this
         0: .line 183
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.archivedFileCount:I
            ireturn
        end local 0 // io.dropwizard.logging.FileAppenderFactory this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/dropwizard/logging/FileAppenderFactory<TE;>;
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonProperty()

  public void setArchivedFileCount(int);
    descriptor: (I)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.dropwizard.logging.FileAppenderFactory this
        start local 1 // int archivedFileCount
         0: .line 188
            aload 0 /* this */
            iload 1 /* archivedFileCount */
            putfield io.dropwizard.logging.FileAppenderFactory.archivedFileCount:I
         1: .line 189
            return
        end local 1 // int archivedFileCount
        end local 0 // io.dropwizard.logging.FileAppenderFactory this
      LocalVariableTable:
        Start  End  Slot               Name  Signature
            0    2     0               this  Lio/dropwizard/logging/FileAppenderFactory<TE;>;
            0    2     1  archivedFileCount  I
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonProperty()
    MethodParameters:
                   Name  Flags
      archivedFileCount  

  public io.dropwizard.util.Size getMaxFileSize();
    descriptor: ()Lio/dropwizard/util/Size;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.dropwizard.logging.FileAppenderFactory this
         0: .line 194
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.maxFileSize:Lio/dropwizard/util/Size;
            areturn
        end local 0 // io.dropwizard.logging.FileAppenderFactory this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/dropwizard/logging/FileAppenderFactory<TE;>;
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonProperty()
      javax.annotation.Nullable()
    RuntimeVisibleTypeAnnotations: 
      METHOD_RETURN
        javax.annotation.Nullable()

  public void setMaxFileSize(io.dropwizard.util.Size);
    descriptor: (Lio/dropwizard/util/Size;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.dropwizard.logging.FileAppenderFactory this
        start local 1 // io.dropwizard.util.Size maxFileSize
         0: .line 199
            aload 0 /* this */
            aload 1 /* maxFileSize */
            putfield io.dropwizard.logging.FileAppenderFactory.maxFileSize:Lio/dropwizard/util/Size;
         1: .line 200
            return
        end local 1 // io.dropwizard.util.Size maxFileSize
        end local 0 // io.dropwizard.logging.FileAppenderFactory this
      LocalVariableTable:
        Start  End  Slot         Name  Signature
            0    2     0         this  Lio/dropwizard/logging/FileAppenderFactory<TE;>;
            0    2     1  maxFileSize  Lio/dropwizard/util/Size;
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonProperty()
    MethodParameters:
             Name  Flags
      maxFileSize  

  public io.dropwizard.util.Size getBufferSize();
    descriptor: ()Lio/dropwizard/util/Size;
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.dropwizard.logging.FileAppenderFactory this
         0: .line 204
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.bufferSize:Lio/dropwizard/util/Size;
            areturn
        end local 0 // io.dropwizard.logging.FileAppenderFactory this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/dropwizard/logging/FileAppenderFactory<TE;>;
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonProperty()

  public void setBufferSize(io.dropwizard.util.Size);
    descriptor: (Lio/dropwizard/util/Size;)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.dropwizard.logging.FileAppenderFactory this
        start local 1 // io.dropwizard.util.Size bufferSize
         0: .line 209
            aload 0 /* this */
            aload 1 /* bufferSize */
            putfield io.dropwizard.logging.FileAppenderFactory.bufferSize:Lio/dropwizard/util/Size;
         1: .line 210
            return
        end local 1 // io.dropwizard.util.Size bufferSize
        end local 0 // io.dropwizard.logging.FileAppenderFactory this
      LocalVariableTable:
        Start  End  Slot        Name  Signature
            0    2     0        this  Lio/dropwizard/logging/FileAppenderFactory<TE;>;
            0    2     1  bufferSize  Lio/dropwizard/util/Size;
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonProperty()
    MethodParameters:
            Name  Flags
      bufferSize  

  public boolean isImmediateFlush();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.dropwizard.logging.FileAppenderFactory this
         0: .line 213
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.immediateFlush:Z
            ireturn
        end local 0 // io.dropwizard.logging.FileAppenderFactory this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    1     0  this  Lio/dropwizard/logging/FileAppenderFactory<TE;>;

  public void setImmediateFlush(boolean);
    descriptor: (Z)V
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=2, args_size=2
        start local 0 // io.dropwizard.logging.FileAppenderFactory this
        start local 1 // boolean immediateFlush
         0: .line 218
            aload 0 /* this */
            iload 1 /* immediateFlush */
            putfield io.dropwizard.logging.FileAppenderFactory.immediateFlush:Z
         1: .line 219
            return
        end local 1 // boolean immediateFlush
        end local 0 // io.dropwizard.logging.FileAppenderFactory this
      LocalVariableTable:
        Start  End  Slot            Name  Signature
            0    2     0            this  Lio/dropwizard/logging/FileAppenderFactory<TE;>;
            0    2     1  immediateFlush  Z
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonProperty()
    MethodParameters:
                Name  Flags
      immediateFlush  

  public boolean isValidArchiveConfiguration();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.dropwizard.logging.FileAppenderFactory this
         0: .line 224
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.archive:Z
            ifeq 1
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.archivedLogFilenamePattern:Ljava/lang/String;
            ifnonnull 1
            iconst_0
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_1
            ireturn
        end local 0 // io.dropwizard.logging.FileAppenderFactory this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lio/dropwizard/logging/FileAppenderFactory<TE;>;
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonIgnore()
      io.dropwizard.validation.ValidationMethod(message = "must have archivedLogFilenamePattern if archive is true")

  public boolean isValidForMaxFileSizeSetting();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // io.dropwizard.logging.FileAppenderFactory this
         0: .line 230
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.archive:Z
            ifeq 3
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.maxFileSize:Lio/dropwizard/util/Size;
            ifnull 3
         1: .line 231
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.archivedLogFilenamePattern:Ljava/lang/String;
            ifnull 2
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.archivedLogFilenamePattern:Ljava/lang/String;
            ldc "%i"
            invokevirtual java.lang.String.contains:(Ljava/lang/CharSequence;)Z
            ifne 3
         2: .line 230
      StackMap locals:
      StackMap stack:
            iconst_0
            ireturn
      StackMap locals:
      StackMap stack:
         3: iconst_1
            ireturn
        end local 0 // io.dropwizard.logging.FileAppenderFactory this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lio/dropwizard/logging/FileAppenderFactory<TE;>;
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonIgnore()
      io.dropwizard.validation.ValidationMethod(message = "when specifying maxFileSize, archivedLogFilenamePattern must contain %i")

  public boolean isMaxFileSizeSettingSpecified();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=2, locals=1, args_size=1
        start local 0 // io.dropwizard.logging.FileAppenderFactory this
         0: .line 237
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.archive:Z
            ifeq 3
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.archivedLogFilenamePattern:Ljava/lang/String;
            ifnull 3
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.archivedLogFilenamePattern:Ljava/lang/String;
            ldc "%i"
            invokevirtual java.lang.String.contains:(Ljava/lang/CharSequence;)Z
            ifeq 3
         1: .line 238
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.maxFileSize:Lio/dropwizard/util/Size;
            ifnonnull 3
         2: .line 237
            iconst_0
            ireturn
      StackMap locals:
      StackMap stack:
         3: iconst_1
            ireturn
        end local 0 // io.dropwizard.logging.FileAppenderFactory this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    4     0  this  Lio/dropwizard/logging/FileAppenderFactory<TE;>;
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonIgnore()
      io.dropwizard.validation.ValidationMethod(message = "when archivedLogFilenamePattern contains %i, maxFileSize must be specified")

  public boolean isValidFileConfiguration();
    descriptor: ()Z
    flags: (0x0001) ACC_PUBLIC
    Code:
      stack=1, locals=1, args_size=1
        start local 0 // io.dropwizard.logging.FileAppenderFactory this
         0: .line 244
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.archive:Z
            ifne 1
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.currentLogFilename:Ljava/lang/String;
            ifnonnull 1
            iconst_0
            ireturn
      StackMap locals:
      StackMap stack:
         1: iconst_1
            ireturn
        end local 0 // io.dropwizard.logging.FileAppenderFactory this
      LocalVariableTable:
        Start  End  Slot  Name  Signature
            0    2     0  this  Lio/dropwizard/logging/FileAppenderFactory<TE;>;
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonIgnore()
      io.dropwizard.validation.ValidationMethod(message = "currentLogFilename can only be null when archiving is enabled")

  protected ch.qos.logback.core.OutputStreamAppender<E> appender(ch.qos.logback.classic.LoggerContext);
    descriptor: (Lch/qos/logback/classic/LoggerContext;)Lch/qos/logback/core/OutputStreamAppender;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=2, locals=3, args_size=2
        start local 0 // io.dropwizard.logging.FileAppenderFactory this
        start local 1 // ch.qos.logback.classic.LoggerContext context
         0: .line 249
            aload 0 /* this */
            aload 1 /* context */
            invokevirtual io.dropwizard.logging.FileAppenderFactory.buildAppender:(Lch/qos/logback/classic/LoggerContext;)Lch/qos/logback/core/FileAppender;
            astore 2 /* appender */
        start local 2 // ch.qos.logback.core.FileAppender appender
         1: .line 250
            aload 2 /* appender */
            ldc "file-appender"
            invokevirtual ch.qos.logback.core.FileAppender.setName:(Ljava/lang/String;)V
         2: .line 251
            aload 2 /* appender */
            iconst_1
            invokevirtual ch.qos.logback.core.FileAppender.setAppend:(Z)V
         3: .line 252
            aload 2 /* appender */
            aload 1 /* context */
            invokevirtual ch.qos.logback.core.FileAppender.setContext:(Lch/qos/logback/core/Context;)V
         4: .line 253
            aload 2 /* appender */
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.immediateFlush:Z
            invokevirtual ch.qos.logback.core.FileAppender.setImmediateFlush:(Z)V
         5: .line 254
            aload 2 /* appender */
            iconst_0
            invokevirtual ch.qos.logback.core.FileAppender.setPrudent:(Z)V
         6: .line 255
            aload 2 /* appender */
            areturn
        end local 2 // ch.qos.logback.core.FileAppender appender
        end local 1 // ch.qos.logback.classic.LoggerContext context
        end local 0 // io.dropwizard.logging.FileAppenderFactory this
      LocalVariableTable:
        Start  End  Slot      Name  Signature
            0    7     0      this  Lio/dropwizard/logging/FileAppenderFactory<TE;>;
            0    7     1   context  Lch/qos/logback/classic/LoggerContext;
            1    7     2  appender  Lch/qos/logback/core/FileAppender<TE;>;
    Signature: (Lch/qos/logback/classic/LoggerContext;)Lch/qos/logback/core/OutputStreamAppender<TE;>;
    MethodParameters:
         Name  Flags
      context  

  protected ch.qos.logback.core.FileAppender<E> buildAppender(ch.qos.logback.classic.LoggerContext);
    descriptor: (Lch/qos/logback/classic/LoggerContext;)Lch/qos/logback/core/FileAppender;
    flags: (0x0004) ACC_PROTECTED
    Code:
      stack=5, locals=5, args_size=2
        start local 0 // io.dropwizard.logging.FileAppenderFactory this
        start local 1 // ch.qos.logback.classic.LoggerContext context
         0: .line 259
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.archive:Z
            ifeq 36
         1: .line 260
            new ch.qos.logback.core.rolling.RollingFileAppender
            dup
            invokespecial ch.qos.logback.core.rolling.RollingFileAppender.<init>:()V
            astore 2 /* appender */
        start local 2 // ch.qos.logback.core.rolling.RollingFileAppender appender
         2: .line 261
            aload 2 /* appender */
            aload 1 /* context */
            invokevirtual ch.qos.logback.core.rolling.RollingFileAppender.setContext:(Lch/qos/logback/core/Context;)V
         3: .line 262
            aload 2 /* appender */
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.currentLogFilename:Ljava/lang/String;
            invokevirtual ch.qos.logback.core.rolling.RollingFileAppender.setFile:(Ljava/lang/String;)V
         4: .line 263
            aload 2 /* appender */
            new ch.qos.logback.core.util.FileSize
            dup
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.bufferSize:Lio/dropwizard/util/Size;
            invokevirtual io.dropwizard.util.Size.toBytes:()J
            invokespecial ch.qos.logback.core.util.FileSize.<init>:(J)V
            invokevirtual ch.qos.logback.core.rolling.RollingFileAppender.setBufferSize:(Lch/qos/logback/core/util/FileSize;)V
         5: .line 265
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.maxFileSize:Lio/dropwizard/util/Size;
            ifnull 19
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.archivedLogFilenamePattern:Ljava/lang/String;
            invokestatic java.util.Objects.requireNonNull:(Ljava/lang/Object;)Ljava/lang/Object;
            checkcast java.lang.String
            ldc "%d"
            invokevirtual java.lang.String.contains:(Ljava/lang/CharSequence;)Z
            ifne 19
         6: .line 266
            new ch.qos.logback.core.rolling.FixedWindowRollingPolicy
            dup
            invokespecial ch.qos.logback.core.rolling.FixedWindowRollingPolicy.<init>:()V
            astore 3 /* rollingPolicy */
        start local 3 // ch.qos.logback.core.rolling.FixedWindowRollingPolicy rollingPolicy
         7: .line 267
            aload 3 /* rollingPolicy */
            aload 1 /* context */
            invokevirtual ch.qos.logback.core.rolling.FixedWindowRollingPolicy.setContext:(Lch/qos/logback/core/Context;)V
         8: .line 268
            aload 3 /* rollingPolicy */
            aload 0 /* this */
            invokevirtual io.dropwizard.logging.FileAppenderFactory.getArchivedFileCount:()I
            invokevirtual ch.qos.logback.core.rolling.FixedWindowRollingPolicy.setMaxIndex:(I)V
         9: .line 269
            aload 3 /* rollingPolicy */
            aload 0 /* this */
            invokevirtual io.dropwizard.logging.FileAppenderFactory.getArchivedLogFilenamePattern:()Ljava/lang/String;
            invokevirtual ch.qos.logback.core.rolling.FixedWindowRollingPolicy.setFileNamePattern:(Ljava/lang/String;)V
        10: .line 270
            aload 3 /* rollingPolicy */
            aload 2 /* appender */
            invokevirtual ch.qos.logback.core.rolling.FixedWindowRollingPolicy.setParent:(Lch/qos/logback/core/FileAppender;)V
        11: .line 271
            aload 3 /* rollingPolicy */
            invokevirtual ch.qos.logback.core.rolling.FixedWindowRollingPolicy.start:()V
        12: .line 272
            aload 2 /* appender */
            aload 3 /* rollingPolicy */
            invokevirtual ch.qos.logback.core.rolling.RollingFileAppender.setRollingPolicy:(Lch/qos/logback/core/rolling/RollingPolicy;)V
        13: .line 274
            new ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy
            dup
            invokespecial ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy.<init>:()V
            astore 4 /* triggeringPolicy */
        start local 4 // ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy triggeringPolicy
        14: .line 275
            aload 4 /* triggeringPolicy */
            new ch.qos.logback.core.util.FileSize
            dup
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.maxFileSize:Lio/dropwizard/util/Size;
            invokevirtual io.dropwizard.util.Size.toBytes:()J
            invokespecial ch.qos.logback.core.util.FileSize.<init>:(J)V
            invokevirtual ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy.setMaxFileSize:(Lch/qos/logback/core/util/FileSize;)V
        15: .line 276
            aload 4 /* triggeringPolicy */
            aload 1 /* context */
            invokevirtual ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy.setContext:(Lch/qos/logback/core/Context;)V
        16: .line 277
            aload 4 /* triggeringPolicy */
            invokevirtual ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy.start:()V
        17: .line 278
            aload 2 /* appender */
            aload 4 /* triggeringPolicy */
            invokevirtual ch.qos.logback.core.rolling.RollingFileAppender.setTriggeringPolicy:(Lch/qos/logback/core/rolling/TriggeringPolicy;)V
        18: .line 280
            aload 2 /* appender */
            areturn
        end local 4 // ch.qos.logback.core.rolling.SizeBasedTriggeringPolicy triggeringPolicy
        end local 3 // ch.qos.logback.core.rolling.FixedWindowRollingPolicy rollingPolicy
        19: .line 283
      StackMap locals: ch.qos.logback.core.rolling.RollingFileAppender
      StackMap stack:
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.maxFileSize:Lio/dropwizard/util/Size;
            ifnonnull 26
        20: .line 284
            new ch.qos.logback.core.rolling.TimeBasedRollingPolicy
            dup
            invokespecial ch.qos.logback.core.rolling.TimeBasedRollingPolicy.<init>:()V
            astore 3 /* rollingPolicy */
        start local 3 // ch.qos.logback.core.rolling.TimeBasedRollingPolicy rollingPolicy
        21: .line 286
            new ch.qos.logback.core.rolling.DefaultTimeBasedFileNamingAndTriggeringPolicy
            dup
            invokespecial ch.qos.logback.core.rolling.DefaultTimeBasedFileNamingAndTriggeringPolicy.<init>:()V
            astore 4 /* triggeringPolicy */
        start local 4 // ch.qos.logback.core.rolling.TimeBasedFileNamingAndTriggeringPolicy triggeringPolicy
        22: .line 287
            aload 4 /* triggeringPolicy */
            aload 1 /* context */
            invokeinterface ch.qos.logback.core.rolling.TimeBasedFileNamingAndTriggeringPolicy.setContext:(Lch/qos/logback/core/Context;)V
        23: .line 288
            aload 4 /* triggeringPolicy */
            aload 3 /* rollingPolicy */
            invokeinterface ch.qos.logback.core.rolling.TimeBasedFileNamingAndTriggeringPolicy.setTimeBasedRollingPolicy:(Lch/qos/logback/core/rolling/TimeBasedRollingPolicy;)V
        24: .line 289
            aload 2 /* appender */
            aload 4 /* triggeringPolicy */
            invokevirtual ch.qos.logback.core.rolling.RollingFileAppender.setTriggeringPolicy:(Lch/qos/logback/core/rolling/TriggeringPolicy;)V
        end local 4 // ch.qos.logback.core.rolling.TimeBasedFileNamingAndTriggeringPolicy triggeringPolicy
        25: .line 290
            goto 29
        end local 3 // ch.qos.logback.core.rolling.TimeBasedRollingPolicy rollingPolicy
        26: .line 293
      StackMap locals:
      StackMap stack:
            new ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy
            dup
            invokespecial ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy.<init>:()V
            astore 4 /* sizeAndTimeBasedRollingPolicy */
        start local 4 // ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy sizeAndTimeBasedRollingPolicy
        27: .line 294
            aload 4 /* sizeAndTimeBasedRollingPolicy */
            new ch.qos.logback.core.util.FileSize
            dup
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.maxFileSize:Lio/dropwizard/util/Size;
            invokevirtual io.dropwizard.util.Size.toBytes:()J
            invokespecial ch.qos.logback.core.util.FileSize.<init>:(J)V
            invokevirtual ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy.setMaxFileSize:(Lch/qos/logback/core/util/FileSize;)V
        28: .line 295
            aload 4 /* sizeAndTimeBasedRollingPolicy */
            astore 3 /* rollingPolicy */
        end local 4 // ch.qos.logback.core.rolling.SizeAndTimeBasedRollingPolicy sizeAndTimeBasedRollingPolicy
        start local 3 // ch.qos.logback.core.rolling.TimeBasedRollingPolicy rollingPolicy
        29: .line 298
      StackMap locals: ch.qos.logback.core.rolling.TimeBasedRollingPolicy
      StackMap stack:
            aload 3 /* rollingPolicy */
            aload 1 /* context */
            invokevirtual ch.qos.logback.core.rolling.TimeBasedRollingPolicy.setContext:(Lch/qos/logback/core/Context;)V
        30: .line 299
            aload 3 /* rollingPolicy */
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.archivedLogFilenamePattern:Ljava/lang/String;
            invokevirtual ch.qos.logback.core.rolling.TimeBasedRollingPolicy.setFileNamePattern:(Ljava/lang/String;)V
        31: .line 300
            aload 3 /* rollingPolicy */
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.archivedFileCount:I
            invokevirtual ch.qos.logback.core.rolling.TimeBasedRollingPolicy.setMaxHistory:(I)V
        32: .line 302
            aload 2 /* appender */
            aload 3 /* rollingPolicy */
            invokevirtual ch.qos.logback.core.rolling.RollingFileAppender.setRollingPolicy:(Lch/qos/logback/core/rolling/RollingPolicy;)V
        33: .line 304
            aload 3 /* rollingPolicy */
            aload 2 /* appender */
            invokevirtual ch.qos.logback.core.rolling.TimeBasedRollingPolicy.setParent:(Lch/qos/logback/core/FileAppender;)V
        34: .line 305
            aload 3 /* rollingPolicy */
            invokevirtual ch.qos.logback.core.rolling.TimeBasedRollingPolicy.start:()V
        35: .line 306
            aload 2 /* appender */
            areturn
        end local 3 // ch.qos.logback.core.rolling.TimeBasedRollingPolicy rollingPolicy
        end local 2 // ch.qos.logback.core.rolling.RollingFileAppender appender
        36: .line 310
      StackMap locals:
      StackMap stack:
            new ch.qos.logback.core.FileAppender
            dup
            invokespecial ch.qos.logback.core.FileAppender.<init>:()V
            astore 2 /* appender */
        start local 2 // ch.qos.logback.core.FileAppender appender
        37: .line 311
            aload 2 /* appender */
            aload 1 /* context */
            invokevirtual ch.qos.logback.core.FileAppender.setContext:(Lch/qos/logback/core/Context;)V
        38: .line 312
            aload 2 /* appender */
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.currentLogFilename:Ljava/lang/String;
            invokevirtual ch.qos.logback.core.FileAppender.setFile:(Ljava/lang/String;)V
        39: .line 313
            aload 2 /* appender */
            new ch.qos.logback.core.util.FileSize
            dup
            aload 0 /* this */
            getfield io.dropwizard.logging.FileAppenderFactory.bufferSize:Lio/dropwizard/util/Size;
            invokevirtual io.dropwizard.util.Size.toBytes:()J
            invokespecial ch.qos.logback.core.util.FileSize.<init>:(J)V
            invokevirtual ch.qos.logback.core.FileAppender.setBufferSize:(Lch/qos/logback/core/util/FileSize;)V
        40: .line 314
            aload 2 /* appender */
            areturn
        end local 2 // ch.qos.logback.core.FileAppender appender
        end local 1 // ch.qos.logback.classic.LoggerContext context
        end local 0 // io.dropwizard.logging.FileAppenderFactory this
      LocalVariableTable:
        Start  End  Slot                           Name  Signature
            0   41     0                           this  Lio/dropwizard/logging/FileAppenderFactory<TE;>;
            0   41     1                        context  Lch/qos/logback/classic/LoggerContext;
            2   36     2                       appender  Lch/qos/logback/core/rolling/RollingFileAppender<TE;>;
            7   19     3                  rollingPolicy  Lch/qos/logback/core/rolling/FixedWindowRollingPolicy;
           14   19     4               triggeringPolicy  Lch/qos/logback/core/rolling/SizeBasedTriggeringPolicy<TE;>;
           21   26     3                  rollingPolicy  Lch/qos/logback/core/rolling/TimeBasedRollingPolicy<TE;>;
           29   36     3                  rollingPolicy  Lch/qos/logback/core/rolling/TimeBasedRollingPolicy<TE;>;
           22   25     4               triggeringPolicy  Lch/qos/logback/core/rolling/TimeBasedFileNamingAndTriggeringPolicy<TE;>;
           27   29     4  sizeAndTimeBasedRollingPolicy  Lch/qos/logback/core/rolling/SizeAndTimeBasedRollingPolicy<TE;>;
           37   41     2                       appender  Lch/qos/logback/core/FileAppender<TE;>;
    Signature: (Lch/qos/logback/classic/LoggerContext;)Lch/qos/logback/core/FileAppender<TE;>;
    MethodParameters:
         Name  Flags
      context  
}
Signature: <E::Lch/qos/logback/core/spi/DeferredProcessingAware;>Lio/dropwizard/logging/AbstractOutputStreamAppenderFactory<TE;>;
SourceFile: "FileAppenderFactory.java"
    RuntimeVisibleAnnotations: 
      com.fasterxml.jackson.annotation.JsonTypeName(value = "file")