File: RuleInfoComparer.cs

package info (click to toggle)
mono 6.12.0.199%2Bdfsg-6
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 1,296,836 kB
  • sloc: cs: 11,181,803; xml: 2,850,076; ansic: 699,709; cpp: 123,344; perl: 59,361; javascript: 30,841; asm: 21,853; makefile: 20,405; sh: 15,009; python: 4,839; pascal: 925; sql: 859; sed: 16; php: 1
file content (69 lines) | stat: -rw-r--r-- 2,682 bytes parent folder | download | duplicates (7)
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
//------------------------------------------------------------------------------
// <copyright file="RuleInfoComparer.cs" company="Microsoft">
//     Copyright (c) Microsoft Corporation.  All rights reserved.
// </copyright>
//------------------------------------------------------------------------------

namespace System.Web.Configuration
{
    using System;
    using System.Xml;
    using System.Configuration;
    using System.Collections.Specialized;
    using System.Collections;
    using System.Globalization;
    using System.IO;
    using System.Text;
    using System.ComponentModel;
    using System.Web.Hosting;
    using System.Web.Util;
    using System.Web.Configuration;
    using System.Web.Management;
    using System.Web.Compilation;

    //
    // This class is used to compare two RuleInfo object.  Basically, the array list
    // will be sorted based on class hierachical order.  The smaller the value, the
    // more nearer the class is to the root (WebBaseEvent), in a class inheritance sense.
    // 
    // On the other hand, if x > y, it means x is NOT a parent class of y.
    //
    // The array is sorted in this way so that if we want to find out the config setting of
    // an event class x, we start searching in a decreasing order, and the first entry (E)
    // that satifies the test: if (x is E), then we find the right settings for x.
    //
    // BTW, this is just a trick to save me from writing too much code.  A n-node tree
    // method is faster, but I was too lazy.
    //
    internal class RuleInfoComparer : IComparer{
        public int Compare(object x, object y) {
            int res;
            
            Type xType = 
                ((HealthMonitoringSectionHelper.RuleInfo)x)._eventMappingSettings.RealType;
            Type yType = 
                ((HealthMonitoringSectionHelper.RuleInfo)y)._eventMappingSettings.RealType;
    
            if (xType.Equals(yType)) {
                res = 0;
            } 
            else if (xType.IsSubclassOf(yType)) {
                res = 1;
            } 
            else if (yType.IsSubclassOf(xType)) {
                res = -1;
            }
            else {
                // If they're unrelated, we can't return 0 because it
                // will confuse the sorting method.
                // We can return 1 or -1, but it must be consistent.
                return String.Compare(xType.ToString(), yType.ToString(), StringComparison.Ordinal);
            }
    
            Debug.Trace("RuleInfoComparer", "xType=" + xType.ToString() +
                "; yType=" + yType.ToString() + "; res=" + res);
            
            return res;
        }
    }
}