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

com.scalar.db.io.DoubleValue 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 double 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 DoubleValue implements Value {
  private static final String ANONYMOUS = "";
  private final String name;
  private final double value;

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

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

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

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

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

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

  @Override
  public DoubleValue copyWith(String name) {
    return new DoubleValue(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 DoubleValue} 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 DoubleValue)) { return false; } DoubleValue other = (DoubleValue) 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().doubleValue()) .compare(name, o.getName()) .result(); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy