org.eclipse.jpt.common.ui.internal.widgets.NewNameStateObject.java Source code

Java tutorial

Introduction

Here is the source code for org.eclipse.jpt.common.ui.internal.widgets.NewNameStateObject.java

Source

/*******************************************************************************
 * Copyright (c) 2008, 2013 Oracle. All rights reserved.
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License v1.0, which accompanies this distribution
 * and is available at http://www.eclipse.org/legal/epl-v10.html.
 *
 * Contributors:
 *     Oracle - initial API and implementation
 ******************************************************************************/
package org.eclipse.jpt.common.ui.internal.widgets;

import java.util.Collection;
import java.util.List;
import org.eclipse.jface.dialogs.IMessageProvider;
import org.eclipse.jpt.common.ui.JptCommonUiMessages;
import org.eclipse.jpt.common.utility.internal.StringTools;
import org.eclipse.jpt.common.utility.internal.node.AbstractNode;
import org.eclipse.jpt.common.utility.node.Node;

/**
 * This is the state object used by the <code>NewNameDialog</code>, which stores
 * the current name and validates it when it is modified.
 */
@SuppressWarnings("nls")
final class NewNameStateObject extends AbstractNode {
    /**
     * The initial input or <code>null</code> if no initial value can be
     * specified.
     */
    private String name;

    /**
     * The collection of names that can't be used or an empty collection if none
     * are available.
     */
    private Collection<String> names;

    /**
     * The <code>Validator</code> used to validate this state object.
     */
    private Validator validator;

    /**
     * Notifies a change in the name property.
     */
    static final String NAME_PROPERTY = "name";

    /**
     * Creates a new <code>NewNameStateObject</code>.
     *
     * @param name The initial input or <code>null</code> if no initial value can
     * be specified
     * @param names The collection of names that can't be used or an empty
     * collection if none are available
     */
    NewNameStateObject(String name, Collection<String> names) {
        super(null);

        this.name = name;
        this.names = names;
    }

    /**
     * Validates the name property.
     *
     * @param currentProblems The list to which <code>Problem</code>s can be
     * added
     */
    private void addNameProblems(List<Problem> currentProblems) {

        if (StringTools.isBlank(name)) {
            currentProblems.add(buildProblem(JptCommonUiMessages.NEW_NAME_STATE_OBJECT__NAME_MUST_BE_SPECIFIED,
                    IMessageProvider.ERROR));
        } else if (names.contains(name.trim())) {
            currentProblems.add(buildProblem(JptCommonUiMessages.NEW_NAME_STATE_OBJECT__NAME_ALREADY_EXISTS,
                    IMessageProvider.ERROR));
        }
    }

    /*
     * (non-Javadoc)
     */
    @Override
    protected void addProblemsTo(List<Problem> currentProblems) {
        super.addProblemsTo(currentProblems);
        addNameProblems(currentProblems);
    }

    /*
     * (non-Javadoc)
     */
    @Override
    protected void checkParent(Node parentNode) {
    }

    /*
     * (non-Javadoc)
     */
    public String displayString() {
        return null;
    }

    /**
     * Returns the current name stored in this state object.
     *
     * @return The current name or <code>null</code>
     */
    String getName() {
        return name;
    }

    /**
     * Sets the current name stored in this state object or <code>null</code> to
     * clear it.
     *
     * @param name The new name or <code>null</code>
     */
    public void setName(String name) {
        String oldName = this.name;
        this.name = name;
        firePropertyChanged(NAME_PROPERTY, oldName, name);
    }

    /*
     * (non-Javadoc)
     */
    @Override
    public void setValidator(Validator validator) {
        this.validator = validator;
    }

    /*
     * (non-Javadoc)
     */
    @Override
    public Validator getValidator() {
        return validator;
    }
}