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

org.javamoney.moneta.spi.base.BaseMonetaryAmountFactory Maven / Gradle / Ivy

Go to download

JSR 354 provides an API for representing, transporting, and performing comprehensive calculations with Money and Currency. This module implements JSR 354.

There is a newer version: 1.4.1
Show newest version
/*
 * 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 {@code 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