blob: 8d3fc497ba71860689ac46b2b6b05b8facdf2c27 [file] [log] [blame]
/**
*
* Copyright (c) 2009-2010 Thales Corporate Services S.A.S.
* All rights reserved. This program and the accompanying materials
* are made available under the terms of the Eclipse Public License v1.0
* which accompanies this distribution, and is available at
* http://www.eclipse.org/legal/epl-v10.html
*
* Contributors:
* Thales Corporate Services S.A.S - initial API and implementation
*
*/
package org.eclipse.egf.model.domain.util;
import java.util.Iterator;
import java.util.Map;
import org.eclipse.core.runtime.IStatus;
import org.eclipse.core.runtime.NullProgressMonitor;
import org.eclipse.core.runtime.Status;
import org.eclipse.egf.model.EGFModelPlugin;
import org.eclipse.egf.model.domain.Domain;
import org.eclipse.egf.model.domain.DomainEPackage;
import org.eclipse.egf.model.domain.DomainPackage;
import org.eclipse.egf.model.domain.DomainURI;
import org.eclipse.egf.model.domain.DomainViewpoint;
import org.eclipse.egf.model.domain.TypeDomainEPackage;
import org.eclipse.egf.model.domain.TypeDomainURI;
import org.eclipse.egf.model.types.util.TypesValidator;
import org.eclipse.emf.common.util.BasicDiagnostic;
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.EClass;
import org.eclipse.emf.ecore.EObject;
import org.eclipse.emf.ecore.EPackage;
import org.eclipse.emf.ecore.util.EObjectValidator;
import org.eclipse.emf.ecore.util.EcoreUtil;
import org.eclipse.emf.validation.model.EvaluationMode;
import org.eclipse.emf.validation.model.IConstraintStatus;
import org.eclipse.emf.validation.service.IBatchValidator;
import org.eclipse.emf.validation.service.ModelValidationService;
import org.eclipse.emf.validation.service.ITraversalStrategy.Recursive;
/**
* <!-- begin-user-doc -->
* The <b>Validator</b> for the model.
* <!-- end-user-doc -->
*
* @see org.eclipse.egf.model.domain.DomainPackage
* @generated
*/
public class DomainValidator extends EObjectValidator {
/**
* The cached model package
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@SuppressWarnings("hiding")
public static final DomainValidator INSTANCE = new DomainValidator();
/**
* 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
*/
@SuppressWarnings("hiding")
public static final String DIAGNOSTIC_SOURCE = "org.eclipse.egf.model.domain"; //$NON-NLS-1$
/**
* 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;
/**
* Model Validation Service interface for batch validation of EMF elements.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
private final IBatchValidator batchValidator;
/**
* The cached base package validator.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
protected TypesValidator typesValidator;
/**
* Creates an instance of the switch.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
public DomainValidator() {
super();
typesValidator = TypesValidator.INSTANCE;
batchValidator = (IBatchValidator) ModelValidationService.getInstance().newValidator(EvaluationMode.BATCH);
batchValidator.setTraversalStrategy(new Recursive());
batchValidator.setIncludeLiveConstraints(true);
batchValidator.setReportSuccesses(false);
}
/**
* Returns the package of this validator switch.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
protected EPackage getEPackage() {
return DomainPackage.eINSTANCE;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
@Override
public boolean validate(EClass eClass, EObject eObject, DiagnosticChain diagnostics, Map<Object, Object> context) {
IStatus status = Status.OK_STATUS;
// do whatever the basic EcoreValidator does
super.validate(eClass, eObject, diagnostics, context);
// no point in validating if we can't report results
if (diagnostics != null) {
// if EMF Mode Validation Service already covered the sub-tree,
// which it does for efficient computation and error reporting,
// then don't repeat (the Diagnostician does the recursion
// externally). If there is no context map, then we can't
// help it
if (hasProcessed(eObject, context) == false) {
status = batchValidator.validate(eObject, new NullProgressMonitor());
processed(eObject, context, status);
appendDiagnostics(status, diagnostics);
}
}
return status.isOK();
}
/**
* 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 DomainPackage.DOMAIN_VIEWPOINT:
return validateDomainViewpoint((DomainViewpoint) value, diagnostics, context);
case DomainPackage.DOMAIN:
return validateDomain((Domain) value, diagnostics, context);
case DomainPackage.DOMAIN_EPACKAGE:
return validateDomainEPackage((DomainEPackage) value, diagnostics, context);
case DomainPackage.TYPE_DOMAIN_EPACKAGE:
return validateTypeDomainEPackage((TypeDomainEPackage) value, diagnostics, context);
case DomainPackage.DOMAIN_URI:
return validateDomainURI((DomainURI) value, diagnostics, context);
case DomainPackage.TYPE_DOMAIN_URI:
return validateTypeDomainURI((TypeDomainURI) value, diagnostics, context);
default:
return true;
}
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
public boolean validateDomainViewpoint(DomainViewpoint domainViewpoint, DiagnosticChain diagnostics, Map<Object, Object> context) {
return validate_EveryDefaultConstraint(domainViewpoint, diagnostics, context);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
public boolean validateDomain(Domain domain, DiagnosticChain diagnostics, Map<Object, Object> context) {
return validate_EveryDefaultConstraint(domain, diagnostics, context);
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
public boolean validateDomainEPackage(DomainEPackage domainEPackage, DiagnosticChain diagnostics, Map<Object, Object> context) {
boolean result = validate_EveryMultiplicityConforms(domainEPackage, diagnostics, context);
if (result || diagnostics != null)
result &= validate_EveryDataValueConforms(domainEPackage, diagnostics, context);
if (result || diagnostics != null)
result &= validate_EveryReferenceIsContained(domainEPackage, diagnostics, context);
if (result || diagnostics != null)
result &= validate_EveryProxyResolves(domainEPackage, diagnostics, context);
if (result || diagnostics != null)
result &= validate_UniqueID(domainEPackage, diagnostics, context);
if (result || diagnostics != null)
result &= validate_EveryKeyUnique(domainEPackage, diagnostics, context);
if (result || diagnostics != null)
result &= validate_EveryMapEntryUnique(domainEPackage, diagnostics, context);
if (result || diagnostics != null)
result &= validateDomainEPackage_ValidPackage(domainEPackage, diagnostics, context);
return result;
}
/**
* Validates the ValidPackage constraint of '<em>EPackage</em>'.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated NOT
*/
public boolean validateDomainEPackage_ValidPackage(DomainEPackage domainEPackage, DiagnosticChain diagnostics, Map<Object, Object> context) {
if (domainEPackage.getEPackage() == null) {
return true;
}
if (EPackage.Registry.INSTANCE.get(domainEPackage.getEPackage().getNsURI()) == null) {
if (diagnostics != null) {
diagnostics.add(createDiagnostic(Diagnostic.ERROR, DIAGNOSTIC_SOURCE, 0, "_UI_EGFConstraint_diagnostic", //$NON-NLS-1$
new Object[] { "ValidPackage", getObjectLabel(domainEPackage, context), "Unknown EPackage in EPackage.Registry" }, //$NON-NLS-1$ //$NON-NLS-2$
new Object[] { domainEPackage }, context));
}
return false;
}
return true;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
public boolean validateTypeDomainEPackage(TypeDomainEPackage typeDomainEPackage, DiagnosticChain diagnostics, Map<Object, Object> context) {
boolean result = validate_EveryMultiplicityConforms(typeDomainEPackage, diagnostics, context);
if (result || diagnostics != null)
result &= validate_EveryDataValueConforms(typeDomainEPackage, diagnostics, context);
if (result || diagnostics != null)
result &= validate_EveryReferenceIsContained(typeDomainEPackage, diagnostics, context);
if (result || diagnostics != null)
result &= validate_EveryProxyResolves(typeDomainEPackage, diagnostics, context);
if (result || diagnostics != null)
result &= validate_UniqueID(typeDomainEPackage, diagnostics, context);
if (result || diagnostics != null)
result &= validate_EveryKeyUnique(typeDomainEPackage, diagnostics, context);
if (result || diagnostics != null)
result &= validate_EveryMapEntryUnique(typeDomainEPackage, diagnostics, context);
if (result || diagnostics != null)
result &= typesValidator.validateTypeObject_ValidValue(typeDomainEPackage, diagnostics, context);
return result;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
public boolean validateDomainURI(DomainURI domainURI, DiagnosticChain diagnostics, Map<Object, Object> context) {
boolean result = validate_EveryMultiplicityConforms(domainURI, diagnostics, context);
if (result || diagnostics != null)
result &= validate_EveryDataValueConforms(domainURI, diagnostics, context);
if (result || diagnostics != null)
result &= validate_EveryReferenceIsContained(domainURI, diagnostics, context);
if (result || diagnostics != null)
result &= validate_EveryProxyResolves(domainURI, diagnostics, context);
if (result || diagnostics != null)
result &= validate_UniqueID(domainURI, diagnostics, context);
if (result || diagnostics != null)
result &= validate_EveryKeyUnique(domainURI, diagnostics, context);
if (result || diagnostics != null)
result &= validate_EveryMapEntryUnique(domainURI, diagnostics, context);
if (result || diagnostics != null)
result &= validateDomainURI_ValidURI(domainURI, diagnostics, context);
return result;
}
/**
* Validates the ValidURI constraint of '<em>URI</em>'.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated NOT
*/
public boolean validateDomainURI_ValidURI(DomainURI domainURI, DiagnosticChain diagnostics, Map<Object, Object> context) {
// if (domainURI.eResource() == null || domainURI.getUri() == null) {
// return true;
// }
// URI contentURI = domainURI.getUri();
// if (contentURI.isRelative()) {
// contentURI = contentURI.resolve(domainURI.eResource().getURI());
// }
// contentURI = CommonPlugin.asLocalURI(contentURI);
boolean valid = true;
// Try to load this URI
// String location = contentURI.toFileString();
// if (location != null) {
// File file = new File(location);
// if (file.canRead()) {
// valid = true;
// }
// }
if (valid == false) {
if (diagnostics != null) {
diagnostics.add(createDiagnostic(Diagnostic.ERROR, DIAGNOSTIC_SOURCE, 0, "_UI_GenericConstraint_diagnostic", //$NON-NLS-1$
new Object[] { "ValidURI", getObjectLabel(domainURI, context) }, //$NON-NLS-1$
new Object[] { domainURI }, context));
}
return false;
}
return true;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
public boolean validateTypeDomainURI(TypeDomainURI typeDomainURI, DiagnosticChain diagnostics, Map<Object, Object> context) {
boolean result = validate_EveryMultiplicityConforms(typeDomainURI, diagnostics, context);
if (result || diagnostics != null)
result &= validate_EveryDataValueConforms(typeDomainURI, diagnostics, context);
if (result || diagnostics != null)
result &= validate_EveryReferenceIsContained(typeDomainURI, diagnostics, context);
if (result || diagnostics != null)
result &= validate_EveryProxyResolves(typeDomainURI, diagnostics, context);
if (result || diagnostics != null)
result &= validate_UniqueID(typeDomainURI, diagnostics, context);
if (result || diagnostics != null)
result &= validate_EveryKeyUnique(typeDomainURI, diagnostics, context);
if (result || diagnostics != null)
result &= validate_EveryMapEntryUnique(typeDomainURI, diagnostics, context);
if (result || diagnostics != null)
result &= typesValidator.validateTypeObject_ValidValue(typeDomainURI, diagnostics, context);
if (result || diagnostics != null)
result &= validateTypeDomainURI_ValidDomainURI(typeDomainURI, diagnostics, context);
return result;
}
/**
* Validates the ValidDomainURI constraint of '<em>Type Domain URI</em>'.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
*
* @generated
*/
public boolean validateTypeDomainURI_ValidDomainURI(TypeDomainURI typeDomainURI, DiagnosticChain diagnostics, Map<Object, Object> context) {
if (typeDomainURI.eResource() == null || typeDomainURI.getDomain() == null) {
return true;
}
boolean found = false;
for (Iterator<EObject> iterator = EcoreUtil.getAllProperContents(typeDomainURI.eResource(), false); iterator.hasNext();) {
EObject eObject = iterator.next();
if (eObject instanceof DomainURI && eObject == typeDomainURI.getDomain()) {
found = true;
break;
}
}
if (found == false) {
if (diagnostics != null) {
diagnostics.add(createDiagnostic(Diagnostic.ERROR, DIAGNOSTIC_SOURCE, 0, "_UI_EGFConstraint_diagnostic", //$NON-NLS-1$
new Object[] { "ValidDomainURI", getObjectLabel(typeDomainURI, context), "Unknown Domain URI in this resource" }, //$NON-NLS-1$ //$NON-NLS-2$
new Object[] { typeDomainURI }, context));
}
return false;
}
return true;
}
/**
* 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() {
return EGFModelPlugin.INSTANCE;
}
/**
* If we have a context map, record this object's <code>status</code> in it
* so that we will know later that we have processed it and its sub-tree.
*
* @param eObject
* an element that we have validated
* @param context
* the context (may be <code>null</code>)
* @param status
* the element's validation status
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
private void processed(EObject eObject, Map<Object, Object> context, IStatus status) {
if (context != null) {
context.put(eObject, status);
}
}
/**
* Determines whether we have processed this <code>eObject</code> before,
* by automatic recursion of the EMF Model Validation Service. This is
* only possible if we do, indeed, have a context.
*
* @param eObject
* an element to be validated (we hope not)
* @param context
* the context (may be <code>null</code>)
* @return <code>true</code> if the context is not <code>null</code> and
* the <code>eObject</code> or one of its containers has already been
* validated; <code>false</code>, otherwise
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
private boolean hasProcessed(EObject eObject, Map<Object, Object> context) {
boolean result = false;
if (context != null) {
// this is O(NlogN) but there's no helping it
while (eObject != null) {
if (context.containsKey(eObject)) {
result = true;
eObject = null;
} else {
eObject = eObject.eContainer();
}
}
}
return result;
}
/**
* Converts a status result from the EMF validation service to diagnostics.
*
* @param status
* the EMF validation service's status result
* @param diagnostics
* a diagnostic chain to accumulate results on
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
private void appendDiagnostics(IStatus status, DiagnosticChain diagnostics) {
if (status.isMultiStatus()) {
IStatus[] children = status.getChildren();
for (int i = 0; i < children.length; i++) {
appendDiagnostics(children[i], diagnostics);
}
} else if (status instanceof IConstraintStatus) {
diagnostics.add(new BasicDiagnostic(status.getSeverity(), status.getPlugin(), status.getCode(), status.getMessage(), ((IConstraintStatus) status).getResultLocus().toArray()));
}
}
} // DomainValidator