00001 package ca.mcgill.sable.soot.coffi; 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 * Coffi, a bytecode parser for the Java(TM) language. * 00038 * Copyright (C) 1996, 1997 Clark Verbrugge (clump@sable.mcgill.ca). * 00039 * All rights reserved. * 00040 * * 00041 * This work was done as a project of the Sable Research Group, * 00042 * School of Computer Science, McGill University, Canada * 00043 * (http://www.sable.mcgill.ca/). It is understood that any * 00044 * modification not identified as such is not covered by the * 00045 * preceding statement. * 00046 * * 00047 * This work is free software; you can redistribute it and/or * 00048 * modify it under the terms of the GNU Library General Public * 00049 * License as published by the Free Software Foundation; either * 00050 * version 2 of the License, or (at your option) any later version. * 00051 * * 00052 * This work is distributed in the hope that it will be useful, * 00053 * but WITHOUT ANY WARRANTY; without even the implied warranty of * 00054 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * 00055 * Library General Public License for more details. * 00056 * * 00057 * You should have received a copy of the GNU Library General Public * 00058 * License along with this library; if not, write to the * 00059 * Free Software Foundation, Inc., 59 Temple Place - Suite 330, * 00060 * Boston, MA 02111-1307, USA. * 00061 * * 00062 * Java is a trademark of Sun Microsystems, Inc. * 00063 * * 00064 * To submit a bug report, send a comment, or get the latest news on * 00065 * this project and other Sable Research Group projects, please * 00066 * visit the web site: http://www.sable.mcgill.ca/ * 00067 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */ 00068 00069 /* 00070 Reference Version 00071 ----------------- 00072 This is the latest official version on which this file is based. 00073 The reference version is: $CoffiVersion: 1.1 $ 00074 $SootVersion: 1.beta.4 $ 00075 00076 Change History 00077 -------------- 00078 A) Notes: 00079 00080 Please use the following template. Most recent changes should 00081 appear at the top of the list. 00082 00083 - Modified on [date (March 1, 1900)] by [name]. [(*) if appropriate] 00084 [description of modification]. 00085 00086 Any Modification flagged with "(*)" was done as a project of the 00087 Sable Research Group, School of Computer Science, 00088 McGill University, Canada (http://www.sable.mcgill.ca/). 00089 00090 You should add your copyright, using the following template, at 00091 the top of this file, along with other copyrights. 00092 00093 * * 00094 * Modifications by [name] are * 00095 * Copyright (C) [year(s)] [your name (or company)]. All rights * 00096 * reserved. * 00097 * * 00098 00099 B) Changes: 00100 00101 - Modified on November 2, 1998 by Raja Vallee-Rai (kor@sable.mcgill.ca) (*) 00102 Repackaged all source files and performed extensive modifications. 00103 First initial release of Soot. 00104 00105 - Modified on 15-Jun-1998 by Raja Vallee-Rai (kor@sable.mcgill.ca). (*) 00106 First internal release (Version 0.1). 00107 */ 00108 00109 import java.util.Enumeration; 00110 00111 /** An enumeration of a Utf8 allows one to run through the characters in a 00112 * unicode string; used primarily for comparing unicode strings. Note that 00113 * unlike regular enumerations, and to be efficient (ie to avoid allocating 00114 * an object in each call to nextElement), the return value is accessed by 00115 * this object's 'c' field, and nextElement merely returns this. 00116 * @see CONSTANT_Utf8_info 00117 * @see Utf8_Enumeration#c 00118 * @see Utf8_Enumeration#nextElement 00119 * @author Clark Verbrugge 00120 */ 00121 class Utf8_Enumeration implements Enumeration { 00122 00123 /** The latest character, as determined by nextElement. 00124 * @see Utf8_Enumeration#nextElement 00125 */ 00126 public int c; // latest character 00127 00128 private short curindex; 00129 private short length; 00130 private byte bytes[]; 00131 00132 /** For creating an empty enumeration; you must use reset() after this 00133 * to initialize the enumeration. 00134 * @see Utf8_Enumeration#reset 00135 */ 00136 public Utf8_Enumeration() {} 00137 /** For creating a normal enumeration of the given Utf8 string. 00138 * @param b array of bytes in Utf8 format. 00139 */ 00140 public Utf8_Enumeration(byte b[]) { 00141 bytes = b; 00142 curindex = (short)2; 00143 length = (short)(((((int)(bytes[0]))&0xff)<<8) + (((int)(bytes[1]))&0xff) + 2); 00144 } 00145 /** <i>true</i> if the entire string hasn't been enumerated yet. */ 00146 public boolean hasMoreElements() { 00147 if (curindex<length) return true; 00148 return false; 00149 } 00150 /** Determines the next Utf8 character, and stores it in c. 00151 * @return <i>this</i> 00152 * @see Utf8_Enumeration#c 00153 */ 00154 public Object nextElement() { 00155 byte b; 00156 b = bytes[curindex++]; 00157 if ((b&((byte)0x80))==0) { // one-byte character 00158 c = b; 00159 } else if ((b&((byte)0xe0))==0xc0) { // two-byte character 00160 c = ((int)(b&((byte)0x1f)))<<6; 00161 b = bytes[curindex++]; 00162 c |= (int)(b&((byte)0x3f)); 00163 } else { // three-byte character 00164 c = ((int)(b&((byte)0x0f)))<<12; 00165 b = bytes[curindex++]; 00166 c |= ((int)(b&((byte)0x3f)))<<6; 00167 b = bytes[curindex++]; 00168 c |= (int)(b&((byte)0x3f)); 00169 } 00170 return this; 00171 } 00172 /** Resets this object to be an enumeration of the given Utf8 string. 00173 * @param b array of bytes in Utf8 format. 00174 */ 00175 public void reset(byte b[]) { 00176 bytes = b; 00177 curindex = (short)2; 00178 length = (short)(((((int)(bytes[0]))&0xff)<<8) + (((int)(bytes[1]))&0xff) + 2); 00179 } 00180 }