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

StaticFieldManager.java

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 }

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