00001 package ca.mcgill.sable.soot.jimple; 00002 00003 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 00004 * Jimple, a 3-address code Java(TM) bytecode representation. * 00005 * Copyright (C) 1997, 1998 Raja Vallee-Rai (kor@sable.mcgill.ca) * 00006 * All rights reserved. * 00007 * * 00008 * This work was done as a project of the Sable Research Group, * 00009 * School of Computer Science, McGill University, Canada * 00010 * (http://www.sable.mcgill.ca/). It is understood that any * 00011 * modification not identified as such is not covered by the * 00012 * 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 library; 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 Sable Research Group projects, please * 00033 * visit the web site: http://www.sable.mcgill.ca/ * 00034 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ 00035 00036 /* 00037 Reference Version 00038 ----------------- 00039 This is the latest official version on which this file is based. 00040 The reference version is: $SootVersion: 1.beta.4 $ 00041 00042 Change History 00043 -------------- 00044 A) Notes: 00045 00046 Please use the following template. Most recent changes should 00047 appear at the top of the list. 00048 00049 - Modified on [date (March 1, 1900)] by [name]. [(*) if appropriate] 00050 [description of modification]. 00051 00052 Any Modification flagged with "(*)" was done as a project of the 00053 Sable Research Group, School of Computer Science, 00054 McGill University, Canada (http://www.sable.mcgill.ca/). 00055 00056 You should add your copyright, using the following template, at 00057 the top of this file, along with other copyrights. 00058 00059 * * 00060 * Modifications by [name] are * 00061 * Copyright (C) [year(s)] [your name (or company)]. All rights * 00062 * reserved. * 00063 * * 00064 00065 B) Changes: 00066 00067 - Modified on March 14, 1999 by Raja Vallee-Rai (rvalleerai@sable.mcgill.ca) (*) 00068 First release. 00069 */ 00070 00071 import ca.mcgill.sable.soot.*; 00072 import ca.mcgill.sable.util.*; 00073 00074 class SimpleEqualLocalsAnalysis extends ForwardFlowAnalysis 00075 { 00076 FlowSet emptySet; 00077 00078 public SimpleEqualLocalsAnalysis(StmtGraph g) 00079 { 00080 super(g); 00081 00082 emptySet = new ArraySparseSet(); 00083 00084 doAnalysis(); 00085 } 00086 protected void copy(Object source, Object dest) 00087 { 00088 FlowSet sourceSet = (FlowSet) source, 00089 destSet = (FlowSet) dest; 00090 00091 sourceSet.copy(destSet); 00092 } 00093 protected void flowThrough(Object inValue, Stmt stmt, Object outValue) 00094 { 00095 FlowSet in = (FlowSet) inValue, out = (FlowSet) outValue; 00096 00097 in.copy(out); 00098 00099 if(stmt instanceof DefinitionStmt) 00100 { 00101 DefinitionStmt d = (DefinitionStmt) stmt; 00102 00103 if(d.getLeftOp() instanceof Local) 00104 { 00105 // Of the form x = ... so remove local from its 00106 // current equiv class 00107 00108 Local x = (Local) d.getLeftOp(); 00109 00110 Iterator copyIt = in.toList().iterator(); 00111 00112 while(copyIt.hasNext()) 00113 { 00114 LocalCopy copy = (LocalCopy) copyIt.next(); 00115 00116 if(copy.leftLocal == x || copy.rightLocal == x) 00117 out.remove(copy, out); 00118 } 00119 00120 if(d.getRightOp() instanceof Local) 00121 { 00122 // Of the form x = y, so make x equivalent to everything 00123 // that y is equivalent to. 00124 00125 Local y = (Local) d.getRightOp(); 00126 00127 if(x != y) 00128 { 00129 out.add(new LocalCopy(x, y), out); 00130 out.add(new LocalCopy(y, x), out); 00131 00132 copyIt = in.toList().iterator(); 00133 00134 while(copyIt.hasNext()) 00135 { 00136 LocalCopy copy = (LocalCopy) copyIt.next(); 00137 Local other; 00138 00139 if(copy.leftLocal == y & copy.rightLocal != x) 00140 out.add(new LocalCopy(x, copy.rightLocal), out); 00141 00142 if(copy.rightLocal == y & copy.leftLocal != x) 00143 out.add(new LocalCopy(copy.leftLocal, x), out); 00144 } 00145 } 00146 } 00147 } 00148 } 00149 } 00150 protected void merge(Object in1, Object in2, Object out) 00151 { 00152 FlowSet inSet1 = (FlowSet) in1, 00153 inSet2 = (FlowSet) in2; 00154 00155 FlowSet outSet = (FlowSet) out; 00156 00157 inSet1.intersection(inSet2, outSet); 00158 } 00159 protected Object newInitialFlow() 00160 { 00161 return emptySet.clone(); 00162 } 00163 }