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
- SplashScreenNativeMethods.cs
- Knowncolors.cs
- TransportContext.cs
- InkPresenterAutomationPeer.cs
- DiscardableAttribute.cs
- CollectionViewProxy.cs
- WebPartDisplayModeEventArgs.cs
- DesignerWebPartChrome.cs
- AppDomainUnloadedException.cs
- PointAnimationBase.cs
- MsmqDecodeHelper.cs
- TextRangeEdit.cs
- SymbolEqualComparer.cs
- RtfNavigator.cs
- SecurityContextSecurityTokenAuthenticator.cs
- WasHostedComPlusFactory.cs
- Base64Encoding.cs
- ChildrenQuery.cs
- StreamSecurityUpgradeInitiatorAsyncResult.cs
- CompositeScriptReferenceEventArgs.cs
- MarginCollapsingState.cs
- FixedSOMGroup.cs
- DataGridViewCellMouseEventArgs.cs
- TextCharacters.cs
- DataGridViewRowEventArgs.cs
- RootBrowserWindowProxy.cs
- PlatformNotSupportedException.cs
- CharEnumerator.cs
- MachineKeySection.cs
- ToolStripDesigner.cs
- StateWorkerRequest.cs
- StylusPointProperties.cs
- EventLogPermission.cs
- Message.cs
- ReadOnlyDictionary.cs
- HttpHandlerActionCollection.cs
- TextDecorationLocationValidation.cs
- SplashScreenNativeMethods.cs
- CatalogPart.cs
- httpstaticobjectscollection.cs
- ComAdminWrapper.cs
- InstanceKeyView.cs
- RuntimeResourceSet.cs
- SectionUpdates.cs
- RelatedImageListAttribute.cs
- DecimalAverageAggregationOperator.cs
- OneOfTypeConst.cs
- ErrorEventArgs.cs
- SQLInt16.cs
- MethodBuilder.cs
- EventProxy.cs
- TransferMode.cs
- ListSurrogate.cs
- DisplayClaim.cs
- DefaultEventAttribute.cs
- HtmlElement.cs
- IndexOutOfRangeException.cs
- ObjectQueryProvider.cs
- UnmanagedMarshal.cs
- ByteStream.cs
- XmlSchemaChoice.cs
- InplaceBitmapMetadataWriter.cs
- ParserContext.cs
- BooleanStorage.cs
- XmlSchemaGroupRef.cs
- MediaContext.cs
- SqlCommandBuilder.cs
- HttpCapabilitiesEvaluator.cs
- TimeZone.cs
- CompilerParameters.cs
- XmlStringTable.cs
- CodeNamespaceCollection.cs
- CodeSubDirectory.cs
- BinaryNegotiation.cs
- BuildProviderAppliesToAttribute.cs
- IIS7WorkerRequest.cs
- ConfigurationSectionGroup.cs
- UriPrefixTable.cs
- DisposableCollectionWrapper.cs
- InputReport.cs
- Win32.cs
- DataGridViewTextBoxColumn.cs
- SqlUtils.cs
- CacheOutputQuery.cs
- TaskScheduler.cs
- SQLResource.cs
- ConfigXmlCDataSection.cs
- MeasurementDCInfo.cs
- CaseInsensitiveHashCodeProvider.cs
- AddInProcess.cs
- Identity.cs
- RadioButton.cs
- DataColumnCollection.cs
- CaseStatementSlot.cs
- ServiceParser.cs
- DataGridTextBox.cs
- TextLine.cs
- SQLGuidStorage.cs
- ColumnMapTranslator.cs
- WmiEventSink.cs