com.ibm.cloud.objectstorage.thirdparty.ion.IonDecimal Maven / Gradle / Ivy
Show all versions of ibm-cos-java-sdk-bundle Show documentation
/*
* Copyright 2007-2016 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://aws.amazon.com/apache2.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 software.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;
}