00001 package edu.ksu.cis.bandera.bofa; 00002 00003 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 00004 * Bandera, a Java(TM) analysis and transformation toolkit * 00005 * Copyright (C) 1998, 1999 * 00006 * John Hatcliff (hatcliff@cis.ksu.edu) 00007 * All rights reserved. * 00008 * * 00009 * This work was done as a project in the SAnToS Laboratory, * 00010 * Department of Computing and Information Sciences, Kansas State * 00011 * University, USA (http://www.cis.ksu.edu/santos). * 00012 * It is understood that any modification not identified as such is * 00013 * not covered by the preceding statement. * 00014 * * 00015 * This work is free software; you can redistribute it and/or * 00016 * modify it under the terms of the GNU Library General Public * 00017 * License as published by the Free Software Foundation; either * 00018 * version 2 of the License, or (at your option) any later version. * 00019 * * 00020 * This work is distributed in the hope that it will be useful, * 00021 * but WITHOUT ANY WARRANTY; without even the implied warranty of * 00022 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * 00023 * Library General Public License for more details. * 00024 * * 00025 * You should have received a copy of the GNU Library General Public * 00026 * License along with this toolkit; if not, write to the * 00027 * Free Software Foundation, Inc., 59 Temple Place - Suite 330, * 00028 * Boston, MA 02111-1307, USA. * 00029 * * 00030 * Java is a trademark of Sun Microsystems, Inc. * 00031 * * 00032 * To submit a bug report, send a comment, or get the latest news on * 00033 * this project and other SAnToS projects, please visit the web-site * 00034 * http://www.cis.ksu.edu/santos * 00035 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ 00036 00037 import ca.mcgill.sable.soot.*; 00038 import ca.mcgill.sable.util.*; 00039 00040 /* 00041 * StaticFieldManager.java 00042 * $Id: StaticFieldManager.java,v 1.1.1.1 2002/01/24 03:42:08 pserver Exp $ 00043 */ 00044 00045 /** 00046 * This class manages the static variables. 00047 * @author <A HREF="http://www.cis.ksu.edu/~hatcliff">John Hatcliff</A> 00048 * @author 00049 * <a href="http://www.cis.ksu.edu/~rvprasad">Venkatesh Prasad Ranganath</a> 00050 * @version $Name: $($Revision: 1.1.1.1 $) 00051 */ 00052 public class StaticFieldManager 00053 { 00054 /** 00055 * A Map from static fields to the associated flow graph node. 00056 */ 00057 private static Map fieldMap; 00058 00059 /** 00060 * Provides the FG node associated with the provided static field. 00061 * 00062 * @param sootField the static field corresponding to which the FG node is 00063 * requried. 00064 * @return the associated FG node. 00065 */ 00066 static FGNodeField get(SootField sootField) 00067 { 00068 return (FGNodeField) fieldMap.get(sootField); 00069 } 00070 /** 00071 * Initializes the Manager. 00072 */ 00073 public static void init() 00074 { 00075 fieldMap = new HashMap(); 00076 } 00077 /** 00078 * Adds a static field and the associated FG node. 00079 * 00080 * @param sootField the static field to be Managed. 00081 * @param node the FG node associated with sootField. 00082 */ 00083 static void put(SootField sootField, FGNodeField node) 00084 { 00085 fieldMap.put(sootField,node); 00086 } 00087 /** 00088 * Reset the data structures of the manager. 00089 * 00090 */ 00091 static void reset() { 00092 if (fieldMap != null) { 00093 fieldMap.clear(); 00094 } // end of if (fieldMap != null) 00095 } 00096 /** 00097 * Provides the flow graph node associated with the provided static field. 00098 * if none exists then a new one is created. 00099 * 00100 * @param sootField the static field corresponding to which the flow graph 00101 * node is required. 00102 * @return the associated flow graph node. 00103 */ 00104 public static FGNodeField select(SootField sootField) 00105 { 00106 FGNodeField node; 00107 00108 if (fieldMap.containsKey(sootField)) { 00109 node = get(sootField); 00110 } else { 00111 node = new FGNodeField(sootField); 00112 put(sootField,node); 00113 00114 } 00115 return node; 00116 } 00117 }