00001 package edu.ksu.cis.bandera.abstraction.typeinference; 00002 00003 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 00004 * Bandera, a Java(TM) analysis and transformation toolkit * 00005 * Copyright (C) 1998, 1999, 2000 Shawn Laubach (laubach@acm.org) * 00006 * All rights reserved. * 00007 * * 00008 * This work was done as a project in the SAnToS Laboratory, * 00009 * Department of Computing and Information Sciences, Kansas State * 00010 * University, USA (http://www.cis.ksu.edu/santos). * 00011 * It is understood that any modification not identified as such is * 00012 * not covered by the preceding statement. * 00013 * * 00014 * This work is free software; you can redistribute it and/or * 00015 * modify it under the terms of the GNU Library General Public * 00016 * License as published by the Free Software Foundation; either * 00017 * version 2 of the License, or (at your option) any later version. * 00018 * * 00019 * This work is distributed in the hope that it will be useful, * 00020 * but WITHOUT ANY WARRANTY; without even the implied warranty of * 00021 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * 00022 * Library General Public License for more details. * 00023 * * 00024 * You should have received a copy of the GNU Library General Public * 00025 * License along with this toolkit; if not, write to the * 00026 * Free Software Foundation, Inc., 59 Temple Place - Suite 330, * 00027 * Boston, MA 02111-1307, USA. * 00028 * * 00029 * Java is a trademark of Sun Microsystems, Inc. * 00030 * * 00031 * To submit a bug report, send a comment, or get the latest news on * 00032 * this project and other SAnToS projects, please visit the web-site * 00033 * http://www.cis.ksu.edu/santos * 00034 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ 00035 public class TypeVariable { 00036 protected Object type; 00037 public Object ast; 00038 /** 00039 * TypeVariable constructor comment. 00040 */ 00041 public TypeVariable(Object type) { 00042 this.type = type; 00043 } 00044 /** 00045 * Insert the method's description here. 00046 * Creation date: (8/22/00 4:21:29 PM) 00047 * @return java.lang.Object 00048 */ 00049 public Object getAST() { 00050 return ast; 00051 } 00052 /** 00053 * Insert the method's description here. 00054 * Creation date: (8/21/00 10:14:56 AM) 00055 * @return ca.mcgill.sable.soot.Type 00056 */ 00057 public Object getType() { 00058 return type; 00059 } 00060 /** 00061 * Insert the method's description here. 00062 * Creation date: (8/22/00 3:50:27 PM) 00063 * @param ast java.lang.Object 00064 */ 00065 public void setAST(Object ast) { 00066 this.ast = ast; 00067 } 00068 /** 00069 * Insert the method's description here. 00070 * Creation date: (8/21/00 10:14:56 AM) 00071 * @param newType ca.mcgill.sable.soot.Type 00072 */ 00073 protected void setType(Object newType) { 00074 type = newType; 00075 } 00076 /** 00077 * Insert the method's description here. 00078 * Creation date: (8/17/00 9:28:49 PM) 00079 * @return java.lang.String 00080 */ 00081 public String toString() { 00082 if (ast == null) 00083 return super.toString(); 00084 else 00085 return ast.toString(); 00086 } 00087 }