Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / CompMod / System / Diagnostics / TraceSource.cs / 1305376 / TraceSource.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- using System; using System.Collections; using System.Collections.Generic; using System.Collections.Specialized; using System.Threading; using System.Configuration; using System.Security; using System.Security.Permissions; namespace System.Diagnostics { public class TraceSource { private static Listtracesources = new List (); private static int s_LastCollectionCount; private SourceSwitch internalSwitch; private TraceListenerCollection listeners; private StringDictionary attributes; private SourceLevels switchLevel; private string sourceName; internal bool _initCalled = false; // Whether we've called Initialize already. public TraceSource(string name) : this(name, SourceLevels.Off) { } public TraceSource(string name, SourceLevels defaultLevel) { if (name == null) throw new ArgumentNullException("name"); if (name.Length == 0) throw new ArgumentException("name"); sourceName = name; switchLevel = defaultLevel; // Delay load config to avoid perf (and working set) issues in retail // Add a weakreference to this source and cleanup invalid references lock(tracesources) { _pruneCachedTraceSources(); tracesources.Add(new WeakReference(this)); } } private static void _pruneCachedTraceSources() { lock (tracesources) { if (s_LastCollectionCount != GC.CollectionCount(2)) { List buffer = new List (tracesources.Count); for (int i = 0; i < tracesources.Count; i++) { TraceSource tracesource = ((TraceSource)tracesources[i].Target); if (tracesource != null) { buffer.Add(tracesources[i]); } } if (buffer.Count < tracesources.Count) { tracesources.Clear(); tracesources.AddRange(buffer); tracesources.TrimExcess(); } s_LastCollectionCount = GC.CollectionCount(2); } } } private void Initialize() { if (!_initCalled) { lock(this) { if (_initCalled) return; SourceElementsCollection sourceElements = DiagnosticsConfiguration.Sources; if (sourceElements != null) { SourceElement sourceElement = sourceElements[sourceName]; if (sourceElement != null) { if (!String.IsNullOrEmpty(sourceElement.SwitchName)) { CreateSwitch(sourceElement.SwitchType, sourceElement.SwitchName); } else { CreateSwitch(sourceElement.SwitchType, sourceName); if (!String.IsNullOrEmpty(sourceElement.SwitchValue)) internalSwitch.Level = (SourceLevels) Enum.Parse(typeof(SourceLevels), sourceElement.SwitchValue); } listeners = sourceElement.Listeners.GetRuntimeObject(); attributes = new StringDictionary(); TraceUtils.VerifyAttributes(sourceElement.Attributes, GetSupportedAttributes(), this); attributes.ReplaceHashtable(sourceElement.Attributes); } else NoConfigInit(); } else NoConfigInit(); _initCalled = true; } } } private void NoConfigInit() { internalSwitch = new SourceSwitch(sourceName, switchLevel.ToString()); listeners = new TraceListenerCollection(); listeners.Add(new DefaultTraceListener()); attributes = null; } [SecurityPermission(SecurityAction.LinkDemand, Flags=SecurityPermissionFlag.UnmanagedCode)] public void Close() { // No need to call Initialize() if (listeners != null) { // Use global lock lock (TraceInternal.critSec) { foreach (TraceListener listener in listeners) { listener.Close(); } } } } public void Flush() { // No need to call Initialize() if (listeners != null) { if (TraceInternal.UseGlobalLock) { lock (TraceInternal.critSec) { foreach (TraceListener listener in listeners) { listener.Flush(); } } } else { foreach (TraceListener listener in listeners) { if (!listener.IsThreadSafe) { lock (listener) { listener.Flush(); } } else { listener.Flush(); } } } } } virtual protected internal string[] GetSupportedAttributes() { return null; } internal static void RefreshAll() { lock (tracesources) { _pruneCachedTraceSources(); for (int i=0; i // Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- using System; using System.Collections; using System.Collections.Generic; using System.Collections.Specialized; using System.Threading; using System.Configuration; using System.Security; using System.Security.Permissions; namespace System.Diagnostics { public class TraceSource { private static List tracesources = new List (); private static int s_LastCollectionCount; private SourceSwitch internalSwitch; private TraceListenerCollection listeners; private StringDictionary attributes; private SourceLevels switchLevel; private string sourceName; internal bool _initCalled = false; // Whether we've called Initialize already. public TraceSource(string name) : this(name, SourceLevels.Off) { } public TraceSource(string name, SourceLevels defaultLevel) { if (name == null) throw new ArgumentNullException("name"); if (name.Length == 0) throw new ArgumentException("name"); sourceName = name; switchLevel = defaultLevel; // Delay load config to avoid perf (and working set) issues in retail // Add a weakreference to this source and cleanup invalid references lock(tracesources) { _pruneCachedTraceSources(); tracesources.Add(new WeakReference(this)); } } private static void _pruneCachedTraceSources() { lock (tracesources) { if (s_LastCollectionCount != GC.CollectionCount(2)) { List buffer = new List (tracesources.Count); for (int i = 0; i < tracesources.Count; i++) { TraceSource tracesource = ((TraceSource)tracesources[i].Target); if (tracesource != null) { buffer.Add(tracesources[i]); } } if (buffer.Count < tracesources.Count) { tracesources.Clear(); tracesources.AddRange(buffer); tracesources.TrimExcess(); } s_LastCollectionCount = GC.CollectionCount(2); } } } private void Initialize() { if (!_initCalled) { lock(this) { if (_initCalled) return; SourceElementsCollection sourceElements = DiagnosticsConfiguration.Sources; if (sourceElements != null) { SourceElement sourceElement = sourceElements[sourceName]; if (sourceElement != null) { if (!String.IsNullOrEmpty(sourceElement.SwitchName)) { CreateSwitch(sourceElement.SwitchType, sourceElement.SwitchName); } else { CreateSwitch(sourceElement.SwitchType, sourceName); if (!String.IsNullOrEmpty(sourceElement.SwitchValue)) internalSwitch.Level = (SourceLevels) Enum.Parse(typeof(SourceLevels), sourceElement.SwitchValue); } listeners = sourceElement.Listeners.GetRuntimeObject(); attributes = new StringDictionary(); TraceUtils.VerifyAttributes(sourceElement.Attributes, GetSupportedAttributes(), this); attributes.ReplaceHashtable(sourceElement.Attributes); } else NoConfigInit(); } else NoConfigInit(); _initCalled = true; } } } private void NoConfigInit() { internalSwitch = new SourceSwitch(sourceName, switchLevel.ToString()); listeners = new TraceListenerCollection(); listeners.Add(new DefaultTraceListener()); attributes = null; } [SecurityPermission(SecurityAction.LinkDemand, Flags=SecurityPermissionFlag.UnmanagedCode)] public void Close() { // No need to call Initialize() if (listeners != null) { // Use global lock lock (TraceInternal.critSec) { foreach (TraceListener listener in listeners) { listener.Close(); } } } } public void Flush() { // No need to call Initialize() if (listeners != null) { if (TraceInternal.UseGlobalLock) { lock (TraceInternal.critSec) { foreach (TraceListener listener in listeners) { listener.Flush(); } } } else { foreach (TraceListener listener in listeners) { if (!listener.IsThreadSafe) { lock (listener) { listener.Flush(); } } else { listener.Flush(); } } } } } virtual protected internal string[] GetSupportedAttributes() { return null; } internal static void RefreshAll() { lock (tracesources) { _pruneCachedTraceSources(); for (int i=0; i
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- odbcmetadatafactory.cs
- DoubleStorage.cs
- AudioStateChangedEventArgs.cs
- TreeViewBindingsEditorForm.cs
- InspectionWorker.cs
- Compilation.cs
- SafeEventHandle.cs
- SByteConverter.cs
- DecoderFallbackWithFailureFlag.cs
- ListViewEditEventArgs.cs
- BinaryCommonClasses.cs
- InfoCardKeyedHashAlgorithm.cs
- SourceItem.cs
- AuthenticodeSignatureInformation.cs
- CodeValidator.cs
- TreeView.cs
- OAVariantLib.cs
- Run.cs
- CapabilitiesAssignment.cs
- HandleRef.cs
- BindingContext.cs
- _AutoWebProxyScriptHelper.cs
- ReflectEventDescriptor.cs
- SoundPlayerAction.cs
- SynchronizingStream.cs
- CapacityStreamGeometryContext.cs
- ConditionCollection.cs
- COM2Properties.cs
- EntityDataSourceEntityTypeFilterItem.cs
- ToolStripDropDownClosedEventArgs.cs
- LastQueryOperator.cs
- Int32Converter.cs
- MetadataCache.cs
- TaiwanCalendar.cs
- MobileSysDescriptionAttribute.cs
- QuaternionAnimation.cs
- StorageAssociationSetMapping.cs
- Ppl.cs
- DynamicRenderer.cs
- NotImplementedException.cs
- FileUtil.cs
- XmlQueryTypeFactory.cs
- TraceLevelStore.cs
- XmlSchemaAttribute.cs
- XmlSchemaInclude.cs
- MediaCommands.cs
- TCPClient.cs
- IndexedGlyphRun.cs
- WmlCalendarAdapter.cs
- EncoderParameters.cs
- VirtualStackFrame.cs
- WebPartZoneCollection.cs
- SqlBinder.cs
- BlobPersonalizationState.cs
- SoapHeader.cs
- TableParagraph.cs
- SessionEndingEventArgs.cs
- SelectionItemPattern.cs
- WorkflowDesigner.cs
- StorageInfo.cs
- FontUnit.cs
- HttpCacheVaryByContentEncodings.cs
- AnimatedTypeHelpers.cs
- SafeFileMappingHandle.cs
- ClientConfigurationSystem.cs
- PageThemeCodeDomTreeGenerator.cs
- Brush.cs
- FontDialog.cs
- FontNamesConverter.cs
- SerializeAbsoluteContext.cs
- RegexRunnerFactory.cs
- FullTextState.cs
- GeometryModel3D.cs
- DataTableMappingCollection.cs
- PipelineModuleStepContainer.cs
- VisualBrush.cs
- ToolStripItemTextRenderEventArgs.cs
- Pkcs7Recipient.cs
- Registry.cs
- Scene3D.cs
- HostProtectionPermission.cs
- WindowProviderWrapper.cs
- ColumnMapCopier.cs
- ScriptControl.cs
- FixedSOMSemanticBox.cs
- XmlCDATASection.cs
- PointLight.cs
- TextFormatterHost.cs
- Msec.cs
- TextSelectionHighlightLayer.cs
- KerberosRequestorSecurityToken.cs
- PrtTicket_Public_Simple.cs
- ObjectDataSourceMethodEventArgs.cs
- TextTreeInsertUndoUnit.cs
- Single.cs
- LateBoundBitmapDecoder.cs
- AutomationProperties.cs
- UnknownWrapper.cs
- NegationPusher.cs
- RecognitionResult.cs