if (obj instanceof Input) {\r
\r
Input temp = (Input)obj;\r
+ boolean thcycle;\r
+ boolean tmcycle;\r
if (this._name != null) {\r
if (temp._name == null) return false;\r
- else if (!(this._name.equals(temp._name))) \r
- return false;\r
- }\r
- else if (temp._name != null)\r
+ if (this._name != temp._name) {\r
+ thcycle=org.castor.util.CycleBreaker.startingToCycle(this._name);\r
+ tmcycle=org.castor.util.CycleBreaker.startingToCycle(temp._name);\r
+ if (thcycle!=tmcycle) {\r
+ if (!thcycle) { org.castor.util.CycleBreaker.releaseCycleHandle(this._name); };\r
+ if (!tmcycle) { org.castor.util.CycleBreaker.releaseCycleHandle(temp._name); };\r
+ return false;\r
+ }\r
+ if (!thcycle) {\r
+ if (!this._name.equals(temp._name)) {\r
+ org.castor.util.CycleBreaker.releaseCycleHandle(this._name);\r
+ org.castor.util.CycleBreaker.releaseCycleHandle(temp._name);\r
+ return false;\r
+ }\r
+ org.castor.util.CycleBreaker.releaseCycleHandle(this._name);\r
+ org.castor.util.CycleBreaker.releaseCycleHandle(temp._name);\r
+ }\r
+ }\r
+ } else if (temp._name != null)\r
return false;\r
if (this._objRef != null) {\r
if (temp._objRef == null) return false;\r
- else if (!(this._objRef.equals(temp._objRef))) \r
- return false;\r
- }\r
- else if (temp._objRef != null)\r
+ if (this._objRef != temp._objRef) {\r
+ thcycle=org.castor.util.CycleBreaker.startingToCycle(this._objRef);\r
+ tmcycle=org.castor.util.CycleBreaker.startingToCycle(temp._objRef);\r
+ if (thcycle!=tmcycle) {\r
+ if (!thcycle) { org.castor.util.CycleBreaker.releaseCycleHandle(this._objRef); };\r
+ if (!tmcycle) { org.castor.util.CycleBreaker.releaseCycleHandle(temp._objRef); };\r
+ return false;\r
+ }\r
+ if (!thcycle) {\r
+ if (!this._objRef.equals(temp._objRef)) {\r
+ org.castor.util.CycleBreaker.releaseCycleHandle(this._objRef);\r
+ org.castor.util.CycleBreaker.releaseCycleHandle(temp._objRef);\r
+ return false;\r
+ }\r
+ org.castor.util.CycleBreaker.releaseCycleHandle(this._objRef);\r
+ org.castor.util.CycleBreaker.releaseCycleHandle(temp._objRef);\r
+ }\r
+ }\r
+ } else if (temp._objRef != null)\r
return false;\r
return true;\r
}\r
int result = super.hashCode();\r
\r
long tmp;\r
- if (_name != null) {\r
+ if (_name != null\r
+ && !org.castor.util.CycleBreaker.startingToCycle(_name)) {\r
result = 37 * result + _name.hashCode();\r
+ org.castor.util.CycleBreaker.releaseCycleHandle(_name);\r
}\r
- if (_objRef != null) {\r
+ if (_objRef != null\r
+ && !org.castor.util.CycleBreaker.startingToCycle(_objRef)) {\r
result = 37 * result + _objRef.hashCode();\r
+ org.castor.util.CycleBreaker.releaseCycleHandle(_objRef);\r
}\r
\r
return result;\r