com.amazon.ion.IonDecimal Maven / Gradle / Ivy
/*
* Copyright 2007-2019 Amazon.com, Inc. or its affiliates. All Rights Reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License").
* You may not use this file except in compliance with the License.
* A copy of the License is located at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* or in the "license" file accompanying this file. This file is distributed
* on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either
* express or implied. See the License for the specific language governing
* permissions and limitations under the License.
*/
package com.amazon.ion;
import java.math.BigDecimal;
/**
* An Ion decimal
value.
*
* WARNING: This interface should not be implemented or extended by
* code outside of this library.
*/
public interface IonDecimal
extends IonNumber
{
/**
* Gets the value of this Ion {@code decimal} as a Java
* float
value.
*
* @return the float value.
* @throws NullValueException if this.isNullValue()
.
*/
public float floatValue()
throws NullValueException;
/**
* Gets the value of this Ion {@code decimal} as a Java
* double
value.
*
* @return the double value.
* @throws NullValueException if this.isNullValue()
.
*/
public double doubleValue()
throws NullValueException;
/**
* Gets the value of this Ion {@code decimal} as a {@link BigDecimal}.
* If you need negative zeros, use {@link #decimalValue()}.
*
* @return the {@code BigDecimal} value,
* or {@code null} if {@code this.isNullValue()}.
*
* @see #decimalValue()
*/
public BigDecimal bigDecimalValue();
/**
* Gets the value of this Ion {@code decimal} as a {@link Decimal},
* which extends {@link BigDecimal} with support for negative zeros.
*
* @return the {@code Decimal} value,
* or {@code null} if {@code this.isNullValue()}.
*
* @see #bigDecimalValue()
*/
public Decimal decimalValue();
/**
* Sets the value of this element.
*/
public void setValue(long value);
/**
* Sets the value of this element.
* This method behaves like {@link BigDecimal#valueOf(double)} in that it
* uses the {@code double}'s canonical string representation provided by
* {@link Double#toString(double)}}.
*
* @see Decimal#valueOf(double)
*/
public void setValue(float value);
/**
* Sets the value of this element.
* This method behaves like {@link BigDecimal#valueOf(double)} in that it
* uses the {@code double}'s canonical string representation provided by
* {@link Double#toString(double)}}.
*
* @see Decimal#valueOf(double)
*/
public void setValue(double value);
/**
* Sets the value of this element.
* To set a negative zero value, pass an {@link Decimal}.
*
* @param value the new value of this decimal;
* may be null
to make this null.decimal
.
*/
public void setValue(BigDecimal value);
public IonDecimal clone()
throws UnknownSymbolException;
}