Open Source Repository

Home /spring/spring-context-3.0.5 | Repository Home



org/springframework/format/number/NumberFormatter.java
/*
 * Copyright 2002-2010 the original author or authors.
 *
 * 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.springframework.format.number;

import java.text.DecimalFormat;
import java.text.NumberFormat;
import java.util.Locale;

/**
 * A general-purpose Number formatter.
 *
 <p>Delegates to {@link NumberFormat#getInstance(Locale)}.
 * Configures BigDecimal parsing so there is no loss in precision.
 * Allows configuration over the decimal number pattern.
 * The {@link #parse(String, Locale)} routine always returns a BigDecimal.
 *
 @author Keith Donald
 @author Juergen Hoeller
 @since 3.0
 @see #setPattern
 @see #setLenient
 */
public class NumberFormatter extends AbstractNumberFormatter {

  private String pattern;


  /**
   * Create a new NumberFormatter without a pattern.
   */
  public NumberFormatter() {
  }

  /**
   * Create a new NumberFormatter with the specified pattern.
   @param pattern the format pattern
   @see #setPattern
   */
  public NumberFormatter(String pattern) {
    this.pattern = pattern;
  }


  /**
   * Sets the pattern to use to format number values.
   * If not specified, the default DecimalFormat pattern is used.
   @see DecimalFormat#applyPattern(String)
   */
  public void setPattern(String pattern) {
    this.pattern = pattern;
  }


  public NumberFormat getNumberFormat(Locale locale) {
    NumberFormat format = NumberFormat.getInstance(locale);
    if (!(format instanceof DecimalFormat)) {
      if (this.pattern != null) {
        throw new IllegalStateException("Cannot support pattern for non-DecimalFormat: " + format);
      }
      return format;
    }
    DecimalFormat decimalFormat = (DecimalFormatformat;
    decimalFormat.setParseBigDecimal(true);
    if (this.pattern != null) {
      decimalFormat.applyPattern(this.pattern);
    }
    return decimalFormat;
  }

}