/*
* Copyright (c) 2012 Data Harmonisation Panel
*
* All rights reserved. This program and the accompanying materials are made
* available under the terms of the GNU Lesser General Public License as
* published by the Free Software Foundation, either version 3 of the License,
* or (at your option) any later version.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this distribution. If not, see <http://www.gnu.org/licenses/>.
*
* Contributors:
* HUMBOLDT EU Integrated Project #030962
* Data Harmonisation Panel <http://www.dhpanel.eu>
*/
package eu.esdihumboldt.hale.common.align.model.transformation.tree.impl;
import java.util.HashMap;
import java.util.Map;
import eu.esdihumboldt.hale.common.align.model.transformation.tree.TransformationNode;
/**
* Abstract transformation node implementation.
*
* @author Simon Templer
*/
public abstract class AbstractTransformationNode implements TransformationNode {
private Map<String, Object> annotations;
/**
* @see TransformationNode#reset()
*/
@Override
public void reset() {
if (annotations != null) {
annotations.clear();
}
}
/**
* @see TransformationNode#getAnnotation(String)
*/
@Override
public Object getAnnotation(String name) {
if (annotations == null) {
return null;
}
return annotations.get(name);
}
/**
* @see TransformationNode#setAnnotation(String, Object)
*/
@Override
public void setAnnotation(String name, Object annotation) {
if (annotations == null) {
annotations = new HashMap<String, Object>();
}
annotations.put(name, annotation);
}
/**
* @see TransformationNode#hasAnnotations()
*/
@Override
public boolean hasAnnotations() {
return annotations != null && !annotations.isEmpty();
}
}