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

Range.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 ca.mcgill.sable.util.*;
00036 
00037 import java.io.*;
00038 import java.util.*;
00039 
00040 /**
00041  * A range type.  
00042  */
00043 
00044 public class Range extends Type implements BirConstants {
00045 
00046     int rangeSize = 0;    // Number of elements in range
00047     int firstElement = 0;   
00048     ConstExpr fromVal;
00049     ConstExpr toVal;
00050 
00051     public Range() {
00052     this(- (1 << 31), (1 << 31) - 1);
00053     }
00054     public Range(int lo, int hi) {
00055     this.rangeSize = (hi - lo) + 1;
00056     this.firstElement = lo;
00057     this.fromVal = new IntLit(lo);
00058     this.toVal = new IntLit(hi);
00059     }
00060     public Range(ConstExpr fromVal, ConstExpr toVal) {
00061     this.fromVal = fromVal;
00062     this.toVal = toVal;
00063     this.firstElement = fromVal.getValue();
00064     this.rangeSize = (toVal.getValue() - fromVal.getValue()) + 1;
00065     }
00066     public void apply(TypeSwitch sw, Object o)
00067     {
00068         sw.caseRange(this, o);
00069     }
00070     public boolean containsValue(Object value) { 
00071     int val;
00072     if (value instanceof Integer) 
00073         val = ((Integer)value).intValue();
00074     else if (value instanceof ConstExpr)
00075         val = ((ConstExpr)value).getValue();
00076     else
00077         return false;
00078     return (val >= firstElement && val < firstElement + rangeSize);
00079     }
00080     public Expr defaultVal() { 
00081     // Zero if in range, else first element
00082     if (firstElement <= 0 && 0 <= (firstElement + rangeSize))
00083         return new IntLit(0);
00084     else
00085         return new IntLit(firstElement); 
00086     }
00087     public boolean equals(Object o) {
00088     return (o instanceof Range) && ((Range)o).rangeSize == this.rangeSize 
00089         && ((Range)o).firstElement == this.firstElement;
00090     }
00091     public int getFirstElement() { return firstElement; }
00092     public ConstExpr getFromVal() { return fromVal; }
00093     public int getRangeSize() { return rangeSize; }
00094     public ConstExpr getToVal() { return toVal; }
00095     public boolean isKind(int kind) { 
00096     return (kind & RANGE) != 0;
00097     }
00098     public boolean isSubtypeOf(Type type) { 
00099     if (! type.isKind(RANGE))
00100         return false; 
00101     Range other = (Range) type;
00102     return this.fromVal.getValue() >= other.fromVal.getValue()
00103         && this.toVal.getValue() <= other.toVal.getValue();
00104     }
00105     public String toString() {  
00106     return "range " + fromVal + ".." + toVal;
00107     }
00108 }

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