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

BirTypeInit.java

00001 package edu.ksu.cis.bandera.bir;
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 /**
00039  * TypeSwitch to initialize a variable of a BIR type
00040  */
00041 
00042 public class BirTypeInit extends AbstractTypeSwitch {
00043 
00044     BirState state;
00045     Literal [] store;
00046     TransSystem system;
00047 
00048     public BirTypeInit(BirState state) {
00049     this.state = state;
00050     this.store = state.getStore();
00051     this.system = state.getSystem();
00052     }
00053     public void caseArray(Array type, Object o)
00054     {
00055     int offset = varOffset(o);
00056     // use length computed from trace (stored at offset) if in collection
00057     int size = type.getSize().getValue();
00058     if (o instanceof Integer) 
00059         size =  ((IntLit)store[offset]).getValue();
00060     else // must init length (static array)
00061         store[offset] = new IntLit(size); 
00062     for (int i = 0; i < size; i++) 
00063         type.getBaseType().apply(this, new Integer(offset + i + 1));
00064     }
00065     public void caseBool(Bool type, Object o) 
00066     {
00067     simpleInit(type, o);
00068     }
00069     public void caseCollection(Collection type, Object o)
00070     {
00071     }
00072     public void caseEnumerated(Enumerated type, Object o) 
00073     {
00074     simpleInit(type, o);
00075     }
00076     public void caseField(Field type, Object o)
00077     {
00078     int offset = varOffset(o) + type.getOffset();
00079     type.getType().apply(this, new Integer(offset));
00080     }
00081     public void caseLock(Lock type, Object o)
00082     {   
00083     store[varOffset(o)] = new LockLit(system);
00084     }
00085     public void caseRange(Range type, Object o) 
00086     {
00087     simpleInit(type, o);
00088     }
00089     public void caseRecord(Record type, Object o)
00090     {
00091     Vector fields = type.getFields();
00092     for (int i = 0; i < fields.size(); i++) 
00093         ((Field)fields.elementAt(i)).apply(this, o);
00094     }
00095     public void caseRef(Ref type, Object o)
00096     {
00097     store[varOffset(o)] = new NullExpr(system);
00098     }
00099     public void defaultCase(Object obj) {
00100     throw new RuntimeException("Construct not handled: " + obj);
00101     }
00102     Expr initValue(Type type, Object context) {
00103     return (context instanceof Integer) ?
00104         type.defaultVal() : ((StateVar)context).getInitVal();
00105     }
00106     void simpleInit(Type type, Object o) 
00107     {
00108     initValue(type,o).apply(state);
00109     Literal val = (Literal) state.getResult();
00110     store[varOffset(o)] = val;
00111     }
00112     int varOffset(Object context) {
00113     return (context instanceof Integer) ? 
00114         ((Integer)context).intValue() : ((StateVar)context).getOffset();
00115     }
00116 }

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