File: TraceUtility.cs

package info (click to toggle)
mono 6.14.1%2Bds2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,282,732 kB
  • sloc: cs: 11,182,461; xml: 2,850,281; ansic: 699,123; cpp: 122,919; perl: 58,604; javascript: 30,841; asm: 21,845; makefile: 19,602; sh: 10,973; python: 4,772; pascal: 925; sql: 859; sed: 16; php: 1
file content (73 lines) | stat: -rw-r--r-- 3,613 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
70
71
72
73
//------------------------------------------------------------
// Copyright (c) Microsoft Corporation.  All rights reserved.
//------------------------------------------------------------

namespace System.IdentityModel.Diagnostics
{
    using System.Collections.Generic;
    using System.Diagnostics;
    using System.Globalization;
    using System.Runtime;
    using System.Runtime.CompilerServices;
    using System.Runtime.Diagnostics;

    static class TraceCode
    {
        // IdentityModel TraceCodes
        public const int IdentityModel = 0xC0000;
        public const int AuthorizationContextCreated = TraceCode.IdentityModel | 0X0002;
        public const int AuthorizationPolicyEvaluated = TraceCode.IdentityModel | 0X0003;
        public const int ServiceBindingCheck = TraceCode.IdentityModel | 0X0004;
        public const int ChannelBindingCheck = TraceCode.IdentityModel | 0x0005;
        public const int Diagnostics = TraceCode.IdentityModel | 0x0006;
    }

    static class TraceUtility
    {
        static Dictionary<int, string> traceCodes = new Dictionary<int, string>( 5 )
        {
            { TraceCode.IdentityModel, "IdentityModel" },
            { TraceCode.AuthorizationContextCreated, "AuthorizationContextCreated" },
            { TraceCode.AuthorizationPolicyEvaluated, "AuthorizationPolicyEvaluated" },
            { TraceCode.ServiceBindingCheck, "ServiceBindingCheck" },
            { TraceCode.ChannelBindingCheck, "ChannelBindingCheck" },
            { TraceCode.Diagnostics, "Diagnostics" }
        };

        internal static void TraceEvent( TraceEventType severity, int traceCode, string traceDescription )
        {
            TraceEvent( severity, traceCode, traceDescription, null, null, null );
        }

        // These methods require a TraceRecord to be allocated, so we want them to show up on profiles if the caller didn't avoid
        // allocating the TraceRecord by using ShouldTrace.
        [MethodImpl( MethodImplOptions.NoInlining )]
        internal static void TraceEvent( TraceEventType severity, int traceCode, string traceDescription, TraceRecord extendedData, object source, Exception exception )
        {
            if ( DiagnosticUtility.ShouldTrace( severity ) )
            {
                Guid activityId = DiagnosticTraceBase.ActivityId;
                Fx.Assert( traceCodes.ContainsKey( traceCode ),
                    string.Format( CultureInfo.InvariantCulture, "Unsupported trace code: Please add trace code 0x{0} to the dictionary TraceUtility.traceCodes in {1}",
                    traceCode.ToString( "X", CultureInfo.InvariantCulture ), typeof( TraceUtility ) ) );
                string msdnTraceCode = System.ServiceModel.Diagnostics.LegacyDiagnosticTrace.GenerateMsdnTraceCode( "System.IdentityModel", traceCodes[traceCode]);
                DiagnosticUtility.DiagnosticTrace.TraceEvent( severity, traceCode, msdnTraceCode, traceDescription, extendedData, exception, activityId, source );
            }
        }

        internal static void TraceString( TraceEventType eventType, string formatString, params object[] args )
        {
            if ( DiagnosticUtility.ShouldTrace( eventType ) )
            {
                if ( null != args && args.Length > 0 )
                {
                    TraceEvent( eventType, TraceCode.IdentityModel, String.Format( CultureInfo.InvariantCulture, formatString, args ) );
                }
                else
                {
                    TraceEvent( eventType, TraceCode.IdentityModel, formatString );
                }
            }
        }
    }
}