org.apache.bval.model.FeaturesCapable Maven / Gradle / Ivy
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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.apache.bval.model;
import java.io.Serializable;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.ConcurrentMap;
/**
* Description: abstract superclass of meta objects that support a map of
* features.
*/
public abstract class FeaturesCapable implements Serializable {
private static final long serialVersionUID = -4045110242904814218L;
private ConcurrentMap features = createFeaturesMap();
/** key = validation id, value = the validation */
private Validation[] validations = new Validation[0];
/**
* Create a new FeaturesCapable instance.
*/
public FeaturesCapable() {
super();
}
/**
* Get the (live) map of features.
*
* @return Map
*/
public Map getFeatures() {
return features;
}
/**
* Get the specified feature.
*
* @param
* @param key
* @return T
*/
public T getFeature(String key) {
return getFeature(key, (T) null);
}
/**
* Get the specified feature, returning defaultValue
if
* undeclared.
*
* @param
* @param key
* @param defaultValue
* @return T
*/
@SuppressWarnings("unchecked")
public T getFeature(String key, T defaultValue) {
final T value = (T) features.get(key);
if (value == null) {
return defaultValue;
}
return value;
}
/**
* Convenience method to set a particular feature value.
*
* @param key
* @param value
*/
public void putFeature(final String key, final T value) {
features.put(key, value);
}
public T initFeature(final String key, final T value) {
@SuppressWarnings("unchecked")
final T faster = (T) features.putIfAbsent(key, value);
return faster == null ? value : faster;
}
/**
* Create a deep copy (copy receiver and copy properties).
*
* @param
* @return new T instance
*/
public T copy() {
try {
@SuppressWarnings("unchecked")
final T self = (T) clone();
copyInto(self);
return self;
} catch (CloneNotSupportedException e) {
throw new IllegalStateException("cannot clone() " + this, e);
}
}
/**
* Copy this {@link FeaturesCapable} into another {@link FeaturesCapable}
* instance.
*
* @param target
*/
protected void copyInto(FeaturesCapable target) {
target.features = target.createFeaturesMap();
target.features.putAll(features);
target.validations = validations != null ? validations.clone() : null;
}
/**
* Get any validations set for this {@link FeaturesCapable}.
*
* @return Validation array
*/
public Validation[] getValidations() {
return validations != null ? validations.clone() : null;
}
/**
* Set the validations for this {@link FeaturesCapable}.
*
* @param validations
*/
public void setValidations(Validation[] validations) {
this.validations = validations != null ? validations.clone() : null;
}
/**
* Add a validation to this {@link FeaturesCapable}.
*
* @param validation
* to add
*/
public void addValidation(Validation validation) {
if (this.validations == null) {
this.validations = new Validation[] { validation };
} else {
Validation[] newValidations = new Validation[this.validations.length + 1];
System.arraycopy(this.validations, 0, newValidations, 0, this.validations.length);
newValidations[validations.length] = validation;
this.validations = newValidations;
}
}
/**
* Search for an equivalent validation among those configured.
*
* @param aValidation
* @return true if found
*/
public boolean hasValidation(Validation aValidation) {
if (validations == null) {
return false;
}
for (Validation validation : validations) {
if (validation.equals(aValidation)) {
return true;
}
}
return false;
}
/**
* Create a features map for this {@link FeaturesCapable} object.
* @return ConcurrentMap
*/
protected ConcurrentMap createFeaturesMap() {
return new ConcurrentHashMap();
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy