All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.forstdb.CompactionStopStyle Maven / Gradle / Ivy

Go to download

ForSt fat jar with modifications specific for Apache Flink that contains .so files for linux32 and linux64 (glibc and musl-libc), jnilib files for Mac OSX, and a .dll for Windows x64.

There is a newer version: 0.1.2-beta
Show newest version
// Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
package org.forstdb;

/**
 * Algorithm used to make a compaction request stop picking new files
 * into a single compaction run
 */
public enum CompactionStopStyle {

  /**
   * Pick files of similar size
   */
  CompactionStopStyleSimilarSize((byte)0x0),

  /**
   * Total size of picked files > next file
   */
  CompactionStopStyleTotalSize((byte)0x1);


  private final byte value;

  CompactionStopStyle(final byte value) {
    this.value = value;
  }

  /**
   * Returns the byte value of the enumerations value
   *
   * @return byte representation
   */
  public byte getValue() {
    return value;
  }

  /**
   * Get CompactionStopStyle by byte value.
   *
   * @param value byte representation of CompactionStopStyle.
   *
   * @return {@link org.forstdb.CompactionStopStyle} instance or null.
   * @throws java.lang.IllegalArgumentException if an invalid
   *     value is provided.
   */
  public static CompactionStopStyle getCompactionStopStyle(final byte value) {
    for (final CompactionStopStyle compactionStopStyle :
        CompactionStopStyle.values()) {
      if (compactionStopStyle.getValue() == value){
        return compactionStopStyle;
      }
    }
    throw new IllegalArgumentException(
        "Illegal value provided for CompactionStopStyle.");
  }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy