/*-
* ============LICENSE_START==========================================
* OPENECOMP - DCAE
* ===================================================================
* Copyright (c) 2017 AT&T Intellectual Property. All rights reserved.
* ===================================================================
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
* ============LICENSE_END============================================
*/
/**
*/
package org.openecomp.ncomp.sirius.manager.swagger.impl;
import org.openecomp.ncomp.sirius.manager.swagger.SwaggerObjectType;
import org.openecomp.ncomp.sirius.manager.swagger.SwaggerPackage;
import org.openecomp.ncomp.sirius.manager.swagger.SwaggerReferenceObjectType;
import org.eclipse.emf.common.notify.Notification;
import org.eclipse.emf.ecore.EClass;
import org.eclipse.emf.ecore.InternalEObject;
import org.eclipse.emf.ecore.impl.ENotificationImpl;
/**
*
* An implementation of the model object 'Reference Object Type'.
*
*
* The following features are implemented:
*
* - {@link org.openecomp.ncomp.sirius.manager.swagger.impl.SwaggerReferenceObjectTypeImpl#isRequired Required}
* - {@link org.openecomp.ncomp.sirius.manager.swagger.impl.SwaggerReferenceObjectTypeImpl#getReference Reference}
*
*
*
* @generated
*/
public class SwaggerReferenceObjectTypeImpl extends SwaggerNamedObjectTypeImpl implements SwaggerReferenceObjectType {
/**
* The default value of the '{@link #isRequired() Required}' attribute.
*
*
* @see #isRequired()
* @generated
* @ordered
*/
protected static final boolean REQUIRED_EDEFAULT = false;
/**
* The cached value of the '{@link #isRequired() Required}' attribute.
*
*
* @see #isRequired()
* @generated
* @ordered
*/
protected boolean required = REQUIRED_EDEFAULT;
/**
* The cached value of the '{@link #getReference() Reference}' reference.
*
*
* @see #getReference()
* @generated
* @ordered
*/
protected SwaggerObjectType reference;
/**
*
*
* @generated
*/
protected SwaggerReferenceObjectTypeImpl() {
super();
}
/**
*
*
* @generated
*/
@Override
protected EClass eStaticClass() {
return SwaggerPackage.Literals.SWAGGER_REFERENCE_OBJECT_TYPE;
}
/**
*
*
* @generated
*/
public boolean isRequired() {
return required;
}
/**
*
*
* @generated
*/
public void setRequired(boolean newRequired) {
boolean oldRequired = required;
required = newRequired;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, SwaggerPackage.SWAGGER_REFERENCE_OBJECT_TYPE__REQUIRED, oldRequired, required));
}
/**
*
*
* @generated
*/
public SwaggerObjectType getReference() {
if (reference != null && reference.eIsProxy()) {
InternalEObject oldReference = (InternalEObject)reference;
reference = (SwaggerObjectType)eResolveProxy(oldReference);
if (reference != oldReference) {
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.RESOLVE, SwaggerPackage.SWAGGER_REFERENCE_OBJECT_TYPE__REFERENCE, oldReference, reference));
}
}
return reference;
}
/**
*
*
* @generated
*/
public SwaggerObjectType basicGetReference() {
return reference;
}
/**
*
*
* @generated
*/
public void setReference(SwaggerObjectType newReference) {
SwaggerObjectType oldReference = reference;
reference = newReference;
if (eNotificationRequired())
eNotify(new ENotificationImpl(this, Notification.SET, SwaggerPackage.SWAGGER_REFERENCE_OBJECT_TYPE__REFERENCE, oldReference, reference));
}
/**
*
*
* @generated
*/
@Override
public Object eGet(int featureID, boolean resolve, boolean coreType) {
switch (featureID) {
case SwaggerPackage.SWAGGER_REFERENCE_OBJECT_TYPE__REQUIRED:
return isRequired();
case SwaggerPackage.SWAGGER_REFERENCE_OBJECT_TYPE__REFERENCE:
if (resolve) return getReference();
return basicGetReference();
}
return super.eGet(featureID, resolve, coreType);
}
/**
*
*
* @generated
*/
@Override
public void eSet(int featureID, Object newValue) {
switch (featureID) {
case SwaggerPackage.SWAGGER_REFERENCE_OBJECT_TYPE__REQUIRED:
setRequired((Boolean)newValue);
return;
case SwaggerPackage.SWAGGER_REFERENCE_OBJECT_TYPE__REFERENCE:
setReference((SwaggerObjectType)newValue);
return;
}
super.eSet(featureID, newValue);
}
/**
*
*
* @generated
*/
@Override
public void eUnset(int featureID) {
switch (featureID) {
case SwaggerPackage.SWAGGER_REFERENCE_OBJECT_TYPE__REQUIRED:
setRequired(REQUIRED_EDEFAULT);
return;
case SwaggerPackage.SWAGGER_REFERENCE_OBJECT_TYPE__REFERENCE:
setReference((SwaggerObjectType)null);
return;
}
super.eUnset(featureID);
}
/**
*
*
* @generated
*/
@Override
public boolean eIsSet(int featureID) {
switch (featureID) {
case SwaggerPackage.SWAGGER_REFERENCE_OBJECT_TYPE__REQUIRED:
return required != REQUIRED_EDEFAULT;
case SwaggerPackage.SWAGGER_REFERENCE_OBJECT_TYPE__REFERENCE:
return reference != null;
}
return super.eIsSet(featureID);
}
/**
*
*
* @generated
*/
@Override
public String toString() {
if (eIsProxy()) return super.toString();
StringBuffer result = new StringBuffer(super.toString());
result.append(" (required: ");
result.append(required);
result.append(')');
return result.toString();
}
} //SwaggerReferenceObjectTypeImpl