00001 package edu.ksu.cis.bandera.jjjc.node;
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036 import ca.mcgill.sable.util.*;
00037 import edu.ksu.cis.bandera.jjjc.analysis.*;
00038
00039 public final class APrimaryNoNewArrayArrayAccess extends PArrayAccess
00040 {
00041 private PExp _first_;
00042 private TLBracket _lBracket_;
00043 private PExp _second_;
00044 private TRBracket _rBracket_;
00045
00046 public APrimaryNoNewArrayArrayAccess()
00047 {
00048 }
00049 public APrimaryNoNewArrayArrayAccess(
00050 PExp _first_,
00051 TLBracket _lBracket_,
00052 PExp _second_,
00053 TRBracket _rBracket_)
00054 {
00055 setFirst(_first_);
00056
00057 setLBracket(_lBracket_);
00058
00059 setSecond(_second_);
00060
00061 setRBracket(_rBracket_);
00062
00063 }
00064 public void apply(Switch sw)
00065 {
00066 ((Analysis) sw).caseAPrimaryNoNewArrayArrayAccess(this);
00067 }
00068 public Object clone()
00069 {
00070 return new APrimaryNoNewArrayArrayAccess(
00071 (PExp) cloneNode(_first_),
00072 (TLBracket) cloneNode(_lBracket_),
00073 (PExp) cloneNode(_second_),
00074 (TRBracket) cloneNode(_rBracket_));
00075 }
00076 public PExp getFirst()
00077 {
00078 return _first_;
00079 }
00080 public TLBracket getLBracket()
00081 {
00082 return _lBracket_;
00083 }
00084 public TRBracket getRBracket()
00085 {
00086 return _rBracket_;
00087 }
00088 public PExp getSecond()
00089 {
00090 return _second_;
00091 }
00092 void removeChild(Node child)
00093 {
00094 if(_first_ == child)
00095 {
00096 _first_ = null;
00097 return;
00098 }
00099
00100 if(_lBracket_ == child)
00101 {
00102 _lBracket_ = null;
00103 return;
00104 }
00105
00106 if(_second_ == child)
00107 {
00108 _second_ = null;
00109 return;
00110 }
00111
00112 if(_rBracket_ == child)
00113 {
00114 _rBracket_ = null;
00115 return;
00116 }
00117
00118 }
00119 void replaceChild(Node oldChild, Node newChild)
00120 {
00121 if(_first_ == oldChild)
00122 {
00123 setFirst((PExp) newChild);
00124 return;
00125 }
00126
00127 if(_lBracket_ == oldChild)
00128 {
00129 setLBracket((TLBracket) newChild);
00130 return;
00131 }
00132
00133 if(_second_ == oldChild)
00134 {
00135 setSecond((PExp) newChild);
00136 return;
00137 }
00138
00139 if(_rBracket_ == oldChild)
00140 {
00141 setRBracket((TRBracket) newChild);
00142 return;
00143 }
00144
00145 }
00146 public void setFirst(PExp node)
00147 {
00148 if(_first_ != null)
00149 {
00150 _first_.parent(null);
00151 }
00152
00153 if(node != null)
00154 {
00155 if(node.parent() != null)
00156 {
00157 node.parent().removeChild(node);
00158 }
00159
00160 node.parent(this);
00161 }
00162
00163 _first_ = node;
00164 }
00165 public void setLBracket(TLBracket node)
00166 {
00167 if(_lBracket_ != null)
00168 {
00169 _lBracket_.parent(null);
00170 }
00171
00172 if(node != null)
00173 {
00174 if(node.parent() != null)
00175 {
00176 node.parent().removeChild(node);
00177 }
00178
00179 node.parent(this);
00180 }
00181
00182 _lBracket_ = node;
00183 }
00184 public void setRBracket(TRBracket node)
00185 {
00186 if(_rBracket_ != null)
00187 {
00188 _rBracket_.parent(null);
00189 }
00190
00191 if(node != null)
00192 {
00193 if(node.parent() != null)
00194 {
00195 node.parent().removeChild(node);
00196 }
00197
00198 node.parent(this);
00199 }
00200
00201 _rBracket_ = node;
00202 }
00203 public void setSecond(PExp node)
00204 {
00205 if(_second_ != null)
00206 {
00207 _second_.parent(null);
00208 }
00209
00210 if(node != null)
00211 {
00212 if(node.parent() != null)
00213 {
00214 node.parent().removeChild(node);
00215 }
00216
00217 node.parent(this);
00218 }
00219
00220 _second_ = node;
00221 }
00222 public String toString()
00223 {
00224 return ""
00225 + toString(_first_)
00226 + toString(_lBracket_)
00227 + toString(_second_)
00228 + toString(_rBracket_);
00229 }
00230 }