00001 package edu.ksu.cis.bandera.pdgslicer; 00002 00003 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 00004 * Bandera, a Java(TM) analysis and transformation toolkit * 00005 * Copyright (C) 1998, 1999 Hongjun Zheng (zheng@cis.ksu.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 00036 import ca.mcgill.sable.soot.jimple.*; 00037 import ca.mcgill.sable.util.*; 00038 /** 00039 * This is for information of slice criterion. 00040 */ 00041 public class SliceCriterion { 00042 /** 00043 * A map from {@link Stmt Stmt} to a {@link Set Set} of 00044 * {@link Value Value} representing all relevant variables 00045 * for every statement. 00046 */ 00047 private Map relVarMap = new HashMap(); 00048 /** 00049 * A set of {@link SlicePoint SlicePoint}. 00050 */ 00051 private Set slicePoints; 00052 /** 00053 * A set of {@link SliceVariable SliceVariable} 00054 */ 00055 private Set sliceVars; 00056 private Set sliceStatements; 00057 /** 00058 * @param p a set of slice points. 00059 * @param v a set of slice variables. 00060 */ 00061 public SliceCriterion(Set p, Set v, Set s) { 00062 this.slicePoints = p; 00063 this.sliceVars = v; 00064 this.sliceStatements = s; 00065 } 00066 Set getSlicePoints() { 00067 return slicePoints; 00068 } 00069 /** 00070 * Insert the method's description here. 00071 * Creation date: (00-12-4 16:34:27) 00072 * @return ca.mcgill.sable.util.Set 00073 */ 00074 Set getSliceStatements() { 00075 return sliceStatements; 00076 } 00077 Set getSliceVars() { 00078 return sliceVars; 00079 } 00080 Map relVarMap() { 00081 return relVarMap; 00082 } 00083 void setRelVarMap(Map m) { 00084 relVarMap = m; 00085 } 00086 public String toString() 00087 { 00088 String s; 00089 00090 s = "slicePoint: " + this.slicePoints + " sliceVars: " + this.sliceVars; 00091 return s; 00092 } 00093 }