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.jimple.Stmt; 00038 import ca.mcgill.sable.util.*; 00039 00040 /* 00041 * FGNodeAST.java 00042 * $Id: FGNodeAST.java,v 1.1.1.1 2002/01/24 03:42:07 pserver Exp $ 00043 */ 00044 00045 /** 00046 * This class represents the FG node for any AST nodes. 00047 * 00048 * @author <A HREF="http://www.cis.ksu.edu/~hatcliff">John Hatcliff</A> 00049 * @author 00050 * <a href="http://www.cis.ksu.edu/~rvprasad">Venkatesh Prasad Ranganath</a> 00051 * @version $Name: $($Revision: 1.1.1.1 $) 00052 */ 00053 public class FGNodeAST extends FGNode 00054 { 00055 /** 00056 * The AST object described by this node. 00057 */ 00058 private Object obj; 00059 00060 /** 00061 * The statement in which the described AST Node is embedded in. 00062 */ 00063 private Stmt stmt; 00064 00065 /** 00066 * Constructor that uses empty sets for values, actions, and succs. 00067 * @param obj AST object described by this flowgraph node. 00068 */ 00069 public FGNodeAST(Object obj) 00070 { 00071 super(); 00072 this.obj = obj; 00073 } 00074 /** 00075 * Returns the AST object described by this node. 00076 * 00077 * @return the AST object described by this node. 00078 */ 00079 public Object getObj() 00080 { 00081 return obj; 00082 } 00083 /** 00084 * Returns the statement enclosing the described AST node. 00085 * 00086 * @return the statement enclosing the described AST node. 00087 */ 00088 public Stmt getStmt() 00089 { 00090 return stmt; 00091 } 00092 /** 00093 * Sets the statement enclosing the described AST node. This is required 00094 * when there are circularity in constructors and so members need to be 00095 * initialized after the call to the construtor. 00096 * 00097 * @param stmt the statement enclosing the described AST node. 00098 */ 00099 void setStmt(Stmt stmt) 00100 { 00101 this.stmt = stmt; 00102 } 00103 }