View Javadoc

1   /***
2    * Cecilia ADL Compiler
3    * Copyright (C) 2006-2007 STMicroelectronics
4    *
5    * This library is free software; you can redistribute it and/or
6    * modify it under the terms of the GNU Lesser General Public
7    * License as published by the Free Software Foundation; either
8    * version 2 of the License, or (at your option) any later version.
9    *
10   * This library is distributed in the hope that it will be useful,
11   * but WITHOUT ANY WARRANTY; without even the implied warranty of
12   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13   * Lesser General Public License for more details.
14   *
15   * You should have received a copy of the GNU Lesser General Public
16   * License along with this library; if not, write to the Free Software
17   * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
18   *
19   * Contact: fractal@objectweb.org
20   *
21   * Author:Ali Erdem Ozcan
22   */
23  
24  package org.objectweb.fractal.cecilia.adl.idl.ast;
25  
26  import org.objectweb.fractal.adl.Node;
27  
28  /**
29   * AST node interface for <code>Type</code> container elements.
30   */
31  public interface TypeContainer extends Node {
32  
33    /**
34     * Returns the <code>primitiveType</code> sub-element.
35     * 
36     * @return the <code>primitiveType</code> sub-element.
37     */
38    PrimitiveType getPrimitiveType();
39  
40    /**
41     * Sets a <code>primitiveType</code> sub-element.
42     * 
43     * @param type a <code>primitiveType</code> sub-element to set.
44     */
45    void setPrimitiveType(PrimitiveType type);
46  
47    /**
48     * Returns the <code>complexType</code> sub-element.
49     * 
50     * @return the <code>complexType</code> sub-element.
51     */
52    ComplexType getComplexType();
53  
54    /**
55     * Sets a <code>complexType</code> sub-element.
56     * 
57     * @param type a <code>complexType</code> sub-element to set.
58     */
59    void setComplexType(ComplexType type);
60  
61    /**
62     * Returns the <code>arrayOf</code> sub-element.
63     * 
64     * @return the <code>arrayOf</code> sub-element.
65     */
66    ArrayOf getArrayOf();
67  
68    /**
69     * Sets a <code>arrayOf</code> sub-element.
70     * 
71     * @param arrayOf a <code>arrayOf</code> sub-element to set.
72     */
73    void setArrayOf(ArrayOf arrayOf);
74  
75    /**
76     * Returns the <code>pointerOf</code> sub-element.
77     * 
78     * @return the <code>pointerOf</code> sub-element.
79     */
80    PointerOf getPointerOf();
81  
82    /**
83     * Sets a <code>pointerOf</code> sub-element.
84     * 
85     * @param pointerOf a <code>pointerOf</code> sub-element to set.
86     */
87    void setPointerOf(PointerOf pointerOf);
88  }