Comparer.cs 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. //
  2. // Comparer
  3. //
  4. // Authors:
  5. // Ben Maurer ([email protected])
  6. //
  7. // Copyright (C) 2004 Novell, Inc (http://www.novell.com)
  8. //
  9. // Permission is hereby granted, free of charge, to any person obtaining
  10. // a copy of this software and associated documentation files (the
  11. // "Software"), to deal in the Software without restriction, including
  12. // without limitation the rights to use, copy, modify, merge, publish,
  13. // distribute, sublicense, and/or sell copies of the Software, and to
  14. // permit persons to whom the Software is furnished to do so, subject to
  15. // the following conditions:
  16. //
  17. // The above copyright notice and this permission notice shall be
  18. // included in all copies or substantial portions of the Software.
  19. //
  20. // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  21. // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  22. // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
  23. // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
  24. // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
  25. // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
  26. // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  27. //
  28. #if NET_2_0
  29. using System;
  30. using System.Runtime.InteropServices;
  31. namespace System.Collections.Generic {
  32. [CLSCompliant(false)]
  33. public abstract class Comparer<T> : IComparer<T>, System.Collections.IKeyComparer,
  34. System.Collections.IComparer, System.Collections.IHashCodeProvider {
  35. public Comparer () {} /* workaround 60438 by not having a protected ctor */
  36. public abstract int Compare (T x, T y);
  37. public abstract bool Equals (T x, T y);
  38. public virtual int GetHashCode (T obj)
  39. {
  40. if (obj == null)
  41. throw new ArgumentNullException ();
  42. return obj.GetHashCode ();
  43. }
  44. static DefaultComparer <T> _default;
  45. public static Comparer<T> Default
  46. {
  47. get {
  48. throw new NotImplementedException ("Waiting on bug#60437");
  49. //if (_default != null)
  50. // return _default;
  51. //return _default = new DefaultComparer<T> ();
  52. }
  53. }
  54. int System.Collections.IComparer.Compare (object x, object y)
  55. {
  56. return this.Compare ((T)x, (T)y);
  57. }
  58. bool System.Collections.IKeyComparer.Equals (object x, object y)
  59. {
  60. return this.Equals ((T) x, (T) y);
  61. }
  62. int System.Collections.IHashCodeProvider.GetHashCode (object obj)
  63. {
  64. return this.GetHashCode ((T)obj);
  65. }
  66. class DefaultComparer<T> : Comparer<T> {
  67. public override int Compare (T x, T y)
  68. {
  69. // `null' is less than any other ref type
  70. if (x == null)
  71. return y == null ? 0 : -1;
  72. else if (y == null)
  73. return 1;
  74. if (x is IComparable<T>)
  75. return ((IComparable<T>) x).CompareTo (y);
  76. else if (x is IComparable)
  77. return ((IComparable) x).CompareTo (y);
  78. else
  79. throw new ArgumentException ("does not implement right interface");
  80. }
  81. public override bool Equals (T x, T y)
  82. {
  83. return System.Object.Equals (x, y);
  84. }
  85. }
  86. }
  87. }
  88. #endif