sequence mappings and DbRef mapping objects unified and source binding for castor...
[vamsas.git] / src / uk / ac / vamsas / objects / core / Link.java
index aea537d..17633cf 100644 (file)
@@ -70,19 +70,51 @@ implements java.io.Serializable
         if (obj instanceof Link) {\r
         \r
             Link temp = (Link)obj;\r
+            boolean thcycle;\r
+            boolean tmcycle;\r
             if (this._content != null) {\r
                 if (temp._content == null) return false;\r
-                else if (!(this._content.equals(temp._content))) \r
-                    return false;\r
-            }\r
-            else if (temp._content != null)\r
+                if (this._content != temp._content) {\r
+                    thcycle=org.castor.util.CycleBreaker.startingToCycle(this._content);\r
+                    tmcycle=org.castor.util.CycleBreaker.startingToCycle(temp._content);\r
+                    if (thcycle!=tmcycle) {\r
+                        if (!thcycle) { org.castor.util.CycleBreaker.releaseCycleHandle(this._content); };\r
+                        if (!tmcycle) { org.castor.util.CycleBreaker.releaseCycleHandle(temp._content); };\r
+                        return false;\r
+                    }\r
+                    if (!thcycle) {\r
+                        if (!this._content.equals(temp._content)) {\r
+                            org.castor.util.CycleBreaker.releaseCycleHandle(this._content);\r
+                            org.castor.util.CycleBreaker.releaseCycleHandle(temp._content);\r
+                            return false;\r
+                        }\r
+                        org.castor.util.CycleBreaker.releaseCycleHandle(this._content);\r
+                        org.castor.util.CycleBreaker.releaseCycleHandle(temp._content);\r
+                    }\r
+                }\r
+            } else if (temp._content != null)\r
                 return false;\r
             if (this._href != null) {\r
                 if (temp._href == null) return false;\r
-                else if (!(this._href.equals(temp._href))) \r
-                    return false;\r
-            }\r
-            else if (temp._href != null)\r
+                if (this._href != temp._href) {\r
+                    thcycle=org.castor.util.CycleBreaker.startingToCycle(this._href);\r
+                    tmcycle=org.castor.util.CycleBreaker.startingToCycle(temp._href);\r
+                    if (thcycle!=tmcycle) {\r
+                        if (!thcycle) { org.castor.util.CycleBreaker.releaseCycleHandle(this._href); };\r
+                        if (!tmcycle) { org.castor.util.CycleBreaker.releaseCycleHandle(temp._href); };\r
+                        return false;\r
+                    }\r
+                    if (!thcycle) {\r
+                        if (!this._href.equals(temp._href)) {\r
+                            org.castor.util.CycleBreaker.releaseCycleHandle(this._href);\r
+                            org.castor.util.CycleBreaker.releaseCycleHandle(temp._href);\r
+                            return false;\r
+                        }\r
+                        org.castor.util.CycleBreaker.releaseCycleHandle(this._href);\r
+                        org.castor.util.CycleBreaker.releaseCycleHandle(temp._href);\r
+                    }\r
+                }\r
+            } else if (temp._href != null)\r
                 return false;\r
             return true;\r
         }\r
@@ -124,11 +156,15 @@ implements java.io.Serializable
         int result = super.hashCode();\r
         \r
         long tmp;\r
-        if (_content != null) {\r
+        if (_content != null\r
+            && !org.castor.util.CycleBreaker.startingToCycle(_content)) {\r
            result = 37 * result + _content.hashCode();\r
+           org.castor.util.CycleBreaker.releaseCycleHandle(_content);\r
         }\r
-        if (_href != null) {\r
+        if (_href != null\r
+            && !org.castor.util.CycleBreaker.startingToCycle(_href)) {\r
            result = 37 * result + _href.hashCode();\r
+           org.castor.util.CycleBreaker.releaseCycleHandle(_href);\r
         }\r
         \r
         return result;\r