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 }