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

LocVector.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 /**
00038  * A vector of Locations.
00039  */
00040 
00041 public class LocVector { 
00042 
00043     int size = 0;
00044     Location [] data;
00045 
00046     public LocVector() { this(5); }
00047     public LocVector(int capacity) {
00048     data = new Location[capacity];
00049     }
00050     public LocVector(Location x) {
00051     this(5);
00052     addElement(x);
00053     }
00054     public void addElement(Location x) {
00055     if (x == null)
00056         throw new RuntimeException("Element cannot be null");
00057     if (size == data.length)
00058         expand();
00059     data[size++] = x;
00060     }
00061     public Location bottom() { 
00062     if (size == 0)
00063         throw new RuntimeException("Cannot bottom() empty vector");
00064     return data[0]; 
00065     }
00066     public boolean contains(Location x) {
00067     for (int i = 0; i < size; i++) 
00068         if (data[i].equals(x))
00069         return true;
00070     return false;
00071     }
00072     public Location elementAt(int pos) {
00073     if (pos < 0 || pos >= size) 
00074         throw new RuntimeException("Position invalid: " + pos);
00075     return data[pos];
00076     }
00077     void expand() {
00078     Location [] newData = new Location[data.length * 2];
00079     for (int i = 0; i < data.length; i++) 
00080         newData[i] = data[i];
00081     data = newData;
00082     }
00083     public Location firstElement() { return elementAt(0); }
00084     public void insertElementAt(Location x, int pos) {
00085     if (x == null)
00086         throw new RuntimeException("Element cannot be null");
00087     if (size == data.length)
00088         expand();
00089     if (pos > size || pos < 0)
00090         throw new RuntimeException("Position invalid: " + pos);
00091     for (int i = size; i > pos; i--) 
00092         data[i] = data[i-1];
00093     data[pos] = x;
00094     size++;
00095     }
00096     public Location pop() {
00097     if (size == 0)
00098         throw new RuntimeException("Cannot pop() empty vector");
00099     size--;
00100     return data[size];
00101     }
00102     public void push(Location x) {
00103     addElement(x);
00104     }
00105     public boolean removeElement(Location x) {
00106     int pos = 0;
00107     while (pos < size && data[pos] != x) 
00108         pos++;
00109     if (pos == size)
00110         return false;
00111     for (int i = pos; i < size - 1; i++) 
00112         data[i] = data[i+1];
00113     size--;
00114     return true;
00115     }
00116     public int size() { return size; }
00117     public Location top() { 
00118     if (size == 0)
00119         throw new RuntimeException("Cannot top() empty vector");
00120     return data[size-1]; 
00121     }
00122 }

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