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

org.javamoney.moneta.function.MonetaryRoundedFactoryBuilder 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
/*
  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.MathContext;
import java.math.RoundingMode;

/**
 * Builder to {@link MonetaryRoundedFactory} once the {@link RoundingMode}, is possible
 * choose the scale, the number of digits to the right of the decimal point, and the precision, the total number of digits in a number or both.
 * @author Otavio Santana
 * @see MonetaryRoundedFactoryBuilder#withScale(int)
 * @see MonetaryRoundedFactoryBuilder#withPrecision(int)
 * @since 1.0.1
 */
public final class MonetaryRoundedFactoryBuilder {

	private final RoundingMode roundingMode;

	MonetaryRoundedFactoryBuilder(RoundingMode roundingMode) {
		this.roundingMode = roundingMode;
	}

	/**
	 * Set the number of digits to the right of the decimal point
	 * @param scale the scale to use.
	 * @return MonetaryRoundedFactoryWithScaleBuilder
	 */
	public MonetaryRoundedFactoryWithScaleBuilder withScale(int scale) {
		return new MonetaryRoundedFactoryWithScaleBuilder(roundingMode, scale);
	}

	/**
	 * Set the total number of digits in a number
	 * @param precision the precision to use.
	 * @return {@link MonetaryRoundedFactoryWithPrecisionBuilder}
	 */
	public MonetaryRoundedFactoryWithPrecisionBuilder withPrecision(int precision) {
		return new MonetaryRoundedFactoryWithPrecisionBuilder(roundingMode, precision);
	}

	/**
	 * Once the {@link RoundingMode} and scale informed, is possible create a {@link MonetaryRoundedFactory}
	 * or set the number of precision.
	 * @author Otavio Santana
	 *@see MonetaryRoundedFactoryWithScaleBuilder#withPrecision(int)
	 *@see MonetaryRoundedFactoryWithScaleBuilder#build()
	 */
	public static class MonetaryRoundedFactoryWithScaleBuilder {

		private final RoundingMode roundingMode;

		private final int scale;

		private MonetaryRoundedFactoryWithScaleBuilder(RoundingMode roundingMode, int scale) {
			this.roundingMode = roundingMode;
			this.scale = scale;
		}

		/**
		 * Make the {@link MonetaryRoundedFactory} using the {@link ScaleRoundedOperator} as rounding operator.
		 * @return {@link MonetaryRoundedFactory} with {@link ScaleRoundedOperator}
		 * @see ScaleRoundedOperator
		 * @see MonetaryRoundedFactory
		 */
		public MonetaryRoundedFactory build() {
			return new DefaultMonetaryRoundedFactory(ScaleRoundedOperator.of(scale, roundingMode));
		}

		/**
		 * Set the total number of digits in a number
		 * @param precision the precision to use.
		 * @return {@link MonetaryRoundedFactoryWithPrecisionBuilder}
		 */
		public MonetaryRoundedFactoryWithPrecisionScaleBuilder withPrecision(int precision) {
			MonetaryRoundedFactoryWithPrecisionScaleBuilder builder = new MonetaryRoundedFactoryWithPrecisionScaleBuilder(roundingMode);
			builder.scale = this.scale;
			builder.precision = precision;
			return builder;
		}

	}

	/**
	 * Once the {@link RoundingMode} and precision informed, is possible create a {@link MonetaryRoundedFactory}
	 * or set the number of scale.
	 * @author Otavio Santana
	 *@see MonetaryRoundedFactoryWithPrecisionBuilder#withScale(int)
	 *@see MonetaryRoundedFactoryWithPrecisionBuilder#build()
	 */
	public static class MonetaryRoundedFactoryWithPrecisionBuilder {

		private final int precision;

		private final RoundingMode roundingMode;

		private MonetaryRoundedFactoryWithPrecisionBuilder(RoundingMode roundingMode, int precision) {
			this.roundingMode = roundingMode;
			this.precision = precision;
		}
		/**
		 * Set the number of digits to the right of the decimal point
		 * @param scale the scale to use.
		 * @return MonetaryRoundedFactoryWithPrecisionScaleBuilder
		 */
		public MonetaryRoundedFactoryWithPrecisionScaleBuilder withScale(int scale) {
			MonetaryRoundedFactoryWithPrecisionScaleBuilder builder = new MonetaryRoundedFactoryWithPrecisionScaleBuilder(roundingMode);
			builder.precision = this.precision;
			builder.scale = scale;
			return builder;
		}

		/**
		 * Make the {@link MonetaryRoundedFactory} using the {@link PrecisionContextRoundedOperator} as rounding operator.
		 * @return {@link MonetaryRoundedFactory} with {@link PrecisionContextRoundedOperator}
		 * @see PrecisionContextRoundedOperator
		 * @see MonetaryRoundedFactory
		 */
		public MonetaryRoundedFactory build() {
			MathContext mathContext = new MathContext(precision, roundingMode);
			return new DefaultMonetaryRoundedFactory(PrecisionContextRoundedOperator.of(mathContext));
		}

	}

	/**
	 * Once the {@link RoundingMode}, precision and scale informed, the next step will build a {@link MonetaryRoundedFactory}
	 * with all these information.
	 * @author Otavio Santana
	 */
	public static class MonetaryRoundedFactoryWithPrecisionScaleBuilder {

		private int scale;

		private int precision;

		private final RoundingMode roundingMode;

		public MonetaryRoundedFactoryWithPrecisionScaleBuilder(
				RoundingMode roundingMode) {
			this.roundingMode = roundingMode;
		}

		/**
		 * Make the {@link MonetaryRoundedFactory} using the {@link PrecisionScaleRoundedOperator} as rounding operator.
		 * @return {@link MonetaryRoundedFactory} with {@link PrecisionScaleRoundedOperator}
		 * @see PrecisionContextRoundedOperator
		 * @see PrecisionScaleRoundedOperator
		 */
		public MonetaryRoundedFactory build() {
			MathContext mathContext = new MathContext(precision, roundingMode);
			return new DefaultMonetaryRoundedFactory(PrecisionScaleRoundedOperator.of(scale, mathContext));
		}

	}

	@Override
	public String toString() {
		String sb = MonetaryRoundedFactoryBuilder.class.getName() + '{' +
				"roundingMode: " + roundingMode + '}';
		return sb;
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy