blob: 05359d8a202eeae0d3fb5fab6d7ec1c618802995 [file] [log] [blame]
/**
* <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