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

ChooseExpander.java

00001 package edu.ksu.cis.bandera.birc;
00002 
00003 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
00004  * Bandera, a Java(TM) analysis and transformation toolkit           *
00005  * Copyright (C) 1998, 1999   James Corbett (corbett@hawaii.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 import java.io.*;
00036 import java.util.*;
00037 
00038 import edu.ksu.cis.bandera.bir.*;
00039 
00040 public class ChooseExpander {
00041 
00042     TransSystem system;
00043     int mark;
00044     TransVector newTransformations = new TransVector();
00045 
00046     public ChooseExpander(TransSystem system) {
00047     this.system = system;
00048     this.mark = Location.getNewMark();
00049     }
00050     void expand(Location currentLoc) {
00051     currentLoc.setMark(mark);
00052     TransVector outTrans = currentLoc.getOutTrans();
00053     for (int i = 0; i < outTrans.size(); i++) {
00054         Transformation trans = outTrans.elementAt(i);
00055         expandTrans(trans);
00056         if ((trans.getToLoc().getMark() != mark))
00057             expand(trans.getToLoc());
00058     }
00059     }
00060     void expandTrans(Transformation trans) {
00061     ActionVector actions = trans.getActions();
00062     if (actions.size() > 0) {
00063         if (actions.size() > 1)
00064         throw new RuntimeException("ChooseExpander doesn't handle multiple assignments per transformation" + trans);
00065         if (actions.elementAt(0).isAssignAction()) {
00066         AssignAction assign = 
00067             (AssignAction) actions.elementAt(0);
00068         if (assign.getRhs() instanceof ChooseExpr) {
00069             trans.markDeleted();
00070             Vector choices = 
00071             ((ChooseExpr)assign.getRhs()).getChoices();
00072             for (int i = 0; i < choices.size(); i++) {
00073             Expr choice = (Expr) choices.elementAt(i);
00074             ActionVector newActions = new ActionVector();
00075             AssignAction choiceAssign = 
00076                 new AssignAction(assign.getLhs(), choice);
00077             newActions.addElement(choiceAssign);
00078             trans.getFromLoc().addTrans(trans.getToLoc(),
00079                             trans.getGuard(),
00080                             newActions);
00081             }
00082         }
00083         }
00084     }
00085     }
00086     public void run() {
00087     ThreadVector threadVector = system.getThreads();
00088     for (int i = 0; i < threadVector.size(); i++) {
00089         BirThread thread = threadVector.elementAt(i);
00090         expand(thread.getStartLoc());
00091     }
00092     Transformation.purge();
00093     }
00094 }

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