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

PredicateSet.java

00001 package edu.ksu.cis.bandera.birc;
00002 
00003 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
00004  * Bandera, a Java(TM) analysis and transformation toolkit           *
00005  * Copyright (C) 1998, 1999   James Corbett (corbett@hawaii.edu)     *
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 import java.io.*;
00036 import java.util.*;
00037 
00038 import edu.ksu.cis.bandera.bir.LocVector;
00039 import edu.ksu.cis.bandera.bir.Location;
00040 
00041 import ca.mcgill.sable.util.*;
00042 import ca.mcgill.sable.soot.*;
00043 import ca.mcgill.sable.soot.jimple.*;
00044 
00045 /**
00046  * PredicateSet allows the caller of BIRC to define state predicates
00047  * that will appear in the translator input.  
00048  * <p>
00049  * Predicates on the location of threads should be specified as value
00050  * predicates using the LocationTestExpr extension to Jimple.
00051  * <p>
00052  * Usage: 
00053  * <pre>
00054  * PredicateSet predicates = new PredicateSet();
00055  * Vector stmts = new Vector();
00056  * Stmt retStmt = ...;
00057  * stmt.addElement(retStmt);
00058  * LocationTestExpr test = new LocationTestExpr(stmts);
00059  * predicates.addValuePredicate("atReturn",test);
00060  * Expr xGT0Expr = ...;
00061  * predicates.addValuePredicate("xGT0",xGT0Expr);
00062  * </pre>
00063  */
00064 
00065 public class PredicateSet {
00066 
00067     Vector valuePredicates = new Vector();
00068     Hashtable predicateName = new Hashtable();  // Map pred -> String
00069     Hashtable predLocations = new Hashtable();  // Map pred -> LocVector
00070     Hashtable observableSet = new Hashtable();  // Set of observable objects
00071 
00072     void addPredicateLocation(Stmt stmt, Location loc) {
00073     LocVector predLocs = (LocVector) predLocations.get(stmt);
00074     if (predLocs == null) {
00075         predLocs = new LocVector();
00076         predLocations.put(stmt,predLocs);
00077     }
00078     predLocs.addElement(loc);
00079     }
00080     /**
00081      * Add a value predicate (a Jimple Expr)
00082      *
00083      * @param name name of predicate
00084      * @param expr Jimple Expr specifying condition when predicate is true
00085      */
00086 
00087     public void addValuePredicate(String name, Expr expr) {
00088     if (predicateName.get(name) != null)
00089         throw new RuntimeException("Attempt to redefine pred: " + name);
00090     valuePredicates.addElement(expr);
00091     predicateName.put(expr,name);
00092     ObservableExtractor extractor = 
00093         new ObservableExtractor(observableSet);
00094     expr.apply(extractor);   // updates observableSet
00095     }
00096     LocVector getPredicateLocations(Stmt stmt) {
00097     return (LocVector) predLocations.get(stmt);
00098     }
00099     public Vector getValuePredicates() { return valuePredicates; }
00100     public boolean isObservable(Object o) {
00101     return observableSet.get(o) != null;
00102     }
00103     public String predicateName(Object pred) { 
00104     return (String) predicateName.get(pred);
00105     }
00106     public void print() {
00107     System.out.println("Predicate Set:");
00108     for (int i = 0; i < valuePredicates.size(); i++) {
00109         Object pred = valuePredicates.elementAt(i);
00110         System.out.println("  " + predicateName(pred) + " = "  + pred);
00111     }                  
00112     }
00113 }

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