Main Page   Packages   Class Hierarchy   Alphabetical List   Compound List   File List   Compound Members  

SimpleEqualLocalsAnalysis.java

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 }

Generated at Thu Feb 7 06:54:54 2002 for Bandera by doxygen1.2.10 written by Dimitri van Heesch, © 1997-2001