blob: ee570dd34c6974a20747a680dda179447e4d67b8 (
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
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
|
/**
* Namespace: System.Web.Utils
* Class: WebEqualComparer
*
* Author: Gaurav Vaish
* Maintainer: gvaish@iitk.ac.in
* Contact: <my_scripts2001@yahoo.com>, <gvaish@iitk.ac.in>
* Implementation: yes
* Status: ??%
*
* (C) Gaurav Vaish (2001)
*/
using System;
using System.Globalization;
using System.Collections;
namespace System.Web.Utils
{
public class WebEqualComparer : IComparer
{
private static IComparer defC;
public WebEqualComparer()
{
}
public static IComparer Default
{
get
{
if(defC == null)
{
defC = new WebEqualComparer();
}
return defC;
}
}
/// <summary>
/// To compare two strings
/// </summary>
/// <remarks>
/// Cannot apply String.Compare(..) since I am at web
/// </remarks>
int IComparer.Compare(object left, object right)
{
string leftStr, rightStr;
leftStr = null;
rightStr = null;
if(left is string)
{
leftStr = (string)left;
}
if(right is string)
{
rightStr = (string)right;
}
if(leftStr==null || rightStr==null)
{
throw new ArgumentException();
}
int ll = leftStr.Length;
int lr = rightStr.Length;
if(ll==0 && lr==0)
{
return 0;
}
if(ll==0 || lr==0)
{
return ( (ll > 0) ? 1 : -1);
}
char cl,cr;
int i=0;
for(i=0; i < leftStr.Length; i++)
{
if(i==lr)
{
return 1;
}
cl = leftStr[i];
cr = leftStr[i];
if(cl==cr)
{
continue;
}
UnicodeCategory ucl = Char.GetUnicodeCategory(cl);
UnicodeCategory ucr = Char.GetUnicodeCategory(cr);
if(ucl==ucr)
{
return ( (cl > cr) ? 1 : -1 );
}
cl = Char.ToLower(cl);
cr = Char.ToLower(cr);
if(cl!=cr)
{
return ( (cl > cr) ? 1 : -1);
}
}
return ( (i==lr) ? 0 : -1 );
}
}
}
|