00001 package ca.mcgill.sable.soot; 00002 00003 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 00004 * Soot, a Java(TM) classfile optimization framework. * 00005 * Copyright (C) 1997, 1998 Raja Vallee-Rai (kor@sable.mcgill.ca) * 00006 * All rights reserved. * 00007 * * 00008 * This work was done as a project of the Sable Research Group, * 00009 * School of Computer Science, McGill University, Canada * 00010 * (http://www.sable.mcgill.ca/). It is understood that any * 00011 * modification not identified as such is not covered by the * 00012 * 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 library; 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 Sable Research Group projects, please * 00033 * visit the web site: http://www.sable.mcgill.ca/ * 00034 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ 00035 00036 /* 00037 Reference Version 00038 ----------------- 00039 This is the latest official version on which this file is based. 00040 The reference version is: $SootVersion: 1.beta.4 $ 00041 00042 Change History 00043 -------------- 00044 A) Notes: 00045 00046 Please use the following template. Most recent changes should 00047 appear at the top of the list. 00048 00049 - Modified on [date (March 1, 1900)] by [name]. [(*) if appropriate] 00050 [description of modification]. 00051 00052 Any Modification flagged with "(*)" was done as a project of the 00053 Sable Research Group, School of Computer Science, 00054 McGill University, Canada (http://www.sable.mcgill.ca/). 00055 00056 You should add your copyright, using the following template, at 00057 the top of this file, along with other copyrights. 00058 00059 * * 00060 * Modifications by [name] are * 00061 * Copyright (C) [year(s)] [your name (or company)]. All rights * 00062 * reserved. * 00063 * * 00064 00065 B) Changes: 00066 00067 - Modified on November 2, 1998 by Raja Vallee-Rai (kor@sable.mcgill.ca) (*) 00068 Repackaged all source files and performed extensive modifications. 00069 First initial release of Soot. 00070 00071 - Modified on 15-Jun-1998 by Raja Vallee-Rai (kor@sable.mcgill.ca). (*) 00072 First internal release (Version 0.1). 00073 */ 00074 00075 import ca.mcgill.sable.util.*; 00076 00077 public abstract class Type implements ca.mcgill.sable.util.ValueObject, Switchable 00078 { 00079 public void apply(Switch sw) { 00080 } 00081 public Type merge(Type other, SootClassManager cm) 00082 { 00083 if(this.equals(UnknownType.v())) 00084 return other; 00085 else if(other.equals(UnknownType.v())) 00086 return this; 00087 else if(this.equals(other)) 00088 return this; 00089 else if(this instanceof RefType && other instanceof RefType) 00090 { 00091 // Return least common superclass 00092 00093 SootClass thisClass = cm.getClass(((RefType) this).className); 00094 SootClass otherClass = cm.getClass(((RefType) other).className); 00095 SootClass javalangObject = cm.getClass("java.lang.Object"); 00096 00097 LinkedList thisHierarchy = new LinkedList(); 00098 LinkedList otherHierarchy = new LinkedList(); 00099 00100 // Build thisHierarchy 00101 { 00102 SootClass SootClass = thisClass; 00103 00104 for(;;) 00105 { 00106 thisHierarchy.addFirst(SootClass); 00107 00108 if(SootClass == javalangObject) 00109 break; 00110 00111 SootClass = SootClass.getSuperClass(); 00112 } 00113 } 00114 00115 // Build otherHierarchy 00116 { 00117 SootClass SootClass = otherClass; 00118 00119 for(;;) 00120 { 00121 otherHierarchy.addFirst(SootClass); 00122 00123 if(SootClass == javalangObject) 00124 break; 00125 00126 SootClass = SootClass.getSuperClass(); 00127 } 00128 } 00129 00130 // Find least common superclass 00131 { 00132 SootClass commonClass = null; 00133 00134 while(!otherHierarchy.isEmpty() && !thisHierarchy.isEmpty() && 00135 otherHierarchy.getFirst() == thisHierarchy.getFirst()) 00136 { 00137 commonClass = (SootClass) otherHierarchy.removeFirst(); 00138 thisHierarchy.removeFirst(); 00139 } 00140 00141 return RefType.v(commonClass.getName()); 00142 } 00143 } 00144 else 00145 throw new IllegalTypeMergeException(this + " and " + other); 00146 } 00147 public static Type toMachineType(Type t) 00148 { 00149 if(t.equals(ShortType.v()) || t.equals(ByteType.v()) || 00150 t.equals(BooleanType.v()) || t.equals(CharType.v())) 00151 { 00152 return IntType.v(); 00153 } 00154 else 00155 return t; 00156 } 00157 public abstract String toString(); 00158 }