org.javamoney.moneta.function.MinorPart Maven / Gradle / Ivy
Show all versions of moneta-bp Show documentation
/**
* Copyright (c) 2012, 2014, Credit Suisse (Anatole Tresch), Werner Keil and others by the @author tag.
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not
* use this file except in compliance with the License. You may obtain a copy of
* the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License 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 org.javamoney.moneta.function;
import java.math.BigDecimal;
import java.math.RoundingMode;
import java.util.Objects;
import javax.money.MonetaryAmount;
import javax.money.MonetaryOperator;
/**
* This class allows to extract the minor part of a {@link MonetaryAmount}
* instance.
*
* @author Anatole Tresch
*/
final class MinorPart implements MonetaryOperator {
/**
* Package private constructor used from MonetaryFunctions.
*/
MinorPart() {
}
/**
* Gets the minor part of a {@code MonetaryAmount} with the same scale.
*
* This returns the monetary amount in terms of the minor units of the
* currency, truncating the whole part if necessary. For example, 'EUR 2.35'
* will return 'EUR 0.35', and 'BHD -1.345' will return 'BHD -0.345'.
*
* This is returned as a {@code MonetaryAmount} rather than a
* {@code BigDecimal} . This is to allow further calculations to be
* performed on the result. Should you need a {@code BigDecimal}, simply
* call {@code asType(BigDecimal.class)}.
*
* @return the minor units part of the amount, never {@code null}
*/
@Override
public MonetaryAmount apply(MonetaryAmount amount){
Objects.requireNonNull(amount, "Amount required.");
BigDecimal number = amount.getNumber().numberValue(BigDecimal.class);
BigDecimal wholes = number.setScale(0, RoundingMode.DOWN);
return amount.subtract(amount.getFactory().setNumber(wholes).create());
}
}