00001 package edu.ksu.cis.bandera.jjjc.decompiler; 00002 00003 /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 00004 * Bandera, a Java(TM) analysis and transformation toolkit * 00005 * Copyright (C) 2000 Roby Joehanes (robbyjo@cis.ksu.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 /** 00036 * DecompilerField basically holds the information of a field. 00037 * The methods and fields are self-explanatory. 00038 * @author <a href="mailto:robbyjo@cis.ksu.edu">Roby Joehanes</a> 00039 * @version 0.4.21 00040 **/ 00041 public class DecompilerField { 00042 private String name, type, defaultValue, modif; 00043 00044 /** 00045 * SlabsField constructor takes field name, type, and modifier. 00046 */ 00047 public DecompilerField(String fname, String ftype, String modi) { 00048 name = fname.trim(); 00049 type = ftype.trim(); 00050 modif = modi.trim(); 00051 defaultValue = ""; 00052 if (modi==null) modif = ""; 00053 } 00054 /** 00055 * 00056 * @return Field's default value in String 00057 */ 00058 public String getDefaultValue() { 00059 return defaultValue; 00060 } 00061 /** 00062 * 00063 * @return The modifier in String 00064 */ 00065 public String getModifier() { 00066 return modif; 00067 } 00068 /** 00069 * 00070 * @return Field's name 00071 */ 00072 public String getName() { 00073 return name; 00074 } 00075 /** 00076 * 00077 * @return Field's type in String 00078 */ 00079 public String getType() { 00080 return type; 00081 } 00082 /** 00083 * 00084 * @param Setting the field's default value in String 00085 */ 00086 public void setDefaultValue(String newDefaultValue) { 00087 defaultValue = newDefaultValue; 00088 } 00089 /** 00090 * 00091 * @param Setting new modifier 00092 */ 00093 public void setModifier(String newModi) { 00094 modif=newModi; 00095 } 00096 /** 00097 * 00098 * @param Setting field's name in String 00099 */ 00100 public void setName(String newName) { 00101 name = newName; 00102 } 00103 /** 00104 * 00105 * @param Setting field's type in String 00106 */ 00107 public void setType(String newType) { 00108 type = newType; 00109 } 00110 public String toString() 00111 { 00112 StringBuffer s = new StringBuffer(modif + " " + type + " " + name); 00113 if ((defaultValue != null) && (!defaultValue.equals(""))) 00114 s.append(" = " + defaultValue); 00115 s.append(";"); 00116 return s.toString(); 00117 } 00118 }