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 00038 /** 00039 * This class is for information of synchronization statement in Jimple 00040 * like <code>wait</code> and <code>notify</code>. 00041 */ 00042 public class SynchroStmt 00043 { 00044 /** 00045 * The lock with which <code>wait</code> or <code>notify</code> 00046 * is associtated. 00047 */ 00048 private Value lock; 00049 /** 00050 * The statement of <code>wait</code> or <code>notify</code>. 00051 */ 00052 private Stmt waitNotify; 00053 /** 00054 * The kind of the statement: <code>notify</code>, 00055 * <code>notifyAll</code>, or <code>wait</code>. 00056 */ 00057 private String stmtKind; 00058 00059 /** 00060 * @param s <code>wait</code> or <code>notify</code> statement. 00061 * @param kind kind of the statement. 00062 */ 00063 public SynchroStmt(Stmt s, String kind) 00064 { 00065 waitNotify = s; 00066 stmtKind = kind; 00067 } 00068 /** 00069 * Get the lock. 00070 * <p> 00071 * @return {@link #lock lock}. 00072 */ 00073 public Value getLock() 00074 { 00075 return lock; 00076 } 00077 /** 00078 * Get the statement. 00079 * <p> 00080 * @return {@link #waitNotify waitNotify}. 00081 */ 00082 public Stmt getWaitNotify() 00083 { 00084 return waitNotify; 00085 } 00086 /** 00087 * See if the statement is <code>notify</code> statement. 00088 * <p> 00089 * @return <code>true</code> if {@link #stmtKind stmtKind} is 00090 * <code>notify</code> or <code>notifyAll</code>; 00091 * <code>false</code> otherwise. 00092 */ 00093 public boolean isNotifyStmt() 00094 { 00095 return (stmtKind.equals("notify") || stmtKind.equals("notifyAll")); 00096 } 00097 /** 00098 * See if the statement is <code>wait</code> statement. 00099 * <p> 00100 * @return <code>true</code> if {@link #stmtKind stmtKind} is 00101 * <code>wait</code>; <code>false</code> otherwise. 00102 */ 00103 public boolean isWaitStmt() 00104 { 00105 return stmtKind.equals("wait"); 00106 } 00107 /** 00108 * Set a value for {@link #lock lock}. 00109 * <p> 00110 * @param v the value. 00111 */ 00112 public void setLock(Value v) 00113 { 00114 lock = v; 00115 } 00116 public String toString() 00117 { 00118 return "[ lock: " + lock + " wnStmt: " + waitNotify + " ]"; 00119 } 00120 }