/* * 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.schema.model.impl.internal; import net.jcip.annotations.Immutable; import com.google.common.base.Preconditions; import eu.esdihumboldt.hale.common.schema.model.GroupPropertyDefinition; import eu.esdihumboldt.hale.common.schema.model.TypeDefinition; import eu.esdihumboldt.hale.common.schema.model.impl.AbstractGroupPropertyDecorator; import eu.esdihumboldt.hale.common.schema.model.impl.AbstractPropertyDecorator; /** * Decorator for {@link GroupPropertyDefinition}s that has a changed parent type * * @author Simon Templer */ @Immutable public class ReparentGroupProperty extends AbstractGroupPropertyDecorator { private final TypeDefinition parent; /** * Create a decorator for the given property that has a changed parent type * * @param propertyGroup the property group to decorate * @param newParent the new parent type, may not be <code>null</code> */ public ReparentGroupProperty(GroupPropertyDefinition propertyGroup, TypeDefinition newParent) { super(propertyGroup); Preconditions.checkNotNull(newParent); this.parent = newParent; } /** * @see AbstractPropertyDecorator#getIdentifier() */ @Override public String getIdentifier() { return parent.getIdentifier() + "/" + getName().getLocalPart(); //$NON-NLS-1$ } /** * @see AbstractPropertyDecorator#getParentType() */ @Override public TypeDefinition getParentType() { return parent; } }