/* * Copyright (c) 2013, the Dart project authors. * * Licensed under the Eclipse Public License v1.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.eclipse.org/legal/epl-v10.html * * 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. */ package com.google.dart.engine.internal.element; import com.google.dart.engine.ast.Identifier; import com.google.dart.engine.element.ElementVisitor; import com.google.dart.engine.element.FieldElement; import com.google.dart.engine.element.FieldFormalParameterElement; /** * Instances of the class {@code FieldFormalParameterElementImpl} extend * {@link ParameterElementImpl} to provide the additional information of the {@link FieldElement} * associated with the parameter. * * @coverage dart.engine.element */ public class FieldFormalParameterElementImpl extends ParameterElementImpl implements FieldFormalParameterElement { /** * The field associated with this field formal parameter. */ private FieldElement field; /** * Initialize a newly created parameter element to have the given name. * * @param name the name of this element */ public FieldFormalParameterElementImpl(Identifier name) { super(name); } @Override public <R> R accept(ElementVisitor<R> visitor) { return visitor.visitFieldFormalParameterElement(this); } @Override public FieldElement getField() { return field; } @Override public boolean isInitializingFormal() { return true; } /** * Set the field element associated with this field formal parameter to the given element. * * @param field the new field element */ public void setField(FieldElement field) { this.field = field; } }