| /** |
| * <copyright> |
| * </copyright> |
| * |
| * $Id: CollectionexpressionsValidator.java,v 1.2 2011/03/05 21:51:24 auhl Exp $ |
| */ |
| package dataaccess.expressions.collectionexpressions.util; |
| |
| import dataaccess.expressions.collectionexpressions.*; |
| |
| import java.util.Map; |
| |
| import org.eclipse.emf.common.util.Diagnostic; |
| import org.eclipse.emf.common.util.DiagnosticChain; |
| import org.eclipse.emf.common.util.ResourceLocator; |
| |
| import org.eclipse.emf.ecore.EPackage; |
| |
| import org.eclipse.emf.ecore.util.EObjectValidator; |
| |
| /** |
| * <!-- begin-user-doc --> |
| * The <b>Validator</b> for the model. |
| * <!-- end-user-doc --> |
| * @see dataaccess.expressions.collectionexpressions.CollectionexpressionsPackage |
| * @generated |
| */ |
| public class CollectionexpressionsValidator extends EObjectValidator { |
| /** |
| * The cached model package |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| public static final CollectionexpressionsValidator INSTANCE = new CollectionexpressionsValidator(); |
| |
| /** |
| * A constant for the {@link org.eclipse.emf.common.util.Diagnostic#getSource() source} of diagnostic {@link org.eclipse.emf.common.util.Diagnostic#getCode() codes} from this package. |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @see org.eclipse.emf.common.util.Diagnostic#getSource() |
| * @see org.eclipse.emf.common.util.Diagnostic#getCode() |
| * @generated |
| */ |
| public static final String DIAGNOSTIC_SOURCE = "dataaccess.expressions.collectionexpressions"; |
| |
| /** |
| * A constant with a fixed name that can be used as the base value for additional hand written constants. |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| private static final int GENERATED_DIAGNOSTIC_CODE_COUNT = 0; |
| |
| /** |
| * A constant with a fixed name that can be used as the base value for additional hand written constants in a derived class. |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| protected static final int DIAGNOSTIC_CODE_COUNT = GENERATED_DIAGNOSTIC_CODE_COUNT; |
| |
| /** |
| * Creates an instance of the switch. |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| public CollectionexpressionsValidator() { |
| super(); |
| } |
| |
| /** |
| * Returns the package of this validator switch. |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| @Override |
| protected EPackage getEPackage() { |
| return CollectionexpressionsPackage.eINSTANCE; |
| } |
| |
| /** |
| * Calls <code>validateXXX</code> for the corresponding classifier of the model. |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| @Override |
| protected boolean validate(int classifierID, Object value, DiagnosticChain diagnostics, Map<Object, Object> context) { |
| switch (classifierID) { |
| case CollectionexpressionsPackage.INCLUDING: |
| return validateIncluding((Including)value, diagnostics, context); |
| case CollectionexpressionsPackage.EXCLUDING: |
| return validateExcluding((Excluding)value, diagnostics, context); |
| case CollectionexpressionsPackage.INCLUDING_AT: |
| return validateIncludingAt((IncludingAt)value, diagnostics, context); |
| case CollectionexpressionsPackage.ITERATE: |
| return validateIterate((Iterate)value, diagnostics, context); |
| case CollectionexpressionsPackage.COLLECTION_EXPRESSION: |
| return validateCollectionExpression((CollectionExpression)value, diagnostics, context); |
| case CollectionexpressionsPackage.EXCLUDING_AT: |
| return validateExcludingAt((ExcludingAt)value, diagnostics, context); |
| case CollectionexpressionsPackage.WITH_POSITION: |
| return validateWithPosition((WithPosition)value, diagnostics, context); |
| case CollectionexpressionsPackage.COLLECTION_EXPRESSION_WITH_ARGUMENT: |
| return validateCollectionExpressionWithArgument((CollectionExpressionWithArgument)value, diagnostics, context); |
| default: |
| return true; |
| } |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| public boolean validateIncluding(Including including, DiagnosticChain diagnostics, Map<Object, Object> context) { |
| if (!validate_NoCircularContainment(including, diagnostics, context)) return false; |
| boolean result = validate_EveryMultiplicityConforms(including, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryDataValueConforms(including, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryReferenceIsContained(including, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryBidirectionalReferenceIsPaired(including, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryProxyResolves(including, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_UniqueID(including, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryKeyUnique(including, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryMapEntryUnique(including, diagnostics, context); |
| if (result || diagnostics != null) result &= validateCollectionExpressionWithArgument_ArgumentTypeMustConformToCollectionExpressionType(including, diagnostics, context); |
| return result; |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| public boolean validateExcluding(Excluding excluding, DiagnosticChain diagnostics, Map<Object, Object> context) { |
| if (!validate_NoCircularContainment(excluding, diagnostics, context)) return false; |
| boolean result = validate_EveryMultiplicityConforms(excluding, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryDataValueConforms(excluding, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryReferenceIsContained(excluding, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryBidirectionalReferenceIsPaired(excluding, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryProxyResolves(excluding, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_UniqueID(excluding, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryKeyUnique(excluding, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryMapEntryUnique(excluding, diagnostics, context); |
| if (result || diagnostics != null) result &= validateCollectionExpressionWithArgument_ArgumentTypeMustConformToCollectionExpressionType(excluding, diagnostics, context); |
| return result; |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| public boolean validateIncludingAt(IncludingAt includingAt, DiagnosticChain diagnostics, Map<Object, Object> context) { |
| if (!validate_NoCircularContainment(includingAt, diagnostics, context)) return false; |
| boolean result = validate_EveryMultiplicityConforms(includingAt, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryDataValueConforms(includingAt, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryReferenceIsContained(includingAt, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryBidirectionalReferenceIsPaired(includingAt, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryProxyResolves(includingAt, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_UniqueID(includingAt, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryKeyUnique(includingAt, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryMapEntryUnique(includingAt, diagnostics, context); |
| if (result || diagnostics != null) result &= validateCollectionExpressionWithArgument_ArgumentTypeMustConformToCollectionExpressionType(includingAt, diagnostics, context); |
| if (result || diagnostics != null) result &= validateWithPosition_SourceMustBeOrdered(includingAt, diagnostics, context); |
| return result; |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| public boolean validateIterate(Iterate iterate, DiagnosticChain diagnostics, Map<Object, Object> context) { |
| if (!validate_NoCircularContainment(iterate, diagnostics, context)) return false; |
| boolean result = validate_EveryMultiplicityConforms(iterate, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryDataValueConforms(iterate, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryReferenceIsContained(iterate, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryBidirectionalReferenceIsPaired(iterate, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryProxyResolves(iterate, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_UniqueID(iterate, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryKeyUnique(iterate, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryMapEntryUnique(iterate, diagnostics, context); |
| if (result || diagnostics != null) result &= validateIterate_AccumulatorTypeEqualsExpressionType(iterate, diagnostics, context); |
| return result; |
| } |
| |
| /** |
| * The cached validation expression for the AccumulatorTypeEqualsExpressionType constraint of '<em>Iterate</em>'. |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| protected static final String ITERATE__ACCUMULATOR_TYPE_EQUALS_EXPRESSION_TYPE__EEXPRESSION = "self.accumulator->notEmpty() implies\r\n" + |
| " (self.accumulator.ownedTypeDefinition->notEmpty() implies\r\n" + |
| " self.accumulator.ownedTypeDefinition.conformsTo(self.iteratorExpression.getType()))"; |
| |
| /** |
| * Validates the AccumulatorTypeEqualsExpressionType constraint of '<em>Iterate</em>'. |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| public boolean validateIterate_AccumulatorTypeEqualsExpressionType(Iterate iterate, DiagnosticChain diagnostics, Map<Object, Object> context) { |
| return |
| validate |
| (CollectionexpressionsPackage.Literals.ITERATE, |
| iterate, |
| diagnostics, |
| context, |
| "http://www.eclipse.org/emf/2002/Ecore/OCL", |
| "AccumulatorTypeEqualsExpressionType", |
| ITERATE__ACCUMULATOR_TYPE_EQUALS_EXPRESSION_TYPE__EEXPRESSION, |
| Diagnostic.ERROR, |
| DIAGNOSTIC_SOURCE, |
| 0); |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| public boolean validateCollectionExpression(CollectionExpression collectionExpression, DiagnosticChain diagnostics, Map<Object, Object> context) { |
| return validate_EveryDefaultConstraint(collectionExpression, diagnostics, context); |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| public boolean validateExcludingAt(ExcludingAt excludingAt, DiagnosticChain diagnostics, Map<Object, Object> context) { |
| if (!validate_NoCircularContainment(excludingAt, diagnostics, context)) return false; |
| boolean result = validate_EveryMultiplicityConforms(excludingAt, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryDataValueConforms(excludingAt, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryReferenceIsContained(excludingAt, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryBidirectionalReferenceIsPaired(excludingAt, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryProxyResolves(excludingAt, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_UniqueID(excludingAt, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryKeyUnique(excludingAt, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryMapEntryUnique(excludingAt, diagnostics, context); |
| if (result || diagnostics != null) result &= validateCollectionExpressionWithArgument_ArgumentTypeMustConformToCollectionExpressionType(excludingAt, diagnostics, context); |
| if (result || diagnostics != null) result &= validateWithPosition_SourceMustBeOrdered(excludingAt, diagnostics, context); |
| return result; |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| public boolean validateWithPosition(WithPosition withPosition, DiagnosticChain diagnostics, Map<Object, Object> context) { |
| if (!validate_NoCircularContainment(withPosition, diagnostics, context)) return false; |
| boolean result = validate_EveryMultiplicityConforms(withPosition, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryDataValueConforms(withPosition, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryReferenceIsContained(withPosition, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryBidirectionalReferenceIsPaired(withPosition, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryProxyResolves(withPosition, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_UniqueID(withPosition, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryKeyUnique(withPosition, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryMapEntryUnique(withPosition, diagnostics, context); |
| if (result || diagnostics != null) result &= validateWithPosition_SourceMustBeOrdered(withPosition, diagnostics, context); |
| return result; |
| } |
| |
| /** |
| * The cached validation expression for the SourceMustBeOrdered constraint of '<em>With Position</em>'. |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| protected static final String WITH_POSITION__SOURCE_MUST_BE_ORDERED__EEXPRESSION = "self.argument.getType().ordered"; |
| |
| /** |
| * Validates the SourceMustBeOrdered constraint of '<em>With Position</em>'. |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| public boolean validateWithPosition_SourceMustBeOrdered(WithPosition withPosition, DiagnosticChain diagnostics, Map<Object, Object> context) { |
| return |
| validate |
| (CollectionexpressionsPackage.Literals.WITH_POSITION, |
| withPosition, |
| diagnostics, |
| context, |
| "http://www.eclipse.org/emf/2002/Ecore/OCL", |
| "SourceMustBeOrdered", |
| WITH_POSITION__SOURCE_MUST_BE_ORDERED__EEXPRESSION, |
| Diagnostic.ERROR, |
| DIAGNOSTIC_SOURCE, |
| 0); |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| public boolean validateCollectionExpressionWithArgument(CollectionExpressionWithArgument collectionExpressionWithArgument, DiagnosticChain diagnostics, Map<Object, Object> context) { |
| if (!validate_NoCircularContainment(collectionExpressionWithArgument, diagnostics, context)) return false; |
| boolean result = validate_EveryMultiplicityConforms(collectionExpressionWithArgument, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryDataValueConforms(collectionExpressionWithArgument, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryReferenceIsContained(collectionExpressionWithArgument, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryBidirectionalReferenceIsPaired(collectionExpressionWithArgument, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryProxyResolves(collectionExpressionWithArgument, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_UniqueID(collectionExpressionWithArgument, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryKeyUnique(collectionExpressionWithArgument, diagnostics, context); |
| if (result || diagnostics != null) result &= validate_EveryMapEntryUnique(collectionExpressionWithArgument, diagnostics, context); |
| if (result || diagnostics != null) result &= validateCollectionExpressionWithArgument_ArgumentTypeMustConformToCollectionExpressionType(collectionExpressionWithArgument, diagnostics, context); |
| return result; |
| } |
| |
| /** |
| * The cached validation expression for the ArgumentTypeMustConformToCollectionExpressionType constraint of '<em>Collection Expression With Argument</em>'. |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| protected static final String COLLECTION_EXPRESSION_WITH_ARGUMENT__ARGUMENT_TYPE_MUST_CONFORM_TO_COLLECTION_EXPRESSION_TYPE__EEXPRESSION = "let snl : Integer = source.getType().getNestingLevel() in let anl : Integer = argument.getType().getNestingLevel() in\r\n" + |
| " if snl = anl then\r\n" + |
| " source.getType().conformsToIgnoringMultiplicity(argument.getType())\r\n" + |
| " else\r\n" + |
| " if snl = (anl + 1) then\r\n" + |
| " source.getType().oclAsType(data::classes::NestedTypeDefinition).type.conformsToIgnoringMultiplicity(argument.getType())\r\n" + |
| " else\r\n" + |
| " if (snl + 1) = anl then\r\n" + |
| " source.getType().conformsToIgnoringMultiplicity(argument.getType().oclAsType(data::classes::NestedTypeDefinition).type)\r\n" + |
| " else\r\n" + |
| " false\r\n" + |
| " endif\r\n" + |
| " endif\r\n" + |
| " endif"; |
| |
| /** |
| * Validates the ArgumentTypeMustConformToCollectionExpressionType constraint of '<em>Collection Expression With Argument</em>'. |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| public boolean validateCollectionExpressionWithArgument_ArgumentTypeMustConformToCollectionExpressionType(CollectionExpressionWithArgument collectionExpressionWithArgument, DiagnosticChain diagnostics, Map<Object, Object> context) { |
| return |
| validate |
| (CollectionexpressionsPackage.Literals.COLLECTION_EXPRESSION_WITH_ARGUMENT, |
| collectionExpressionWithArgument, |
| diagnostics, |
| context, |
| "http://www.eclipse.org/emf/2002/Ecore/OCL", |
| "ArgumentTypeMustConformToCollectionExpressionType", |
| COLLECTION_EXPRESSION_WITH_ARGUMENT__ARGUMENT_TYPE_MUST_CONFORM_TO_COLLECTION_EXPRESSION_TYPE__EEXPRESSION, |
| Diagnostic.ERROR, |
| DIAGNOSTIC_SOURCE, |
| 0); |
| } |
| |
| /** |
| * Returns the resource locator that will be used to fetch messages for this validator's diagnostics. |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| @Override |
| public ResourceLocator getResourceLocator() { |
| // TODO |
| // Specialize this to return a resource locator for messages specific to this validator. |
| // Ensure that you remove @generated or mark it @generated NOT |
| return super.getResourceLocator(); |
| } |
| |
| } //CollectionexpressionsValidator |