/* * 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.constraint.type; import net.jcip.annotations.Immutable; import eu.esdihumboldt.hale.common.schema.model.Constraint; import eu.esdihumboldt.hale.common.schema.model.TypeConstraint; import eu.esdihumboldt.hale.common.schema.model.constraint.AbstractFlagConstraint; /** * Flags if an augmented value is present for a type, meaning a value that is * not defined through the schema, but associated additionally to an instance. * Disabled by default. Should never be enabled when {@link HasValueFlag} is * enabled, meaning there is a value defined through the schema.<br> * <br> * The {@link Binding} constraint defines the Java binding for the value. * * @see Binding * @see HasValueFlag * * @author Simon Templer */ @Immutable @Constraint(mutable = false) public class AugmentedValueFlag extends AbstractFlagConstraint implements TypeConstraint { /** * Enabled augmented value flag */ public static final AugmentedValueFlag ENABLED = new AugmentedValueFlag(true); /** * Disabled augmented value flag */ public static final AugmentedValueFlag DISABLED = new AugmentedValueFlag(false); /** * Get the augmented value flag * * @param augmentedValue if the flag shall be enabled * @return the flag */ public static AugmentedValueFlag get(boolean augmentedValue) { return (augmentedValue) ? (ENABLED) : (DISABLED); } /** * Creates a default augmented value flag, which is disabled. If possible, * instead of creating an instance, use {@link #ENABLED} or * {@link #DISABLED}. * * @see Constraint */ public AugmentedValueFlag() { this(false); } /** * @see AbstractFlagConstraint#AbstractFlagConstraint(boolean) */ protected AugmentedValueFlag(boolean enabled) { super(enabled); } /** * @see TypeConstraint#isInheritable() */ @Override public boolean isInheritable() { // inherit unless overridden return true; } }