// // System.Object.cs // // Author: // Miguel de Icaza (miguel@ximian.com) // // (C) Ximian, Inc. http://www.ximian.com // // // // Copyright (C) 2004 Novell, Inc (http://www.novell.com) // // Permission is hereby granted, free of charge, to any person obtaining // a copy of this software and associated documentation files (the // "Software"), to deal in the Software without restriction, including // without limitation the rights to use, copy, modify, merge, publish, // distribute, sublicense, and/or sell copies of the Software, and to // permit persons to whom the Software is furnished to do so, subject to // the following conditions: // // The above copyright notice and this permission notice shall be // included in all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. // using System.Runtime.InteropServices; using System.Runtime.CompilerServices; using System.Runtime.ConstrainedExecution; namespace System { [Serializable] [ClassInterface (ClassInterfaceType.AutoDual)] [ComVisible (true)] public class Object { // // Compares this object to the specified object. // Returns true if they are equal, false otherwise. // public virtual bool Equals (object obj) { return this == obj; } // // Compares two objects for equality // public static bool Equals (object objA, object objB) { if (objA == objB) return true; if (objA == null || objB == null) return false; return objA.Equals (objB); } // // Initializes a new instance of the object class. // [ReliabilityContractAttribute (Consistency.WillNotCorruptState, Cer.MayFail)] public Object () { } // // Object destructor. // [ReliabilityContractAttribute (Consistency.WillNotCorruptState, Cer.Success)] ~Object () { } // // Returns a hashcode for this object. Each derived // class should return a hash code that makes sense // for that particular implementation of the object. // public virtual int GetHashCode () { return InternalGetHashCode (this); } // // Returns the Type associated with the object. // [MethodImplAttribute(MethodImplOptions.InternalCall)] public extern Type GetType (); // // Shallow copy of the object. // [MethodImplAttribute(MethodImplOptions.InternalCall)] protected extern object MemberwiseClone (); // // Returns a stringified representation of the object. // This is not supposed to be used for user presentation, // use Format() for that and IFormattable. // // ToString is mostly used for debugging purposes. // public virtual string ToString () { return GetType ().ToString (); } // // Tests whether a is equal to b. // Can not figure out why this even exists // [ReliabilityContractAttribute (Consistency.WillNotCorruptState, Cer.Success)] public static bool ReferenceEquals (object objA, object objB) { return (objA == objB); } [MethodImplAttribute(MethodImplOptions.InternalCall)] internal static extern int InternalGetHashCode (object o); #pragma warning disable 169 void FieldGetter (string typeName, string fieldName, ref object val) { /* never called */ } void FieldSetter (string typeName, string fieldName, object val) { /* never called */ } #pragma warning restore 169 } }