00001 package edu.ksu.cis.bandera.abstraction.specification.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
00037
00038 import java.util.*;
00039 import edu.ksu.cis.bandera.abstraction.specification.analysis.*;
00040
00041 public final class ANeqEqExp extends PEqExp
00042 {
00043 private PEqExp _eqExp_;
00044 private TNotEqual _notEqual_;
00045 private PRelExp _relExp_;
00046
00047 public ANeqEqExp()
00048 {
00049 }
00050 public ANeqEqExp(
00051 PEqExp _eqExp_,
00052 TNotEqual _notEqual_,
00053 PRelExp _relExp_)
00054 {
00055 setEqExp(_eqExp_);
00056
00057 setNotEqual(_notEqual_);
00058
00059 setRelExp(_relExp_);
00060
00061 }
00062 public void apply(Switch sw)
00063 {
00064 ((Analysis) sw).caseANeqEqExp(this);
00065 }
00066 public Object clone()
00067 {
00068 return new ANeqEqExp(
00069 (PEqExp) cloneNode(_eqExp_),
00070 (TNotEqual) cloneNode(_notEqual_),
00071 (PRelExp) cloneNode(_relExp_));
00072 }
00073 public PEqExp getEqExp()
00074 {
00075 return _eqExp_;
00076 }
00077 public TNotEqual getNotEqual()
00078 {
00079 return _notEqual_;
00080 }
00081 public PRelExp getRelExp()
00082 {
00083 return _relExp_;
00084 }
00085 void removeChild(Node child)
00086 {
00087 if(_eqExp_ == child)
00088 {
00089 _eqExp_ = null;
00090 return;
00091 }
00092
00093 if(_notEqual_ == child)
00094 {
00095 _notEqual_ = null;
00096 return;
00097 }
00098
00099 if(_relExp_ == child)
00100 {
00101 _relExp_ = null;
00102 return;
00103 }
00104
00105 }
00106 void replaceChild(Node oldChild, Node newChild)
00107 {
00108 if(_eqExp_ == oldChild)
00109 {
00110 setEqExp((PEqExp) newChild);
00111 return;
00112 }
00113
00114 if(_notEqual_ == oldChild)
00115 {
00116 setNotEqual((TNotEqual) newChild);
00117 return;
00118 }
00119
00120 if(_relExp_ == oldChild)
00121 {
00122 setRelExp((PRelExp) newChild);
00123 return;
00124 }
00125
00126 }
00127 public void setEqExp(PEqExp node)
00128 {
00129 if(_eqExp_ != null)
00130 {
00131 _eqExp_.parent(null);
00132 }
00133
00134 if(node != null)
00135 {
00136 if(node.parent() != null)
00137 {
00138 node.parent().removeChild(node);
00139 }
00140
00141 node.parent(this);
00142 }
00143
00144 _eqExp_ = node;
00145 }
00146 public void setNotEqual(TNotEqual node)
00147 {
00148 if(_notEqual_ != null)
00149 {
00150 _notEqual_.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 _notEqual_ = node;
00164 }
00165 public void setRelExp(PRelExp node)
00166 {
00167 if(_relExp_ != null)
00168 {
00169 _relExp_.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 _relExp_ = node;
00183 }
00184 public String toString()
00185 {
00186 return ""
00187 + toString(_eqExp_)
00188 + toString(_notEqual_)
00189 + toString(_relExp_);
00190 }
00191 }