/* * #%L * Nazgul Project: nazgul-core-configuration-model * %% * Copyright (C) 2010 - 2017 jGuru Europe AB * %% * Licensed under the jGuru Europe AB license (the "License"), based * on Apache License, Version 2.0; you may not use this file except * in compliance with the License. * * You may obtain a copy of the License at * * http://www.jguru.se/licenses/jguruCorporateSourceLicense-2.0.txt * * 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. * #L% * */ package se.jguru.nazgul.core.configuration.model; import se.jguru.nazgul.core.xmlbinding.api.XmlBinder; import se.jguru.nazgul.tools.validation.api.exception.InternalStateValidationException; import javax.persistence.Basic; import javax.persistence.Column; import javax.persistence.MappedSuperclass; import javax.xml.bind.annotation.XmlAccessType; import javax.xml.bind.annotation.XmlAccessorType; import javax.xml.bind.annotation.XmlElement; import javax.xml.bind.annotation.XmlType; import java.io.Serializable; /** * Abstract implementation of a MutableProperty with String keys. * * @author <a href="mailto:lj@jguru.se">Lennart Jörelid</a>, jGuru Europe AB */ @MappedSuperclass @XmlType(namespace = XmlBinder.CORE_NAMESPACE, propOrder = {"key"}) @XmlAccessorType(XmlAccessType.FIELD) public abstract class AbstractStringKeyedMutableProperty<V extends Serializable> extends AbstractMutableProperty<String, V> { // Internal state @Basic(optional = false) @Column(nullable = false) @XmlElement(required = true, nillable = false) private String key; /** * <p>JAXB / JPA-friendly constructor.</p> * <p><strong>Note!</strong> For framework use only.</p> */ public AbstractStringKeyedMutableProperty() { } /** * Creates a new AbstractMutableProperty which can hold values of the supplied valueTypeClass. * * @param valueTypeClass The class (V) of values held by this AbstractMutableProperty. * The valueTypeClass argument cannot be {@code null}. */ public AbstractStringKeyedMutableProperty(final String key, final Class<V> valueTypeClass) { // Delegate super(valueTypeClass); // Assign internal state this.key = key; } /** * {@inheritDoc} */ @Override public String getKey() { return key; } /** * {@inheritDoc} */ @Override public void validateEntityState() throws InternalStateValidationException { // Delegate super.validateEntityState(); // Check sanity InternalStateValidationException.create() .notNullOrEmpty(key, "key") .endExpressionAndValidate(); } /** * Equality comparison definition that compares key and value. * {@inheritDoc} */ @Override public boolean equals(final Object that) { // Check sanity if (this == that) { return true; } if (null == that || that.getClass() != getClass()) { return false; } // Delegate and compare final AbstractStringKeyedMutableProperty thatProperty = (AbstractStringKeyedMutableProperty) that; boolean valuesAreEqual = getValue() == null ? thatProperty.getValue() == null : getValue().equals(thatProperty.getValue()); return valuesAreEqual && getKey().equals(thatProperty.getKey()); } /** * {@inheritDoc} */ @Override public int hashCode() { int valueHashcode = getValue() == null ? 0 : getValue().hashCode(); return getKey().hashCode() + valueHashcode; } }