Code:
/ 4.0 / 4.0 / untmp / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / Services / Monitoring / system / Diagnosticts / DiagnosticsConfigurationHandler.cs / 1305376 / DiagnosticsConfigurationHandler.cs
//------------------------------------------------------------------------------
//
// Copyright (c) Microsoft Corporation. All rights reserved.
//
//-----------------------------------------------------------------------------
#if !LIB
#define TRACE
#define DEBUG
namespace System.Diagnostics {
using System;
using System.Collections;
using System.Diagnostics;
using System.Xml;
using System.Configuration;
using System.Reflection;
using System.Globalization;
///
/// The configuration section handler for the diagnostics section of the configuration
/// file. The section handler participates in the resolution of configuration settings
/// between the <diagnostics> and </diagnostics>portion of the .config file.
///
///
[Obsolete("This class has been deprecated. http://go.microsoft.com/fwlink/?linkid=14202")]
public class DiagnosticsConfigurationHandler : IConfigurationSectionHandler {
///
/// Parses the configuration settings between the
/// <diagnostics> and </diagnostics> portion of the .config file to populate
/// the values of 'WebServicesConfiguration' object and returning it.
///
///
///
public virtual object Create(object parent, object configContext, XmlNode section) {
bool foundSwitches = false;
bool foundAssert = false;
bool foundTrace = false;
bool foundCounters = false;
HandlerBase.CheckForUnrecognizedAttributes(section);
// Since the tracing and switch code lives in System.Dll and config is in System.Configuration.dll
// the settings just go into a hashtable to communicate to the values to the diagnostics code in System.dll
Hashtable parentConfig = (Hashtable)parent;
Hashtable config;
if (parentConfig == null)
config = new Hashtable();
else
config = (Hashtable)parentConfig.Clone();
foreach (XmlNode child in section.ChildNodes) {
if (HandlerBase.IsIgnorableAlsoCheckForNonElement(child))
continue;
switch (child.Name) {
case "switches":
if (foundSwitches)
throw new ConfigurationErrorsException(SR.GetString(SR.ConfigSectionsUnique, "switches"));
foundSwitches = true;
HandleSwitches(config, child, configContext);
break;
case "assert":
if (foundAssert)
throw new ConfigurationErrorsException(SR.GetString(SR.ConfigSectionsUnique, "assert"));
foundAssert = true;
HandleAssert(config, child, configContext);
break;
case "trace":
if (foundTrace)
throw new ConfigurationErrorsException(SR.GetString(SR.ConfigSectionsUnique, "trace"));
foundTrace = true;
HandleTrace(config, child, configContext);
break;
case "performanceCounters":
if (foundCounters)
throw new ConfigurationErrorsException(SR.GetString(SR.ConfigSectionsUnique, "performanceCounters"));
foundCounters = true;
HandleCounters((Hashtable)parent, config, child, configContext);
break;
default:
HandlerBase.ThrowUnrecognizedElement(child);
break;
} // switch(child.Name)
HandlerBase.CheckForUnrecognizedAttributes(child);
}
return config;
}
private static void HandleSwitches(Hashtable config, XmlNode switchesNode, object context) {
Hashtable switches = (Hashtable) new SwitchesDictionarySectionHandler().Create(config["switches"], context, switchesNode);
IDictionaryEnumerator en = switches.GetEnumerator();
while (en.MoveNext()) {
try {
Int32.Parse((string) en.Value, CultureInfo.InvariantCulture);
}
catch {
throw new ConfigurationErrorsException(SR.GetString(SR.Value_must_be_numeric, en.Key));
}
}
config["switches"] = switches;
}
private static void HandleAssert(Hashtable config, XmlNode assertNode, object context) {
bool assertuienabled = false;
if (HandlerBase.GetAndRemoveBooleanAttribute(assertNode, "assertuienabled", ref assertuienabled) != null)
config["assertuienabled"] = assertuienabled;
string logfilename = null;
if (HandlerBase.GetAndRemoveStringAttribute(assertNode, "logfilename", ref logfilename) != null)
config["logfilename"] = logfilename;
HandlerBase.CheckForChildNodes(assertNode);
}
private static void HandleCounters(Hashtable parent, Hashtable config, XmlNode countersNode, object context) {
int filemappingsize = 0;
if (HandlerBase.GetAndRemoveIntegerAttribute(countersNode, "filemappingsize", ref filemappingsize) != null) {
//Should only be handled at machine config level
if (parent == null)
config["filemappingsize"] = filemappingsize;
}
HandlerBase.CheckForChildNodes(countersNode);
}
private static void HandleTrace(Hashtable config, XmlNode traceNode, object context) {
bool foundListeners = false;
bool autoflush = false;
if (HandlerBase.GetAndRemoveBooleanAttribute(traceNode, "autoflush", ref autoflush) != null)
config["autoflush"] = autoflush;
int indentsize = 0;
if (HandlerBase.GetAndRemoveIntegerAttribute(traceNode, "indentsize", ref indentsize) != null)
config["indentsize"] = indentsize;
foreach (XmlNode traceChild in traceNode.ChildNodes) {
if (HandlerBase.IsIgnorableAlsoCheckForNonElement(traceChild))
continue;
if (traceChild.Name == "listeners") {
if (foundListeners)
throw new ConfigurationErrorsException(SR.GetString(SR.ConfigSectionsUnique, "listeners"));
foundListeners = true;
HandleListeners(config, traceChild, context);
}
else {
HandlerBase.ThrowUnrecognizedElement(traceChild);
}
}
}
private static void HandleListeners(Hashtable config, XmlNode listenersNode, object context) {
HandlerBase.CheckForUnrecognizedAttributes(listenersNode);
foreach (XmlNode listenersChild in listenersNode.ChildNodes) {
if (HandlerBase.IsIgnorableAlsoCheckForNonElement(listenersChild))
continue;
string name = null, className = null, initializeData = null;
string op = listenersChild.Name;
switch (op) {
case "add":
case "remove":
case "clear":
break;
default:
HandlerBase.ThrowUnrecognizedElement(listenersChild);
break;
}
HandlerBase.GetAndRemoveStringAttribute(listenersChild, "name", ref name);
HandlerBase.GetAndRemoveStringAttribute(listenersChild, "type", ref className);
HandlerBase.GetAndRemoveStringAttribute(listenersChild, "initializeData", ref initializeData);
HandlerBase.CheckForUnrecognizedAttributes(listenersChild);
HandlerBase.CheckForChildNodes(listenersChild);
TraceListener newListener = null;
if (className != null) {
Type t = Type.GetType(className);
if (t == null)
throw new ConfigurationErrorsException(SR.GetString(SR.Could_not_find_type, className));
if (!typeof(TraceListener).IsAssignableFrom(t))
throw new ConfigurationErrorsException(SR.GetString(SR.Type_isnt_tracelistener, className));
// create a listener with parameterless constructor
if (initializeData == null) {
ConstructorInfo ctorInfo = t.GetConstructor(new Type[] {});
if (ctorInfo == null)
throw new ConfigurationErrorsException(SR.GetString(SR.Could_not_get_constructor, className));
newListener = (TraceListener)(SecurityUtils.ConstructorInfoInvoke(ctorInfo, new object[] { }));
}
// create a listener with a one-string constructor
else {
ConstructorInfo ctorInfo = t.GetConstructor(new Type[] { typeof(string) });
if (ctorInfo == null)
throw new ConfigurationErrorsException(SR.GetString(SR.Could_not_get_constructor, className));
newListener = (TraceListener)(SecurityUtils.ConstructorInfoInvoke(ctorInfo, new object[] { initializeData }));
}
if (name != null) {
newListener.Name = name;
}
}
// we already verified above that we only have "add", "remove", or "clear", so we can
// switch on the first char here for perf.
switch (op[0]) {
case 'a':
if (newListener == null)
throw new ConfigurationErrorsException(SR.GetString(SR.Could_not_create_listener, name));
Trace.Listeners.Add(newListener);
break;
case 'r':
if (newListener == null) {
// no type specified, we'll have to delete by name
// if no name is specified we can't do anything
if (name == null)
throw new ConfigurationErrorsException(SR.GetString(SR.Cannot_remove_with_null));
Trace.Listeners.Remove(name);
}
else {
// remove by listener
Trace.Listeners.Remove(newListener);
}
break;
case 'c':
Trace.Listeners.Clear();
break;
default:
HandlerBase.ThrowUnrecognizedElement(listenersChild);
break;
}
}
}
}
internal class SwitchesDictionarySectionHandler : DictionarySectionHandler {
protected override string KeyAttributeName {
get { return "name";}
}
internal override bool ValueRequired {
get { return true; }
}
}
}
#endif
// File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- GridViewUpdateEventArgs.cs
- PresentationTraceSources.cs
- ChangeDirector.cs
- DesignerAttributeInfo.cs
- InkCanvasSelection.cs
- HttpCookieCollection.cs
- TripleDES.cs
- BadImageFormatException.cs
- CrossContextChannel.cs
- CellParagraph.cs
- SecurityKeyUsage.cs
- XPathParser.cs
- assemblycache.cs
- MdiWindowListStrip.cs
- HttpHandlersSection.cs
- GB18030Encoding.cs
- basenumberconverter.cs
- ReaderWriterLockWrapper.cs
- SafeNativeMethods.cs
- NominalTypeEliminator.cs
- Parallel.cs
- Model3DCollection.cs
- PartitionResolver.cs
- RectAnimationUsingKeyFrames.cs
- SQLStringStorage.cs
- ContainsRowNumberChecker.cs
- Type.cs
- EventDescriptor.cs
- DataControlFieldCollection.cs
- InvalidCastException.cs
- SchemaInfo.cs
- MimePart.cs
- InfoCardUIAgent.cs
- DoubleCollection.cs
- XmlBinaryReader.cs
- RSAPKCS1KeyExchangeFormatter.cs
- wmiprovider.cs
- DropShadowBitmapEffect.cs
- LocalBuilder.cs
- SqlGatherProducedAliases.cs
- Pkcs7Recipient.cs
- EventManager.cs
- SqlClientFactory.cs
- EmptyReadOnlyDictionaryInternal.cs
- EntityProviderFactory.cs
- RenderDataDrawingContext.cs
- ConfigurationException.cs
- OutputScopeManager.cs
- UmAlQuraCalendar.cs
- EntityContainer.cs
- SerializationSectionGroup.cs
- SoapWriter.cs
- DataGridViewRowPostPaintEventArgs.cs
- FontDriver.cs
- CodeMemberProperty.cs
- Range.cs
- XPathNode.cs
- StylusTip.cs
- ListChunk.cs
- EntitySqlQueryCacheEntry.cs
- Verify.cs
- TimeSpanStorage.cs
- ToolStripSettings.cs
- XamlFigureLengthSerializer.cs
- DropShadowBitmapEffect.cs
- ExpressionBinding.cs
- ToolStripOverflow.cs
- XmlValidatingReader.cs
- TableRow.cs
- ContentPresenter.cs
- Translator.cs
- Properties.cs
- RequestCache.cs
- HandleCollector.cs
- ADMembershipProvider.cs
- PrivateFontCollection.cs
- SafeTimerHandle.cs
- DivideByZeroException.cs
- ScrollChrome.cs
- _NativeSSPI.cs
- GlyphingCache.cs
- MILUtilities.cs
- PerformanceCounterManager.cs
- ApplicationDirectory.cs
- SqlRecordBuffer.cs
- ADMembershipUser.cs
- PreservationFileWriter.cs
- AnnotationHighlightLayer.cs
- NameValuePair.cs
- PageThemeParser.cs
- EndpointIdentityConverter.cs
- Variable.cs
- ButtonColumn.cs
- LifetimeServices.cs
- Single.cs
- UnmanagedBitmapWrapper.cs
- MenuItemBindingCollection.cs
- EditorPartCollection.cs
- OperationParameterInfoCollection.cs
- BitmapEffectInputData.cs