summaryrefslogtreecommitdiffstats
path: root/sdo-java/branches/emf-2.5/sdo-api/src/main/java/commonj/sdo/helper/EqualityHelper.java
blob: 31cd9b686fb1dce7565a8ed72e605393ffb11dbb (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
/**
 * <copyright>
 *
 * Service Data Objects
 * Version 2.1.0
 * Licensed Materials
 *
 * (c) Copyright BEA Systems, Inc., International Business Machines Corporation, 
 * Oracle Corporation, Primeton Technologies Ltd., Rogue Wave Software, SAP AG., 
 * Software AG., Sun Microsystems, Sybase Inc., Xcalia, Zend Technologies, 
 * 2005, 2006. All rights reserved.
 *
 * </copyright>
 * 
 */

package commonj.sdo.helper;

import commonj.sdo.DataObject;
import commonj.sdo.impl.HelperProvider;

/**
 * A helper for comparing DataObjects.
 */
public interface EqualityHelper
{
  /**
   * <p>Two DataObjects are equalShallow if
   *  they have the same {@link DataObject#getType Type}
   *  and all their compared Properties are equal.
   *  The set of Properties compared are the 
   *  {@link DataObject#getInstanceProperties() instance properties}
   *  where property.getType().isDataType() is true
   *  and property.getType() is not ChangeSummaryType.
   * <br/>Two of these Property values are equal if they are both not
   *  {@link DataObject#isSet(Property) set}, or set to an equal value
   *  dataObject1.get(property).equals(dataObject2.get(property))
   * <br/>If the type is a sequenced type, the sequence entries must be the same.
   *  For each entry x in the sequence where the property is used in the comparison,
   *  dataObject1.getSequence().getValue(x).equals(
   *   dataObject2.getSequence().getValue(x)) and
   *  dataObject1.getSequence().getProperty(x) == 
   *   dataObject2.getSequence().getProperty(x)
   *  must be true.
   * </p>
   *  Returns true the objects have the same Type and all values of all compared Properties are equal.
   *  @param dataObject1 DataObject to be compared
   *  @param dataObject2 DataObject to be compared
   *  @return true the objects have the same Type and all values of all compared Properties are equal.
   */
  boolean equalShallow(DataObject dataObject1, DataObject dataObject2);
    
  /**
   * <p>Two DataObjects are equal(Deep) if they are equalShallow,
   *  all their compared Properties are equal, and all reachable DataObjects in their
   *  graphs excluding containers are equal.
   *  The set of Properties compared are the 
   *  {@link DataObject#getInstanceProperties() instance properties}
   *  where property.getType().isDataType() is false, 
   *  and is not a container property, ie !property.getOpposite().isContainment()
   * <br/>Two of these Property values are equal if they are both not
   *  {@link DataObject#isSet(Property) set}, or all the DataObjects
   *  they refer to are {@link #equal(DataObject, DataObject) equal} in the 
   *  context of dataObject1 and dataObject2.
   * <br/>Note that properties to a containing DataObject are not compared
   *  which means two DataObject trees can be equal even if their containers are not equal.
   * <br/>If the type is a sequenced type, the sequence entries must be the same.
   *  For each entry x in the sequence where the property is used in the comparison,
   *  equal(dataObject1.getSequence().getValue(x), 
   *   dataObject2.getSequence().getValue(x)) and
   *  dataObject1.getSequence().getProperty(x) == 
   *   dataObject2.getSequence().getProperty(x)
   *  must be true.
   * </p><p>
   * A DataObject directly or indirectly referenced by dataObject1 or dataObject2 
   *  can only be equal to exactly one DataObject directly or indirectly referenced 
   *  by dataObject1 or dataObject2, respectively.
   *  This ensures that dataObject1 and dataObject2 are equal if the graph formed by 
   *  all their referenced DataObjects have the same shape.
   * </p>
   *  Returns true if the trees of DataObjects are equal(Deep). 
   *  @param dataObject1 DataObject to be compared
   *  @param dataObject2 DataObject to be compared
   *  @return true if the trees of DataObjects are equal(Deep). 
   */
  boolean equal(DataObject dataObject1, DataObject dataObject2);

  /**
   * The default EqualityHelper.
   */
  EqualityHelper INSTANCE = HelperProvider.getEqualityHelper();
}