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 }