00001 package edu.ksu.cis.bandera.bofa; 00002 00003 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 00004 * Bandera, a Java(TM) analysis and transformation toolkit * 00005 * Copyright (C) 1998, 1999 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 00036 import ca.mcgill.sable.soot.*; 00037 import ca.mcgill.sable.util.*; 00038 00039 /** 00040 * Class represents classes that are being managed by the Analysis and are not 00041 * array classes. 00042 * @author <A HREF="http://www.cis.ksu.edu/~hatcliff">John Hatcliff</A> 00043 * @author <a href="http://www.cis.ksu.edu/~rvprasad">Venkatesh Prasad Ranganath 00044 * </a> 00045 */ 00046 00047 public class ClassTokenManaged implements ClassToken 00048 { 00049 /* ***************** */ 00050 /* static components */ 00051 /* ***************** */ 00052 00053 /** 00054 * Maps SootClass objects to ClassToken objects. 00055 */ 00056 private static Map allocatedTokens = new HashMap(); 00057 00058 /** 00059 * ClassToken representing the type of the unknown values. Basically the 00060 * values which we will not cover in the analysis. 00061 */ 00062 final public static ClassTokenManaged unknownClassToken = 00063 new ClassTokenManaged(new SootClass("unknownClassToken")); 00064 00065 /** The Class token corresponding to the Null object. It is reasonable to 00066 * use the same Class Token for all null references.*/ 00067 public final static ClassTokenManaged nullClassToken = 00068 new ClassTokenManaged(new SootClass("BOFA_NullValue")); 00069 /** 00070 * dump the SootClass to ClassToken mapping for unknown values. 00071 */ 00072 static { 00073 allocatedTokens.put(unknownClassToken.getSootClass(), 00074 unknownClassToken); 00075 allocatedTokens.put(nullClassToken.getSootClass(), 00076 nullClassToken); 00077 } 00078 00079 /* ******************* */ 00080 /* instance components */ 00081 /* ******************* */ 00082 00083 /** 00084 * the SootClass this object is associated with. 00085 */ 00086 SootClass sootClass; 00087 00088 00089 /** 00090 * Constructor for the class 00091 */ 00092 private ClassTokenManaged(SootClass sootClass) 00093 { 00094 this.sootClass = sootClass; 00095 } 00096 /** 00097 * Returns a string to be displayed in the GUI. 00098 * @return the string to dump 00099 */ 00100 public String display() 00101 { 00102 return this.sootClass.getName(); 00103 } 00104 /** 00105 * Returns a string used in debugging dumps. 00106 * @return the string to dump 00107 */ 00108 public String dump() 00109 { 00110 return display(); 00111 } 00112 /** 00113 * Returns the SootClass associated with this class token 00114 * @return the SootClass 00115 */ 00116 public SootClass getSootClass() 00117 { 00118 return this.sootClass; 00119 } 00120 /** 00121 * Retrieves the ClassToken object corresponding to the SootClass. If a 00122 * ClassToken is not associated, a new object is created and associated. 00123 * @param sootClass the soot class for which the class token is requested. 00124 * @return the class token corresponding to the soot class. */ 00125 public static ClassTokenManaged select(Object sootClass) 00126 { 00127 if (allocatedTokens.containsKey(sootClass)) { 00128 return (ClassTokenManaged) allocatedTokens.get(sootClass); 00129 } else { 00130 ClassTokenManaged classToken 00131 = new ClassTokenManaged((SootClass) sootClass); 00132 allocatedTokens.put(sootClass,classToken); 00133 return classToken; 00134 } 00135 } 00136 }