org.javamoney.moneta.spi.base.BaseMonetaryAmountFactory Maven / Gradle / Ivy
/*
* CREDIT SUISSE IS WILLING TO LICENSE THIS SPECIFICATION TO YOU ONLY UPON THE CONDITION THAT YOU
* ACCEPT ALL OF THE TERMS CONTAINED IN THIS AGREEMENT. PLEASE READ THE TERMS AND CONDITIONS OF THIS
* AGREEMENT CAREFULLY. BY DOWNLOADING THIS SPECIFICATION, YOU ACCEPT THE TERMS AND CONDITIONS OF
* THE AGREEMENT. IF YOU ARE NOT WILLING TO BE BOUND BY IT, SELECT THE "DECLINE" BUTTON AT THE
* BOTTOM OF THIS PAGE. Specification: JSR-354 Money and Currency API ("Specification") Copyright
* (c) 2012-2013, Credit Suisse All rights reserved.
*/
package org.javamoney.moneta.spi.base;
import javax.money.MonetaryAmount;
import javax.money.MonetaryAmountFactory;
import javax.money.MonetaryContext;
import javax.money.Monetary;
/**
* Factory for {@link javax.money.MonetaryAmount} instances for a given type. It can be accessed, by
*
* - calling {@link javax.money.MonetaryAmount#getFactory()}, returning a {@link BaseMonetaryAmountFactory}
* creating amounts of the same implementation type, which also provided the factory instance.
* - calling {@link javax.money.Monetary#getAmountFactory(Class)} accessing a
* {@link BaseMonetaryAmountFactory} for a concrete type
Class
.
* - calling {@link javax.money.Monetary#getDefaultAmountFactory()} accessing a default
* {@link BaseMonetaryAmountFactory}.
*
*
* Implementations of this interface allow to get {@link javax.money.MonetaryAmount} instances providing
* different data as required:
*
* - the {@link javax.money.CurrencyUnit}, or the corresponding currency code (must be solvable by
* {@link javax.money.Monetary}).
* - the number part
* - the {@link javax.money.MonetaryContext}
* - by passing any {@link javax.money.MonetaryAmount} instance, it is possible to convert an arbitrary amount
* implementation to the implementation provided by this factory. If the current factory cannot
* support the precision/scale as required by the current {@link javax.money.NumberValue} a
* {@link javax.money.MonetaryException} must be thrown.
*
* If not defined a default {@link javax.money.MonetaryContext} is used, which can also be configured by adding
* configuration to a file {@code /javamoney.properties} to the classpath.
*
* Hereby the entries. e.g. for a class {@code MyMoney} should start with {@code a.b.MyMoney.ctx}. The entries valid
* must be documented
* on the according implementation class, where the following entries are defined for all implementation types
* (example below given for a class {@code a.b.MyMoney}:
*
* - {@code a.b.MyMoney.ctx.precision} to define the maximal supported precision.
* - {@code a.b.MyMoney.ctx.maxScale} to define the maximal supported scale.
* - {@code a.b.MyMoney.ctx.fixedScale} to define the scale to be fixed (constant).
*
*
*
Implementation specification
Instances of this interface are not required to be
* thread-safe!
*
* @author Anatole Tresch
* @author Werner Keil
* @version 0.6.1
*/
public abstract class BaseMonetaryAmountFactory implements MonetaryAmountFactory {
/**
* Sets the {@link javax.money.CurrencyUnit} to be used.
*
* @param currencyCode the currencyCode of the currency to be used, not {@code null}. The currency code
* will be resolved using {@link javax.money.Monetary#getCurrency(String, String...)}.
* @return This factory instance, for chaining.
* @throws javax.money.UnknownCurrencyException if the {@code currencyCode} is not resolvable.
* @throws javax.money.UnknownCurrencyException if the {@code currencyCode} is not resolvable.
*/
public MonetaryAmountFactory setCurrency(String currencyCode) {
return setCurrency(Monetary.getCurrency(currencyCode));
}
/**
* Uses an arbitrary {@link javax.money.MonetaryAmount} to initialize this factory. Properties reused are:
*
* - CurrencyUnit,
* - Number value,
* - MonetaryContext.
*
*
* @param amount the amount to be used, not {@code null}.
* @return this factory instance, for chaining.
* @throws javax.money.MonetaryException when the {@link javax.money.MonetaryContext} implied by {@code amount.getContext()}
* exceeds the capabilities supported by this factory type.
*/
public MonetaryAmountFactory setAmount(MonetaryAmount amount) {
setCurrency(amount.getCurrency());
setNumber(amount.getNumber());
setContext(amount.getContext());
return this;
}
/**
* Returns the maximal {@link javax.money.MonetaryContext} supported, for requests that exceed these maximal
* capabilities, an {@link ArithmeticException} must be thrown.
*
* @return the maximal {@link javax.money.MonetaryContext} supported, never {@code null}
*/
public MonetaryContext getMaximalMonetaryContext() {
return getDefaultMonetaryContext();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy