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

com.scalar.db.io.FloatValue Maven / Gradle / Ivy

Go to download

A universal transaction manager that achieves database-agnostic transactions and distributed transactions that span multiple databases

The newest version!
package com.scalar.db.io;

import static com.google.common.base.Preconditions.checkNotNull;

import com.google.common.base.MoreObjects;
import com.google.common.collect.ComparisonChain;
import java.util.Objects;
import javax.annotation.Nonnull;
import javax.annotation.concurrent.Immutable;

/**
 * A {@code Value} (column) for a single precision floating point number
 *
 * @author Hiroyuki Yamada
 * @deprecated As of release 3.6.0. Will be removed in release 5.0.0
 */
@Deprecated
@Immutable
public final class FloatValue implements Value {
  private static final String ANONYMOUS = "";
  private final String name;
  private final float value;

  /**
   * Constructs a {@code FloatValue} with the specified name and value
   *
   * @param name name of the {@code Value} (column)
   * @param value value of the {@code Value} (column)
   */
  public FloatValue(String name, float value) {
    this.name = checkNotNull(name);
    this.value = value;
  }

  /**
   * Constructs a {@code FloatValue} with the specified value. The name of this value (column) is
   * anonymous.
   *
   * @param value value of the {@code Value} (column)
   */
  public FloatValue(float value) {
    this(ANONYMOUS, value);
  }

  @Override
  @Nonnull
  public Float get() {
    return value;
  }

  @Override
  public DataType getDataType() {
    return DataType.FLOAT;
  }

  @Override
  public float getAsFloat() {
    return value;
  }

  @Override
  public double getAsDouble() {
    return value;
  }

  @Override
  @Nonnull
  public String getName() {
    return name;
  }

  @Override
  public FloatValue copyWith(String name) {
    return new FloatValue(name, value);
  }

  @Override
  public void accept(ValueVisitor v) {
    v.visit(this);
  }

  @Override
  public int hashCode() {
    return Objects.hash(name, value);
  }

  /**
   * Indicates whether some other object is "equal to" this object. The other object is considered
   * equal if:
   *
   * 
    *
  • both super class instances are equal and *
  • it is also an {@code FloatValue} and *
  • both instances have the same name and value *
* * @param o an object to be tested for equality * @return {@code true} if the other object is "equal to" this object otherwise {@code false} */ @Override public boolean equals(Object o) { if (o == this) { return true; } if (!(o instanceof FloatValue)) { return false; } FloatValue other = (FloatValue) o; return (name.equals(other.name) && value == other.value); } @Override public String toString() { return MoreObjects.toStringHelper(this).add("name", name).add("value", value).toString(); } @Override public int compareTo(Value o) { return ComparisonChain.start() .compare(value, o.get().floatValue()) .compare(name, o.getName()) .result(); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy