| /******************************************************************************* |
| * Copyright (c) 2001, 2006 IBM Corporation and others. |
| * 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: |
| * IBM Corporation - initial API and implementation |
| *******************************************************************************/ |
| package org.eclipse.jst.j2ee.taglib.internal.impl; |
| |
| import java.util.Collection; |
| |
| import org.eclipse.emf.common.notify.Notification; |
| import org.eclipse.emf.common.notify.NotificationChain; |
| import org.eclipse.emf.common.util.EList; |
| import org.eclipse.emf.ecore.EClass; |
| import org.eclipse.emf.ecore.InternalEObject; |
| import org.eclipse.emf.ecore.impl.ENotificationImpl; |
| import org.eclipse.emf.ecore.util.EObjectContainmentEList; |
| import org.eclipse.emf.ecore.util.InternalEList; |
| import org.eclipse.jem.java.JavaClass; |
| import org.eclipse.jst.j2ee.common.Description; |
| import org.eclipse.jst.j2ee.common.internal.impl.J2EEEObjectImpl; |
| import org.eclipse.jst.j2ee.taglib.internal.JSPTagAttribute; |
| import org.eclipse.jst.j2ee.taglib.internal.TaglibPackage; |
| |
| |
| /** |
| * The attribute tag defines an attribute for the nesting tag |
| * @generated |
| */ |
| public class JSPTagAttributeImpl extends J2EEEObjectImpl implements JSPTagAttribute { |
| |
| /** |
| * The default value of the '{@link #getName() <em>Name</em>}' attribute. |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @see #getName() |
| * @generated |
| * @ordered |
| */ |
| protected static final String NAME_EDEFAULT = null; |
| |
| /** |
| * @generated This field/method will be replaced during code generation. |
| */ |
| /** |
| * @generated This field/method will be replaced during code generation. |
| */ |
| protected String name = NAME_EDEFAULT; |
| /** |
| * The default value of the '{@link #isRequired() <em>Required</em>}' attribute. |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @see #isRequired() |
| * @generated |
| * @ordered |
| */ |
| protected static final boolean REQUIRED_EDEFAULT = false; |
| |
| /** |
| * @generated This field/method will be replaced during code generation. |
| */ |
| protected boolean required = REQUIRED_EDEFAULT; |
| /** |
| * This is true if the Required attribute has been set. |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| * @ordered |
| */ |
| protected boolean requiredESet = false; |
| |
| /** |
| * The default value of the '{@link #isRtExprValue() <em>Rt Expr Value</em>}' attribute. |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @see #isRtExprValue() |
| * @generated |
| * @ordered |
| */ |
| protected static final boolean RT_EXPR_VALUE_EDEFAULT = false; |
| |
| /** |
| * @generated This field/method will be replaced during code generation. |
| */ |
| protected boolean rtExprValue = RT_EXPR_VALUE_EDEFAULT; |
| /** |
| * This is true if the Rt Expr Value attribute has been set. |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| * @ordered |
| */ |
| protected boolean rtExprValueESet = false; |
| |
| /** |
| * The default value of the '{@link #isFragment() <em>Fragment</em>}' attribute. |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @see #isFragment() |
| * @generated |
| * @ordered |
| */ |
| protected static final boolean FRAGMENT_EDEFAULT = false; |
| |
| /** |
| * The cached value of the '{@link #isFragment() <em>Fragment</em>}' attribute. |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @see #isFragment() |
| * @generated |
| * @ordered |
| */ |
| protected boolean fragment = FRAGMENT_EDEFAULT; |
| |
| /** |
| * @generated This field/method will be replaced during code generation. |
| */ |
| protected JavaClass type = null; |
| /** |
| * The cached value of the '{@link #getDescriptions() <em>Descriptions</em>}' containment reference list. |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @see #getDescriptions() |
| * @generated |
| * @ordered |
| */ |
| protected EList descriptions = null; |
| |
| public JSPTagAttributeImpl() { |
| super(); |
| } |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| @Override |
| protected EClass eStaticClass() { |
| return TaglibPackage.Literals.JSP_TAG_ATTRIBUTE; |
| } |
| |
| /** |
| * @generated This field/method will be replaced during code generation |
| * Defines the canonical name of a tag or attribute being defined (required). |
| */ |
| public String getName() { |
| return name; |
| } |
| |
| /** |
| * @generated This field/method will be replaced during code generation. |
| */ |
| public void setName(String newName) { |
| String oldName = name; |
| name = newName; |
| if (eNotificationRequired()) |
| eNotify(new ENotificationImpl(this, Notification.SET, TaglibPackage.JSP_TAG_ATTRIBUTE__NAME, oldName, name)); |
| } |
| |
| /** |
| * @generated This field/method will be replaced during code generation |
| * Defines if the nesting attribute is required or optional. |
| */ |
| public boolean isRequired() { |
| return required; |
| } |
| |
| /** |
| * @generated This field/method will be replaced during code generation. |
| */ |
| public void setRequired(boolean newRequired) { |
| boolean oldRequired = required; |
| required = newRequired; |
| boolean oldRequiredESet = requiredESet; |
| requiredESet = true; |
| if (eNotificationRequired()) |
| eNotify(new ENotificationImpl(this, Notification.SET, TaglibPackage.JSP_TAG_ATTRIBUTE__REQUIRED, oldRequired, required, !oldRequiredESet)); |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| public void unsetRequired() { |
| boolean oldRequired = required; |
| boolean oldRequiredESet = requiredESet; |
| required = REQUIRED_EDEFAULT; |
| requiredESet = false; |
| if (eNotificationRequired()) |
| eNotify(new ENotificationImpl(this, Notification.UNSET, TaglibPackage.JSP_TAG_ATTRIBUTE__REQUIRED, oldRequired, REQUIRED_EDEFAULT, oldRequiredESet)); |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| public boolean isSetRequired() { |
| return requiredESet; |
| } |
| |
| /** |
| * @generated This field/method will be replaced during code generation |
| * Defines if the nesting attribute can have scriptlet expressions asa value, i.e |
| * the value of the attribute may be dynamically calculatedat request time, as |
| * opposed to a static value determined at translationtime. (optional) |
| * Default = false |
| */ |
| public boolean isRtExprValue() { |
| return rtExprValue; |
| } |
| |
| /** |
| * @generated This field/method will be replaced during code generation. |
| */ |
| public void setRtExprValue(boolean newRtExprValue) { |
| boolean oldRtExprValue = rtExprValue; |
| rtExprValue = newRtExprValue; |
| boolean oldRtExprValueESet = rtExprValueESet; |
| rtExprValueESet = true; |
| if (eNotificationRequired()) |
| eNotify(new ENotificationImpl(this, Notification.SET, TaglibPackage.JSP_TAG_ATTRIBUTE__RT_EXPR_VALUE, oldRtExprValue, rtExprValue, !oldRtExprValueESet)); |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| public void unsetRtExprValue() { |
| boolean oldRtExprValue = rtExprValue; |
| boolean oldRtExprValueESet = rtExprValueESet; |
| rtExprValue = RT_EXPR_VALUE_EDEFAULT; |
| rtExprValueESet = false; |
| if (eNotificationRequired()) |
| eNotify(new ENotificationImpl(this, Notification.UNSET, TaglibPackage.JSP_TAG_ATTRIBUTE__RT_EXPR_VALUE, oldRtExprValue, RT_EXPR_VALUE_EDEFAULT, oldRtExprValueESet)); |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| public boolean isSetRtExprValue() { |
| return rtExprValueESet; |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| public boolean isFragment() { |
| return fragment; |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| public void setFragment(boolean newFragment) { |
| boolean oldFragment = fragment; |
| fragment = newFragment; |
| if (eNotificationRequired()) |
| eNotify(new ENotificationImpl(this, Notification.SET, TaglibPackage.JSP_TAG_ATTRIBUTE__FRAGMENT, oldFragment, fragment)); |
| } |
| |
| /** |
| * @generated This field/method will be replaced during code generation |
| * The value of the type element describes the Java type of the attributes value. |
| * For static values (those determined at translation time) the type is always |
| * java.lang.String. |
| */ |
| public JavaClass getType() { |
| if (type != null && type.eIsProxy()) { |
| InternalEObject oldType = (InternalEObject)type; |
| type = (JavaClass)eResolveProxy(oldType); |
| if (type != oldType) { |
| if (eNotificationRequired()) |
| eNotify(new ENotificationImpl(this, Notification.RESOLVE, TaglibPackage.JSP_TAG_ATTRIBUTE__TYPE, oldType, type)); |
| } |
| } |
| return type; |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| public JavaClass basicGetType() { |
| return type; |
| } |
| |
| /** |
| * @generated This field/method will be replaced during code generation. |
| */ |
| public void setType(JavaClass newType) { |
| JavaClass oldType = type; |
| type = newType; |
| if (eNotificationRequired()) |
| eNotify(new ENotificationImpl(this, Notification.SET, TaglibPackage.JSP_TAG_ATTRIBUTE__TYPE, oldType, type)); |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| public EList getDescriptions() { |
| if (descriptions == null) { |
| descriptions = new EObjectContainmentEList(Description.class, this, TaglibPackage.JSP_TAG_ATTRIBUTE__DESCRIPTIONS); |
| } |
| return descriptions; |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| @Override |
| public NotificationChain eInverseRemove(InternalEObject otherEnd, int featureID, NotificationChain msgs) { |
| switch (featureID) { |
| case TaglibPackage.JSP_TAG_ATTRIBUTE__DESCRIPTIONS: |
| return ((InternalEList)getDescriptions()).basicRemove(otherEnd, msgs); |
| } |
| return super.eInverseRemove(otherEnd, featureID, msgs); |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| @Override |
| public Object eGet(int featureID, boolean resolve, boolean coreType) { |
| switch (featureID) { |
| case TaglibPackage.JSP_TAG_ATTRIBUTE__NAME: |
| return getName(); |
| case TaglibPackage.JSP_TAG_ATTRIBUTE__REQUIRED: |
| return isRequired() ? Boolean.TRUE : Boolean.FALSE; |
| case TaglibPackage.JSP_TAG_ATTRIBUTE__RT_EXPR_VALUE: |
| return isRtExprValue() ? Boolean.TRUE : Boolean.FALSE; |
| case TaglibPackage.JSP_TAG_ATTRIBUTE__FRAGMENT: |
| return isFragment() ? Boolean.TRUE : Boolean.FALSE; |
| case TaglibPackage.JSP_TAG_ATTRIBUTE__TYPE: |
| if (resolve) return getType(); |
| return basicGetType(); |
| case TaglibPackage.JSP_TAG_ATTRIBUTE__DESCRIPTIONS: |
| return getDescriptions(); |
| } |
| return super.eGet(featureID, resolve, coreType); |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| @Override |
| public void eSet(int featureID, Object newValue) { |
| switch (featureID) { |
| case TaglibPackage.JSP_TAG_ATTRIBUTE__NAME: |
| setName((String)newValue); |
| return; |
| case TaglibPackage.JSP_TAG_ATTRIBUTE__REQUIRED: |
| setRequired(((Boolean)newValue).booleanValue()); |
| return; |
| case TaglibPackage.JSP_TAG_ATTRIBUTE__RT_EXPR_VALUE: |
| setRtExprValue(((Boolean)newValue).booleanValue()); |
| return; |
| case TaglibPackage.JSP_TAG_ATTRIBUTE__FRAGMENT: |
| setFragment(((Boolean)newValue).booleanValue()); |
| return; |
| case TaglibPackage.JSP_TAG_ATTRIBUTE__TYPE: |
| setType((JavaClass)newValue); |
| return; |
| case TaglibPackage.JSP_TAG_ATTRIBUTE__DESCRIPTIONS: |
| getDescriptions().clear(); |
| getDescriptions().addAll((Collection)newValue); |
| return; |
| } |
| super.eSet(featureID, newValue); |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| @Override |
| public void eUnset(int featureID) { |
| switch (featureID) { |
| case TaglibPackage.JSP_TAG_ATTRIBUTE__NAME: |
| setName(NAME_EDEFAULT); |
| return; |
| case TaglibPackage.JSP_TAG_ATTRIBUTE__REQUIRED: |
| unsetRequired(); |
| return; |
| case TaglibPackage.JSP_TAG_ATTRIBUTE__RT_EXPR_VALUE: |
| unsetRtExprValue(); |
| return; |
| case TaglibPackage.JSP_TAG_ATTRIBUTE__FRAGMENT: |
| setFragment(FRAGMENT_EDEFAULT); |
| return; |
| case TaglibPackage.JSP_TAG_ATTRIBUTE__TYPE: |
| setType((JavaClass)null); |
| return; |
| case TaglibPackage.JSP_TAG_ATTRIBUTE__DESCRIPTIONS: |
| getDescriptions().clear(); |
| return; |
| } |
| super.eUnset(featureID); |
| } |
| |
| /** |
| * <!-- begin-user-doc --> |
| * <!-- end-user-doc --> |
| * @generated |
| */ |
| @Override |
| public boolean eIsSet(int featureID) { |
| switch (featureID) { |
| case TaglibPackage.JSP_TAG_ATTRIBUTE__NAME: |
| return NAME_EDEFAULT == null ? name != null : !NAME_EDEFAULT.equals(name); |
| case TaglibPackage.JSP_TAG_ATTRIBUTE__REQUIRED: |
| return isSetRequired(); |
| case TaglibPackage.JSP_TAG_ATTRIBUTE__RT_EXPR_VALUE: |
| return isSetRtExprValue(); |
| case TaglibPackage.JSP_TAG_ATTRIBUTE__FRAGMENT: |
| return fragment != FRAGMENT_EDEFAULT; |
| case TaglibPackage.JSP_TAG_ATTRIBUTE__TYPE: |
| return type != null; |
| case TaglibPackage.JSP_TAG_ATTRIBUTE__DESCRIPTIONS: |
| return descriptions != null && !descriptions.isEmpty(); |
| } |
| return super.eIsSet(featureID); |
| } |
| |
| /** |
| * @generated This field/method will be replaced during code generation. |
| */ |
| @Override |
| public String toString() { |
| if (eIsProxy()) return super.toString(); |
| |
| StringBuffer result = new StringBuffer(super.toString()); |
| result.append(" (name: "); //$NON-NLS-1$ |
| result.append(name); |
| result.append(", required: "); //$NON-NLS-1$ |
| if (requiredESet) result.append(required); else result.append("<unset>"); //$NON-NLS-1$ |
| result.append(", rtExprValue: "); //$NON-NLS-1$ |
| if (rtExprValueESet) result.append(rtExprValue); else result.append("<unset>"); //$NON-NLS-1$ |
| result.append(", fragment: "); //$NON-NLS-1$ |
| result.append(fragment); |
| result.append(')'); |
| return result.toString(); |
| } |
| |
| } |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |