EmptyNumberFormatter.java :  » Swing-Library » jgoodies-validation » com » jgoodies » validation » formatter » Java Open Source

Java Open Source » Swing Library » jgoodies validation 
jgoodies validation » com » jgoodies » validation » formatter » EmptyNumberFormatter.java
/*
 * Copyright (c) 2003-2007 JGoodies Karsten Lentzsch. All Rights Reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are met:
 *
 *  o Redistributions of source code must retain the above copyright notice,
 *    this list of conditions and the following disclaimer.
 *
 *  o Redistributions in binary form must reproduce the above copyright notice,
 *    this list of conditions and the following disclaimer in the documentation
 *    and/or other materials provided with the distribution.
 *
 *  o Neither the name of JGoodies Karsten Lentzsch nor the names of
 *    its contributors may be used to endorse or promote products derived
 *    from this software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
 * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
 * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */

package com.jgoodies.validation.formatter;

import java.text.NumberFormat;
import java.text.ParseException;

import javax.swing.text.NumberFormatter;

import com.jgoodies.validation.util.ValidationUtils;

/**
 * In addition to its superclass NumberFormatter, this class converts
 * to/from the empty string. Therefore it holds an <em>empty value</em>
 * that is the counterpart of the empty string.
 * The Method <code>#valueToString</code> converts the empty value to the
 * empty string. And <code>#stringToValue</code> converts blank strings
 * to the empty value. In all other cases the conversion is delegated
 * to its superclass.<p>
 *
 * Often the empty value is <code>null</code> or <code>-1</code>.
 *
 * <strong>Examples:</strong><pre>
 * new EmptyNumberFormatter();
 * new EmptyNumberFormatter(-1);
 * </pre>
 *
 * @author Karsten Lentzsch
 * @version $Revision: 1.5 $
 *
 * @see java.text.Format
 */
public class EmptyNumberFormatter extends NumberFormatter {

    /**
     * Holds the Number that is converted to an empty string and
     * that is the result of converting blank strings to a value.
     *
     * @see #stringToValue(String)
     * @see #valueToString(Object)
     */
    private final Number emptyValue;


    // Instance Creation ****************************************************

    /**
     * Constructs an EmptyNumberFormatter that converts <code>null</code>
     * to the empty string and vice versa.
     */
    public EmptyNumberFormatter() {
        this((Number) null);
    }


    /**
     * Constructs an EmptyNumberFormatter configured with the specified
     * Format; converts <code>null</code> to the empty string and vice versa.
     *
     * @param format       Format used to dictate legal values
     */
    public EmptyNumberFormatter(NumberFormat format) {
        this(format, null);
    }


    /**
     * Constructs an EmptyNumberFormatter that converts the given
     * <code>emptyValue</code> to the empty string and vice versa.
     *
     * @param emptyValue   the representation of the empty string
     */
    public EmptyNumberFormatter(Number emptyValue) {
        this.emptyValue = emptyValue;
    }


    /**
     * Constructs an EmptyNumberFormatter configured with the specified
     * Format; converts <code>null</code> to the given <code>emptyValue</code>
     * and vice versa.
     *
     * @param format       Format used to dictate legal values
     * @param emptyValue   the representation of the empty string
     */
    public EmptyNumberFormatter(NumberFormat format, Number emptyValue) {
        super(format);
        this.emptyValue = emptyValue;
    }


    // Overriding Superclass Behavior *****************************************

    /**
     * Returns the <code>Object</code> representation of the
     * <code>String</code> <code>text</code>.<p>
     *
     * Unlike its superclass, this class converts blank strings
     * to the empty value.
     *
     * @param text <code>String</code> to convert
     * @return <code>Object</code> representation of text
     * @throws ParseException if there is an error in the conversion
     */
    @Override
    public Object stringToValue(String text) throws ParseException {
        return ValidationUtils.isBlank(text)
            ? emptyValue
            : super.stringToValue(text);
    }


    /**
     * Returns a String representation of the Object <code>value</code>.
     * This invokes <code>format</code> on the current <code>Format</code>.<p>
     *
     * Unlike its superclass, this class converts the empty value
     * to the empty string.
     *
     * @param value   the value to convert
     * @return a String representation of value
     * @throws ParseException if there is an error in the conversion
     */
    @Override
    public String valueToString(Object value) throws ParseException {
        return ValidationUtils.equals(value, emptyValue)
            ? ""
            : super.valueToString(value);
    }


}
java2s.com  | Contact Us | Privacy Policy
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.