ada.editor/src/org/netbeans/modules/ada/editor/ast/nodes/FormalParameter.java
author Andrea Lucarelli <raster@netbeans.org>
Sun, 22 Aug 2010 23:37:11 +0200
branchrelease68
changeset 16367 d2820c029d3a
parent 15779 367c7fdb5d23
permissions -rw-r--r--
Add JVM compiler support.
     1 /*
     2  * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
     3  * 
     4  * Copyright 2008 Sun Microsystems, Inc. All rights reserved.
     5  * 
     6  * The contents of this file are subject to the terms of either the GNU
     7  * General Public License Version 2 only ("GPL") or the Common
     8  * Development and Distribution License("CDDL") (collectively, the
     9  * "License"). You may not use this file except in compliance with the
    10  * License. You can obtain a copy of the License at
    11  * http://www.netbeans.org/cddl-gplv2.html
    12  * or nbbuild/licenses/CDDL-GPL-2-CP. See the License for the
    13  * specific language governing permissions and limitations under the
    14  * License.  When distributing the software, include this License Header
    15  * Notice in each file and include the License file at
    16  * nbbuild/licenses/CDDL-GPL-2-CP.  Sun designates this
    17  * particular file as subject to the "Classpath" exception as provided
    18  * by Sun in the GPL Version 2 section of the License file that
    19  * accompanied this code. If applicable, add the following below the
    20  * License Header, with the fields enclosed by brackets [] replaced by
    21  * your own identifying information:
    22  * "Portions Copyrighted [year] [name of copyright owner]"
    23  * 
    24  * If you wish your version of this file to be governed by only the CDDL
    25  * or only the GPL Version 2, indicate your decision by adding
    26  * "[Contributor] elects to include this software in this distribution
    27  * under the [CDDL or GPL Version 2] license." If you do not indicate a
    28  * single choice of license, a recipient has the option to distribute
    29  * your version of this file under either the CDDL, the GPL Version 2 or
    30  * to extend the choice of license to its licensees as provided above.
    31  * However, if you add GPL Version 2 code and therefore, elected the GPL
    32  * Version 2 license, then the option applies only if the new code is
    33  * made subject to such option by the copyright holder.
    34  * 
    35  * Contributor(s):
    36  * 
    37  * Portions Copyrighted 2008 Sun Microsystems, Inc.
    38  */
    39 package org.netbeans.modules.ada.editor.ast.nodes;
    40 
    41 import org.netbeans.modules.ada.editor.ast.ASTNode;
    42 import org.netbeans.modules.ada.editor.ast.nodes.visitors.Visitor;
    43 
    44 /**
    45  * Represents a function/procedure formal parameter
    46  * <pre>e.g.<pre>
    47  * procedure Foo (a : in bar; b : in out foo_bar; c : out boolean)
    48  * function Foo (a : in bar; b : in foo_bar) return boolean
    49  */
    50 public class FormalParameter extends ASTNode {
    51 
    52     public enum Mode {
    53         IN, OUT, IN_OUT, ACCESS;
    54     }
    55     private Variable parameterName;
    56     private Mode parameterMode;
    57     private NameBase parameterType;
    58     private Expression defaultValue;
    59 
    60     public FormalParameter(int start, int end, final Variable parameterName, Mode parameterMode, NameBase type, Expression defaultValue) {
    61         super(start, end);
    62 
    63         this.parameterName = parameterName;
    64         this.parameterMode = parameterMode;
    65         this.parameterType = type;
    66         this.defaultValue = defaultValue;
    67     }
    68 
    69     public FormalParameter(int start, int end, final Variable parameterName, Mode parameterMode, NameBase type) {
    70         this(start, end, parameterName, parameterMode, type, null);
    71     }
    72 
    73     /**
    74      * @return default value of this parameter
    75      */
    76     public Expression getDefaultValue() {
    77         return defaultValue;
    78     }
    79 
    80     /**
    81      * @return the name of this parameter
    82      */
    83     public Variable getParameterName() {
    84         return parameterName;
    85     }
    86 
    87     /**
    88      * @return the mode of this parameter
    89      */
    90     public Mode getParameterMode() {
    91         return parameterMode;
    92     }
    93 
    94     /**
    95      * @return the type of this parameter
    96      */
    97     public NameBase getParameterType() {
    98         return parameterType;
    99     }
   100 
   101     @Override
   102     public void accept(Visitor visitor) {
   103         visitor.visit(this);
   104     }
   105 }