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

org.javamoney.moneta.convert.ConversionOperators Maven / Gradle / Ivy

There is a newer version: 1.4.4
Show newest version
/*
 * Copyright (c) 2012, 2015, 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.convert;

import java.util.Objects;
import java.util.function.Supplier;
import java.util.stream.Collector;

import javax.money.CurrencyUnit;
import javax.money.MonetaryAmount;
import javax.money.MonetaryOperator;
import javax.money.convert.ExchangeRateProvider;

import org.javamoney.moneta.convert.ExchangeCurrencyOperator;
import org.javamoney.moneta.function.MonetarySummaryStatistics;

/**
 * This singleton class provides access to the predefined monetary functions.
 * 

* The class is thread-safe, which is also true for all functions returned by * this class. *

 * {@code
 * 	MonetaryAmount money = Money.parse("EUR 2.35");
 *  MonetaryAmount result = operator.apply(money);
 * }
 * 
*

Or using:

*
 * {@code
 * 	MonetaryAmount money = Money.parse("EUR 2.35");
 *  MonetaryAmount result = money.with(operator);
 * }
 * 
* @see MonetaryAmount#with(MonetaryOperator) * @see MonetaryOperator * @see MonetaryOperator#apply(MonetaryAmount) * @author Werner Keil * @since 1.0.1 */ public final class ConversionOperators { private ConversionOperators() { } /** * Do exchange of currency, in other words, create the monetary amount with the * same value but with currency different. *

* For example, 'EUR 2.35', using the currency 'USD' as exchange parameter, will return 'USD 2.35', * and 'BHD -1.345', using the currency 'USD' as exchange parameter, will return 'BHD -1.345'. *

*

	 *{@code
	 *Currency real = Monetary.getCurrency("BRL");
	 *MonetaryAmount money = Money.parse("EUR 2.355");
	 *MonetaryAmount result = ConversionOperators.exchangeCurrency(real).apply(money);//BRL 2.355
	 *}
	 *
* @param currencyUnit the currency to be used * @return the major part as {@link MonetaryOperator} * @since 1.0.1 */ public static MonetaryOperator exchange(CurrencyUnit currencyUnit){ return new ExchangeCurrencyOperator(Objects.requireNonNull(currencyUnit)); } /** * of the summary of the MonetaryAmount * @param currencyUnit * the target {@link javax.money.CurrencyUnit} * @return the MonetarySummaryStatistics */ public static Collector summarizingMonetary( CurrencyUnit currencyUnit, ExchangeRateProvider provider) { Supplier supplier = () -> new ExchangeRateMonetarySummaryStatistics( currencyUnit, provider); return Collector.of(supplier, MonetarySummaryStatistics::accept, MonetarySummaryStatistics::combine); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy