Main Page   Packages   Class Hierarchy   Alphabetical List   Compound List   File List   Compound Members  

ClassTokenManaged.java

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 }

Generated at Thu Feb 7 06:42:31 2002 for Bandera by doxygen1.2.10 written by Dimitri van Heesch, © 1997-2001