Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / whidbey / netfxsp / ndp / fx / src / CompMod / System / Diagnostics / Switch.cs / 1 / Switch.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- /* */ namespace System.Diagnostics { using System; using System.Security; using System.Security.Permissions; using System.Threading; using System.Runtime.InteropServices; using Microsoft.Win32; using System.Collections; using System.Collections.Generic; using System.Collections.Specialized; using System.Globalization; using System.Configuration; using System.Xml.Serialization; ////// public abstract class Switch { private SwitchElementsCollection switchSettings; private string description; private string displayName; private int switchSetting = 0; private bool initialized = false; private bool initializing = false; private string switchValueString = String.Empty; private StringDictionary attributes; private string defaultValue; private static ListProvides an ///base class to /// create new debugging and tracing switches. switches = new List (); /// /// protected Switch(string displayName, string description) : this(displayName, description, "0") { } protected Switch(string displayName, string description, string defaultSwitchValue) { // displayName is used as a hashtable key, so it can never // be null. if (displayName == null) displayName = string.Empty; this.displayName = displayName; this.description = description; lock (switches) { switches.Add(new WeakReference(this)); } defaultValue = defaultSwitchValue; } [XmlIgnore] public StringDictionary Attributes { get { Initialize(); if (attributes == null) attributes = new StringDictionary(); return attributes; } } ///Initializes a new instance of the ////// class. /// public string DisplayName { get { return displayName; } } ///Gets a name used to identify the switch. ////// public string Description { get { return (description == null) ? string.Empty : description; } } ///Gets a description of the switch. ////// protected int SwitchSetting { get { if (!initialized) { if (!InitializeWithStatus()) return 0; OnSwitchSettingChanged(); } return switchSetting; } set { initialized = true; if (switchSetting != value) { switchSetting = value; OnSwitchSettingChanged(); } } } protected string Value { get { Initialize(); return switchValueString; } set { Initialize(); switchValueString = value; try { OnValueChanged(); } catch (ArgumentException e) { throw new ConfigurationErrorsException(SR.GetString(SR.BadConfigSwitchValue, DisplayName), e); } catch (FormatException e) { throw new ConfigurationErrorsException(SR.GetString(SR.BadConfigSwitchValue, DisplayName), e); } catch (OverflowException e) { throw new ConfigurationErrorsException(SR.GetString(SR.BadConfigSwitchValue, DisplayName), e); } } } private void Initialize() { InitializeWithStatus(); } private bool InitializeWithStatus() { if (!initialized) { if (initializing) return false; initializing = true; if (switchSettings == null) { if (!InitializeConfigSettings()) return false; } if (switchSettings != null) { SwitchElement mySettings = switchSettings[displayName]; if (mySettings != null) { string value = mySettings.Value; if (value != null) { this.Value = value; } else this.Value = defaultValue; try { TraceUtils.VerifyAttributes(mySettings.Attributes, GetSupportedAttributes(), this); } catch (ConfigurationException) { // if VerifyAttributes throws, clean up a little bit so we're not in a bad state. initialized = false; initializing = false; throw; } attributes = new StringDictionary(); attributes.contents = mySettings.Attributes; } else { // We don't use the property here because we don't want to catch exceptions // and rethrow them as ConfigurationException. In this case there's no config. switchValueString = defaultValue; OnValueChanged(); } } else { // We don't use the property here because we don't want to catch exceptions // and rethrow them as ConfigurationException. In this case there's no config. switchValueString = defaultValue; OnValueChanged(); } initialized = true; initializing = false; } return true; } private bool InitializeConfigSettings() { if (switchSettings != null) return true; if (!DiagnosticsConfiguration.CanInitialize()) return false; // This hashtable is case-insensitive. switchSettings = DiagnosticsConfiguration.SwitchSettings; return true; } virtual protected internal string[] GetSupportedAttributes() { return null; } ////// Indicates the current setting for this switch. /// ////// This method is invoked when a switch setting has been changed. It will /// be invoked the first time a switch reads its value from the registry /// or environment, and then it will be invoked each time the switch's /// value is changed. /// protected virtual void OnSwitchSettingChanged() { } protected virtual void OnValueChanged() { SwitchSetting = Int32.Parse(Value, CultureInfo.InvariantCulture); } internal static void RefreshAll() { lock (switches) { for (int i=0; i// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- /* */ namespace System.Diagnostics { using System; using System.Security; using System.Security.Permissions; using System.Threading; using System.Runtime.InteropServices; using Microsoft.Win32; using System.Collections; using System.Collections.Generic; using System.Collections.Specialized; using System.Globalization; using System.Configuration; using System.Xml.Serialization; /// /// public abstract class Switch { private SwitchElementsCollection switchSettings; private string description; private string displayName; private int switchSetting = 0; private bool initialized = false; private bool initializing = false; private string switchValueString = String.Empty; private StringDictionary attributes; private string defaultValue; private static ListProvides an ///base class to /// create new debugging and tracing switches. switches = new List (); /// /// protected Switch(string displayName, string description) : this(displayName, description, "0") { } protected Switch(string displayName, string description, string defaultSwitchValue) { // displayName is used as a hashtable key, so it can never // be null. if (displayName == null) displayName = string.Empty; this.displayName = displayName; this.description = description; lock (switches) { switches.Add(new WeakReference(this)); } defaultValue = defaultSwitchValue; } [XmlIgnore] public StringDictionary Attributes { get { Initialize(); if (attributes == null) attributes = new StringDictionary(); return attributes; } } ///Initializes a new instance of the ////// class. /// public string DisplayName { get { return displayName; } } ///Gets a name used to identify the switch. ////// public string Description { get { return (description == null) ? string.Empty : description; } } ///Gets a description of the switch. ////// protected int SwitchSetting { get { if (!initialized) { if (!InitializeWithStatus()) return 0; OnSwitchSettingChanged(); } return switchSetting; } set { initialized = true; if (switchSetting != value) { switchSetting = value; OnSwitchSettingChanged(); } } } protected string Value { get { Initialize(); return switchValueString; } set { Initialize(); switchValueString = value; try { OnValueChanged(); } catch (ArgumentException e) { throw new ConfigurationErrorsException(SR.GetString(SR.BadConfigSwitchValue, DisplayName), e); } catch (FormatException e) { throw new ConfigurationErrorsException(SR.GetString(SR.BadConfigSwitchValue, DisplayName), e); } catch (OverflowException e) { throw new ConfigurationErrorsException(SR.GetString(SR.BadConfigSwitchValue, DisplayName), e); } } } private void Initialize() { InitializeWithStatus(); } private bool InitializeWithStatus() { if (!initialized) { if (initializing) return false; initializing = true; if (switchSettings == null) { if (!InitializeConfigSettings()) return false; } if (switchSettings != null) { SwitchElement mySettings = switchSettings[displayName]; if (mySettings != null) { string value = mySettings.Value; if (value != null) { this.Value = value; } else this.Value = defaultValue; try { TraceUtils.VerifyAttributes(mySettings.Attributes, GetSupportedAttributes(), this); } catch (ConfigurationException) { // if VerifyAttributes throws, clean up a little bit so we're not in a bad state. initialized = false; initializing = false; throw; } attributes = new StringDictionary(); attributes.contents = mySettings.Attributes; } else { // We don't use the property here because we don't want to catch exceptions // and rethrow them as ConfigurationException. In this case there's no config. switchValueString = defaultValue; OnValueChanged(); } } else { // We don't use the property here because we don't want to catch exceptions // and rethrow them as ConfigurationException. In this case there's no config. switchValueString = defaultValue; OnValueChanged(); } initialized = true; initializing = false; } return true; } private bool InitializeConfigSettings() { if (switchSettings != null) return true; if (!DiagnosticsConfiguration.CanInitialize()) return false; // This hashtable is case-insensitive. switchSettings = DiagnosticsConfiguration.SwitchSettings; return true; } virtual protected internal string[] GetSupportedAttributes() { return null; } ////// Indicates the current setting for this switch. /// ////// This method is invoked when a switch setting has been changed. It will /// be invoked the first time a switch reads its value from the registry /// or environment, and then it will be invoked each time the switch's /// value is changed. /// protected virtual void OnSwitchSettingChanged() { } protected virtual void OnValueChanged() { SwitchSetting = Int32.Parse(Value, CultureInfo.InvariantCulture); } internal static void RefreshAll() { lock (switches) { for (int i=0; i
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- EditingMode.cs
- panel.cs
- DesignerAdRotatorAdapter.cs
- FakeModelPropertyImpl.cs
- DependencyPropertyDescriptor.cs
- login.cs
- ParseChildrenAsPropertiesAttribute.cs
- SHA384.cs
- UrlMapping.cs
- MenuRenderer.cs
- ObjectStorage.cs
- WeakReferenceEnumerator.cs
- BamlLocalizabilityResolver.cs
- Size.cs
- ControlBuilder.cs
- SessionPageStatePersister.cs
- ValueConversionAttribute.cs
- TextReader.cs
- CodeMemberField.cs
- DataGridRow.cs
- CompilerCollection.cs
- RightsManagementEncryptedStream.cs
- Config.cs
- CheckableControlBaseAdapter.cs
- AsynchronousChannel.cs
- SocketException.cs
- PresentationTraceSources.cs
- _NegoStream.cs
- RequestDescription.cs
- pingexception.cs
- TabControl.cs
- BinaryCommonClasses.cs
- StringFreezingAttribute.cs
- DecimalKeyFrameCollection.cs
- UpdateCommand.cs
- Fault.cs
- Utility.cs
- PerformanceCounter.cs
- InvalidWMPVersionException.cs
- OleDbReferenceCollection.cs
- MappingModelBuildProvider.cs
- SqlDeflator.cs
- RC2.cs
- TreeView.cs
- DataObject.cs
- Int16.cs
- ParenthesizePropertyNameAttribute.cs
- TextServicesDisplayAttribute.cs
- LinearQuaternionKeyFrame.cs
- XmlSchemaProviderAttribute.cs
- Misc.cs
- DataGrid.cs
- Cursor.cs
- UnitControl.cs
- CodeTypeOfExpression.cs
- WasHttpHandlersInstallComponent.cs
- StackOverflowException.cs
- Run.cs
- DataColumnCollection.cs
- SrgsElementFactoryCompiler.cs
- MetadataItem.cs
- StylusDevice.cs
- ProjectionCamera.cs
- ImageMapEventArgs.cs
- DynamicValueConverter.cs
- WeakEventManager.cs
- ColorContext.cs
- ManifestResourceInfo.cs
- CountAggregationOperator.cs
- VirtualPathProvider.cs
- XmlILConstructAnalyzer.cs
- ContainerFilterService.cs
- CollectionCodeDomSerializer.cs
- COM2ExtendedBrowsingHandler.cs
- TabControlAutomationPeer.cs
- CardSpaceSelector.cs
- Globals.cs
- TranslateTransform3D.cs
- XmlAtomicValue.cs
- ProxyWebPartManager.cs
- DataSvcMapFileSerializer.cs
- EntityReference.cs
- IndexerNameAttribute.cs
- NativeMethods.cs
- RegexFCD.cs
- AccessDataSource.cs
- ListViewDeleteEventArgs.cs
- RemoteWebConfigurationHostStream.cs
- PocoPropertyAccessorStrategy.cs
- DashStyle.cs
- DashStyles.cs
- HeaderUtility.cs
- PublisherIdentityPermission.cs
- HyperLinkStyle.cs
- SimpleType.cs
- XsltArgumentList.cs
- EditingMode.cs
- DerivedKeySecurityTokenStub.cs
- ConfigurationElementProperty.cs
- COM2FontConverter.cs