PageRenderTime 41ms CodeModel.GetById 11ms RepoModel.GetById 1ms app.codeStats 0ms

/Dependencies/boo/src/Boo.Lang/BooComparer.cs

https://github.com/w4x/boolangstudio
C# | 114 lines | 73 code | 11 blank | 30 comment | 19 complexity | db4aa65461ce3c19c05a4a2b9ede7bb4 MD5 | raw file
Possible License(s): GPL-2.0
  1. #region license
  2. // Copyright (c) 2004, Rodrigo B. de Oliveira (rbo@acm.org)
  3. // All rights reserved.
  4. //
  5. // Redistribution and use in source and binary forms, with or without modification,
  6. // are permitted provided that the following conditions are met:
  7. //
  8. // * Redistributions of source code must retain the above copyright notice,
  9. // this list of conditions and the following disclaimer.
  10. // * Redistributions in binary form must reproduce the above copyright notice,
  11. // this list of conditions and the following disclaimer in the documentation
  12. // and/or other materials provided with the distribution.
  13. // * Neither the name of Rodrigo B. de Oliveira nor the names of its
  14. // contributors may be used to endorse or promote products derived from this
  15. // software without specific prior written permission.
  16. //
  17. // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
  18. // ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
  19. // WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  20. // DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE
  21. // FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  22. // DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
  23. // SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
  24. // CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  25. // OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
  26. // THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  27. #endregion
  28. namespace Boo.Lang
  29. {
  30. using System;
  31. using System.Collections;
  32. /// <summary>
  33. /// Compares items lexicographically through IEnumerable whenever
  34. /// they don't implement IComparable.
  35. /// </summary>
  36. [Serializable]
  37. public class BooComparer : IComparer
  38. {
  39. public static readonly IComparer Default = new BooComparer();
  40. private BooComparer()
  41. {
  42. }
  43. public int Compare(object lhs, object rhs)
  44. {
  45. if (null == lhs)
  46. {
  47. if (null == rhs)
  48. {
  49. return 0;
  50. }
  51. return -1;
  52. }
  53. else
  54. {
  55. if (null == rhs)
  56. {
  57. return 1;
  58. }
  59. IComparable lhsComparable = lhs as IComparable;
  60. if (null == lhsComparable)
  61. {
  62. IComparable rhsComparable = rhs as IComparable;
  63. if (null == rhsComparable)
  64. {
  65. IEnumerable lhsEnumerable = lhs as IEnumerable;
  66. IEnumerable rhsEnumerable = rhs as IEnumerable;
  67. if (null != lhsEnumerable && null != rhsEnumerable)
  68. {
  69. return CompareEnumerables(lhsEnumerable, rhsEnumerable);
  70. }
  71. //throw new ArgumentException(ResourceManager.GetString("CantCompareItems"));
  72. return lhs.Equals(rhs) ? 0 : 1;
  73. }
  74. return -1*(rhsComparable.CompareTo(lhs));
  75. }
  76. return lhsComparable.CompareTo(rhs);
  77. }
  78. }
  79. int CompareEnumerables(IEnumerable lhs, IEnumerable rhs)
  80. {
  81. IEnumerator lhsEnum = lhs.GetEnumerator();
  82. IEnumerator rhsEnum = rhs.GetEnumerator();
  83. while (lhsEnum.MoveNext())
  84. {
  85. if (!rhsEnum.MoveNext())
  86. {
  87. return 1;
  88. }
  89. int value = Compare(lhsEnum.Current, rhsEnum.Current);
  90. if (0 == value)
  91. {
  92. continue;
  93. }
  94. return value;
  95. }
  96. if (rhsEnum.MoveNext())
  97. {
  98. return -1;
  99. }
  100. return 0;
  101. }
  102. }
  103. }