/**
* Copyright (c) 2015-2016 Obeo, Inria
* 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:
* - William Piers <william.piers@obeo.fr>
* - Philippe Merle <philippe.merle@inria.fr>
*/
package servicelevelagreements.util;
import java.util.Map;
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;
import org.eclipse.emf.ecore.xml.type.util.XMLTypeUtil;
import org.occiware.clouddesigner.occi.util.OCCIValidator;
import servicelevelagreements.*;
/**
* <!-- begin-user-doc -->
* The <b>Validator</b> for the model.
* <!-- end-user-doc -->
* @see servicelevelagreements.ServicelevelagreementsPackage
* @generated
*/
public class ServicelevelagreementsValidator extends EObjectValidator {
/**
* The cached model package
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public static final ServicelevelagreementsValidator INSTANCE = new ServicelevelagreementsValidator();
/**
* 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 = "servicelevelagreements";
/**
* 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;
/**
* The cached base package validator.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
protected OCCIValidator occiValidator;
/**
* Creates an instance of the switch.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public ServicelevelagreementsValidator() {
super();
occiValidator = OCCIValidator.INSTANCE;
}
/**
* Returns the package of this validator switch.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
@Override
protected EPackage getEPackage() {
return ServicelevelagreementsPackage.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 ServicelevelagreementsPackage.AGREEMENT:
return validateAgreement((Agreement)value, diagnostics, context);
case ServicelevelagreementsPackage.AGREEMENT_LINK:
return validateAgreement_link((Agreement_link)value, diagnostics, context);
case ServicelevelagreementsPackage.AGREEMENT_STATUS:
return validateAgreementStatus((AgreementStatus)value, diagnostics, context);
case ServicelevelagreementsPackage.AGREEMENT_TERM_TYPE:
return validateAgreementTermType((AgreementTermType)value, diagnostics, context);
case ServicelevelagreementsPackage.AGREEMENT_TERM_STATUS:
return validateAgreementTermStatus((AgreementTermStatus)value, diagnostics, context);
case ServicelevelagreementsPackage.DATE_TIME:
return validateDateTime((String)value, diagnostics, context);
default:
return true;
}
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public boolean validateAgreement(Agreement agreement, DiagnosticChain diagnostics, Map<Object, Object> context) {
if (!validate_NoCircularContainment(agreement, diagnostics, context)) return false;
boolean result = validate_EveryMultiplicityConforms(agreement, diagnostics, context);
if (result || diagnostics != null) result &= validate_EveryDataValueConforms(agreement, diagnostics, context);
if (result || diagnostics != null) result &= validate_EveryReferenceIsContained(agreement, diagnostics, context);
if (result || diagnostics != null) result &= validate_EveryBidirectionalReferenceIsPaired(agreement, diagnostics, context);
if (result || diagnostics != null) result &= validate_EveryProxyResolves(agreement, diagnostics, context);
if (result || diagnostics != null) result &= validate_UniqueID(agreement, diagnostics, context);
if (result || diagnostics != null) result &= validate_EveryKeyUnique(agreement, diagnostics, context);
if (result || diagnostics != null) result &= validate_EveryMapEntryUnique(agreement, diagnostics, context);
if (result || diagnostics != null) result &= occiValidator.validateEntity_IdUnique(agreement, diagnostics, context);
if (result || diagnostics != null) result &= occiValidator.validateEntity_AttributesNameUnique(agreement, diagnostics, context);
if (result || diagnostics != null) result &= occiValidator.validateEntity_KindCompatibleWithOneAppliesOfEachMixin(agreement, diagnostics, context);
if (result || diagnostics != null) result &= occiValidator.validateResource_ResourceKindIsInParent(agreement, diagnostics, context);
return result;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public boolean validateAgreement_link(Agreement_link agreement_link, DiagnosticChain diagnostics, Map<Object, Object> context) {
if (!validate_NoCircularContainment(agreement_link, diagnostics, context)) return false;
boolean result = validate_EveryMultiplicityConforms(agreement_link, diagnostics, context);
if (result || diagnostics != null) result &= validate_EveryDataValueConforms(agreement_link, diagnostics, context);
if (result || diagnostics != null) result &= validate_EveryReferenceIsContained(agreement_link, diagnostics, context);
if (result || diagnostics != null) result &= validate_EveryBidirectionalReferenceIsPaired(agreement_link, diagnostics, context);
if (result || diagnostics != null) result &= validate_EveryProxyResolves(agreement_link, diagnostics, context);
if (result || diagnostics != null) result &= validate_UniqueID(agreement_link, diagnostics, context);
if (result || diagnostics != null) result &= validate_EveryKeyUnique(agreement_link, diagnostics, context);
if (result || diagnostics != null) result &= validate_EveryMapEntryUnique(agreement_link, diagnostics, context);
if (result || diagnostics != null) result &= occiValidator.validateEntity_IdUnique(agreement_link, diagnostics, context);
if (result || diagnostics != null) result &= occiValidator.validateEntity_AttributesNameUnique(agreement_link, diagnostics, context);
if (result || diagnostics != null) result &= occiValidator.validateEntity_KindCompatibleWithOneAppliesOfEachMixin(agreement_link, diagnostics, context);
if (result || diagnostics != null) result &= occiValidator.validateLink_LinkKindIsInParent(agreement_link, diagnostics, context);
return result;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public boolean validateAgreementStatus(AgreementStatus agreementStatus, DiagnosticChain diagnostics, Map<Object, Object> context) {
return true;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public boolean validateAgreementTermType(AgreementTermType agreementTermType, DiagnosticChain diagnostics, Map<Object, Object> context) {
return true;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public boolean validateAgreementTermStatus(AgreementTermStatus agreementTermStatus, DiagnosticChain diagnostics, Map<Object, Object> context) {
return true;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public boolean validateDateTime(String dateTime, DiagnosticChain diagnostics, Map<Object, Object> context) {
boolean result = validateDateTime_Pattern(dateTime, diagnostics, context);
return result;
}
/**
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
* @see #validateDateTime_Pattern
*/
public static final PatternMatcher [][] DATE_TIME__PATTERN__VALUES =
new PatternMatcher [][] {
new PatternMatcher [] {
XMLTypeUtil.createPatternMatcher("^(\\d{4}((-)?(0[1-9]|1[0-2])((-)?(0[1-9]|[1-2][0-9]|3[0-1])(T(24:00(:00(\\.[0]+)?)?|(([0-1][0-9]|2[0-3])(:)[0-5][0-9])((:)[0-5][0-9](\\.[\\d]+)?)?)((\\+|-)(14:00|(0[0-9]|1[0-3])(:)[0-5][0-9])|Z))?)?)?)$")
}
};
/**
* Validates the Pattern constraint of '<em>Date Time</em>'.
* <!-- begin-user-doc -->
* <!-- end-user-doc -->
* @generated
*/
public boolean validateDateTime_Pattern(String dateTime, DiagnosticChain diagnostics, Map<Object, Object> context) {
return validatePattern(ServicelevelagreementsPackage.Literals.DATE_TIME, dateTime, DATE_TIME__PATTERN__VALUES, diagnostics, context);
}
/**
* 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();
}
} //ServicelevelagreementsValidator