Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / Orcas / NetFXw7 / wpf / src / Base / System / Diagnostics / PresentationTraceSources.cs / 1 / PresentationTraceSources.cs
/****************************************************************************\ * * File: PresentationTraceSources.cs * * This class provides a public interface to access TraceSources for * enabling/disabling/filtering of trace messages by area. * * The other portion of this partial class is generated using * genTraceSource.pl and AvTraceMessages.txt * * Copyright (C) by Microsoft Corporation. All rights reserved. * \***************************************************************************/ using System.Collections.Generic; using System.Security; using System.Security.Permissions; using MS.Internal; using System.Windows; namespace System.Diagnostics { ////// PresentationTraceLevel - Enum which describes how much detail to trace about a particular object. /// public enum PresentationTraceLevel { ////// Trace no additional information. /// None, ////// Trace some additional information. /// Low, ////// Trace a medium amount of additional information. /// Medium, ////// Trace all available additional information. /// High, } ////// Helper class for retrieving TraceSources /// public static partial class PresentationTraceSources { //----------------------------------------------------- // // Public Properties // //----------------------------------------------------- ////// DependencyProperty for TraceLevel property. /// public static readonly DependencyProperty TraceLevelProperty = DependencyProperty.RegisterAttached( "TraceLevel", typeof(PresentationTraceLevel), typeof(PresentationTraceSources)); ////// Reads the attached property TraceLevel from the given element. /// public static PresentationTraceLevel GetTraceLevel(object element) { return TraceLevelStore.GetTraceLevel(element); } ////// Writes the attached property TraceLevel to the given element. /// public static void SetTraceLevel(object element, PresentationTraceLevel traceLevel) { TraceLevelStore.SetTraceLevel(element, traceLevel); } //----------------------------------------------------- // // Public Methods // //------------------------------------------------------ ////// Refresh TraceSources (re-read config file), creating if necessary. /// // Note: Better would be to separate enable from the Refresh method. public static void Refresh() { // Let AvTrace know that an explicit Refresh has been called. AvTrace.OnRefresh(); // Re-read the .config files System.Diagnostics.Trace.Refresh(); // Initialize any traces classes if needed if (TraceRefresh != null) { TraceRefresh(); } } internal static event TraceRefreshEventHandler TraceRefresh; ////// Critical: /// 1) Asserts for UMC to set trace level. /// /// TreatAsSafe: /// 1) The code path is only invoked when under a debugger /// if the caller can attach a debugger they already have /// unlimited access to the process. Also the only inputs /// to the assert are simply a label for the name. /// [SecurityCritical, SecurityTreatAsSafe] private static TraceSource CreateTraceSource(string sourceName) { // Create the trace source. Whether or not it will actually // trace anything is a decision of the trace source, e.g. it // depends on the app.config file settings. TraceSource source = new TraceSource(sourceName); // If we're attached to the debugger, ensure that at least // warnings/errors are getting traced. if (source.Switch.Level == SourceLevels.Off && AvTrace.IsDebuggerAttached()) { // we need to assert as PT callers under a debugger can invoke this code path // with out having the needed permission to peform this action new SecurityPermission(SecurityPermissionFlag.UnmanagedCode).Assert(); // BlessedAssert try { source.Switch.Level = SourceLevels.Warning; } finally { SecurityPermission.RevertAssert(); } } // returning source after reverting the assert to avoid // using exposed elements under the assert return source; } } internal delegate void TraceRefreshEventHandler(); } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. /****************************************************************************\ * * File: PresentationTraceSources.cs * * This class provides a public interface to access TraceSources for * enabling/disabling/filtering of trace messages by area. * * The other portion of this partial class is generated using * genTraceSource.pl and AvTraceMessages.txt * * Copyright (C) by Microsoft Corporation. All rights reserved. * \***************************************************************************/ using System.Collections.Generic; using System.Security; using System.Security.Permissions; using MS.Internal; using System.Windows; namespace System.Diagnostics { ////// PresentationTraceLevel - Enum which describes how much detail to trace about a particular object. /// public enum PresentationTraceLevel { ////// Trace no additional information. /// None, ////// Trace some additional information. /// Low, ////// Trace a medium amount of additional information. /// Medium, ////// Trace all available additional information. /// High, } ////// Helper class for retrieving TraceSources /// public static partial class PresentationTraceSources { //----------------------------------------------------- // // Public Properties // //----------------------------------------------------- ////// DependencyProperty for TraceLevel property. /// public static readonly DependencyProperty TraceLevelProperty = DependencyProperty.RegisterAttached( "TraceLevel", typeof(PresentationTraceLevel), typeof(PresentationTraceSources)); ////// Reads the attached property TraceLevel from the given element. /// public static PresentationTraceLevel GetTraceLevel(object element) { return TraceLevelStore.GetTraceLevel(element); } ////// Writes the attached property TraceLevel to the given element. /// public static void SetTraceLevel(object element, PresentationTraceLevel traceLevel) { TraceLevelStore.SetTraceLevel(element, traceLevel); } //----------------------------------------------------- // // Public Methods // //------------------------------------------------------ ////// Refresh TraceSources (re-read config file), creating if necessary. /// // Note: Better would be to separate enable from the Refresh method. public static void Refresh() { // Let AvTrace know that an explicit Refresh has been called. AvTrace.OnRefresh(); // Re-read the .config files System.Diagnostics.Trace.Refresh(); // Initialize any traces classes if needed if (TraceRefresh != null) { TraceRefresh(); } } internal static event TraceRefreshEventHandler TraceRefresh; ////// Critical: /// 1) Asserts for UMC to set trace level. /// /// TreatAsSafe: /// 1) The code path is only invoked when under a debugger /// if the caller can attach a debugger they already have /// unlimited access to the process. Also the only inputs /// to the assert are simply a label for the name. /// [SecurityCritical, SecurityTreatAsSafe] private static TraceSource CreateTraceSource(string sourceName) { // Create the trace source. Whether or not it will actually // trace anything is a decision of the trace source, e.g. it // depends on the app.config file settings. TraceSource source = new TraceSource(sourceName); // If we're attached to the debugger, ensure that at least // warnings/errors are getting traced. if (source.Switch.Level == SourceLevels.Off && AvTrace.IsDebuggerAttached()) { // we need to assert as PT callers under a debugger can invoke this code path // with out having the needed permission to peform this action new SecurityPermission(SecurityPermissionFlag.UnmanagedCode).Assert(); // BlessedAssert try { source.Switch.Level = SourceLevels.Warning; } finally { SecurityPermission.RevertAssert(); } } // returning source after reverting the assert to avoid // using exposed elements under the assert return source; } } internal delegate void TraceRefreshEventHandler(); } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- TableParagraph.cs
- FileRecordSequenceHelper.cs
- UnsafeNativeMethodsPenimc.cs
- TextSelectionHelper.cs
- RuleSettings.cs
- StrongNameKeyPair.cs
- JoinGraph.cs
- ToolStripItemClickedEventArgs.cs
- Frame.cs
- HwndHostAutomationPeer.cs
- ValueTable.cs
- CompatibleIComparer.cs
- Transform3DGroup.cs
- WindowsEditBox.cs
- CacheOutputQuery.cs
- SmiSettersStream.cs
- TypeDescriptionProvider.cs
- DataRowCollection.cs
- RouteUrlExpressionBuilder.cs
- DES.cs
- PartialCachingAttribute.cs
- WebPartRestoreVerb.cs
- XmlSchemaSimpleContent.cs
- UDPClient.cs
- SoapObjectReader.cs
- ProtocolImporter.cs
- MenuItem.cs
- MessageSecurityTokenVersion.cs
- NodeFunctions.cs
- EventLogEntryCollection.cs
- ValidationResult.cs
- UnionCodeGroup.cs
- InternalRelationshipCollection.cs
- DateTime.cs
- log.cs
- ListChunk.cs
- PtsCache.cs
- Facet.cs
- CheckBoxField.cs
- PingOptions.cs
- MissingManifestResourceException.cs
- Overlapped.cs
- XhtmlBasicListAdapter.cs
- SevenBitStream.cs
- KeyedCollection.cs
- XomlDesignerLoader.cs
- MessageSmuggler.cs
- ExceptionUtility.cs
- sqlstateclientmanager.cs
- DbConnectionHelper.cs
- ChannelPoolSettingsElement.cs
- VisualBasic.cs
- InternalsVisibleToAttribute.cs
- OleCmdHelper.cs
- sqlser.cs
- GridViewColumn.cs
- Automation.cs
- TextElementCollectionHelper.cs
- HebrewNumber.cs
- AQNBuilder.cs
- InputScope.cs
- CodeNamespaceCollection.cs
- DataKeyArray.cs
- TextServicesProperty.cs
- QuarticEase.cs
- OleCmdHelper.cs
- RegexFCD.cs
- AssemblyCache.cs
- EdgeProfileValidation.cs
- InputMethod.cs
- CodePrimitiveExpression.cs
- GPStream.cs
- ElementFactory.cs
- ServiceManagerHandle.cs
- StandardTransformFactory.cs
- ModuleBuilder.cs
- HyperLinkField.cs
- StringWriter.cs
- CompilerCollection.cs
- SortDescription.cs
- Number.cs
- PreservationFileWriter.cs
- EntityConnection.cs
- BindStream.cs
- SqlConnectionPoolProviderInfo.cs
- AssemblyCollection.cs
- Component.cs
- SudsParser.cs
- ProviderSettingsCollection.cs
- Image.cs
- PublisherIdentityPermission.cs
- BufferedStream2.cs
- Converter.cs
- Int16.cs
- StringSource.cs
- CursorConverter.cs
- CheckoutException.cs
- ConfigurationSettings.cs
- XmlCollation.cs
- COSERVERINFO.cs