source: trunk/gcc/libjava/gnu/java/io/ObjectIdentityWrapper.java

Last change on this file was 2, checked in by bird, 22 years ago

Initial revision

  • Property cvs2svn:cvs-rev set to 1.1
  • Property svn:eol-style set to native
  • Property svn:executable set to *
File size: 3.3 KB
Line 
1/* ObjectIdentityWrapper.java -- Wrapper class used to override equals()
2 and hashCode() to be as discriminating as possible
3 Copyright (C) 1998 Free Software Foundation, Inc.
4
5This file is part of GNU Classpath.
6
7GNU Classpath is free software; you can redistribute it and/or modify
8it under the terms of the GNU General Public License as published by
9the Free Software Foundation; either version 2, or (at your option)
10any later version.
11
12GNU Classpath is distributed in the hope that it will be useful, but
13WITHOUT ANY WARRANTY; without even the implied warranty of
14MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15General Public License for more details.
16
17You should have received a copy of the GNU General Public License
18along with GNU Classpath; see the file COPYING. If not, write to the
19Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
2002111-1307 USA.
21
22Linking this library statically or dynamically with other modules is
23making a combined work based on this library. Thus, the terms and
24conditions of the GNU General Public License cover the whole
25combination.
26
27As a special exception, the copyright holders of this library give you
28permission to link this library with independent modules to produce an
29executable, regardless of the license terms of these independent
30modules, and to copy and distribute the resulting executable under
31terms of your choice, provided that you also meet, for each linked
32independent module, the terms and conditions of the license of that
33module. An independent module is a module which is not derived from
34or based on this library. If you modify this library, you may extend
35this exception to your version of the library, but you are not
36obligated to do so. If you do not wish to do so, delete this
37exception statement from your version. */
38
39
40package gnu.java.io;
41
42/**
43 This class is a thin wrapper around <code>Object</code> that makes
44 the methods <code>hashCode()</code> and <code>equals(Object)</code>
45 as discriminating as possible.
46*/
47public class ObjectIdentityWrapper
48{
49
50 /**
51 Constructs a <code>ObjectIdentityWrapper</code> that is wrapped
52 around o.
53 */
54 public ObjectIdentityWrapper( Object o )
55 {
56 object = o;
57 }
58
59 /**
60 Uses <code>System.identityHashCode(Object)</code> to compute a
61 hash code for the object wrapped by this
62 <code>ObjectIdentityWrapper</code>.
63
64 @see java.lang.System#identityHashCode(java.lang.Object)
65 @see java.util.Hashtable
66 @see java.lang.Object#hashCode()
67 */
68 public int hashCode()
69 {
70 return System.identityHashCode( object );
71 }
72
73 /**
74 Uses the <code>==</code> operator to test for equality between
75 the object wrapped by this <code>ObjectIdentityWrapper</code> and
76 the object wrapped by the <code>ObjectIdentityWrapper</code> o.
77 Returns false if o is not a <code>ObjectIdentityWrapper</code>.
78
79 @see java.util.Hashtable
80 @see java.lang.Object#equals()
81 */
82 public boolean equals( Object o )
83 {
84 if( o instanceof ObjectIdentityWrapper )
85 return object == ((ObjectIdentityWrapper)o).object;
86 else
87 return false;
88 }
89
90 public String toString()
91 {
92 return "ObjectIdentityWrapper< " + object + ", " + hashCode() + " >";
93 }
94
95 /**
96 The <code>Object</code> wrapped by this
97 <code>ObjectIdentityWrapper</code>.
98 */
99 public Object object;
100}
Note: See TracBrowser for help on using the repository browser.