Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / cdf / src / WCF / SMDiagnostics / System / ServiceModel / Diagnostics / AssertUtility.cs / 1305376 / AssertUtility.cs
//------------------------------------------------------------ // Copyright (c) Microsoft Corporation. All rights reserved. //----------------------------------------------------------- // This class needs to function even if it was built retail. That is, a debug caller calling against a retail // SMDiagnostics should still have asserts fire. To achieve that, we need to define DEBUG here. // We do not do the registry override in retail SMDiagnostics because that would require shipping a test hook. We // do not generally ship test hooks today. #if DEBUG #define DEBUG_FOR_REALS #else #define DEBUG #endif namespace System.ServiceModel.Diagnostics { using System; using System.Runtime; using System.Runtime.Interop; using System.Diagnostics; using System.Runtime.CompilerServices; using System.Diagnostics.CodeAnalysis; using Microsoft.Win32; static class AssertUtility { #if DEBUG_FOR_REALS const string WinFXRegistryKey = @"SOFTWARE\Microsoft\NET Framework Setup\NDP"; const string WcfRegistryKey = AssertUtility.WinFXRegistryKey + @"\CDF\v4.0\Debug"; const string AssertsFailFastName = "AssertsFailFast"; #endif [Obsolete("For SMDiagnostics.dll use only. Call DiagnosticUtility.DebugAssert instead")] [SuppressMessage(FxCop.Category.ReliabilityBasic, FxCop.Rule.InvariantAssertRule, Justification = "Assert implementation")] internal static void DebugAssertCore(string message) { try { #if DEBUG_FOR_REALS string debugMessage = "WCF Assert fired! --> " + message + "\r\n"; if (Debugger.IsAttached) { Debugger.Log(0, Debugger.DefaultCategory, debugMessage); Debugger.Break(); } if (UnsafeNativeMethods.IsDebuggerPresent()) { UnsafeNativeMethods.OutputDebugString(debugMessage); UnsafeNativeMethods.DebugBreak(); } // This can be switched to just FailFast (e.g. for the stress lab). RegistryKey key = Registry.LocalMachine.OpenSubKey(AssertUtility.WcfRegistryKey); if (key != null) { object value; using (key) { value = key.GetValue(AssertUtility.AssertsFailFastName); } if (value != null && typeof(int).IsAssignableFrom(value.GetType()) && ((int) value) != 0) { try { if (ExceptionUtility.mainInstance != null) { #pragma warning disable 618 ExceptionUtility.mainInstance.TraceFailFast(message); } else { ExceptionUtility.TraceFailFast(message, new EventLogger("System.ServiceModel", null)); } #pragma warning restore 618 } finally { Environment.FailFast(message); } } } } catch (Exception exception) { message = string.Concat("Exception during assert! [", exception.GetType().Name, ": ", exception.Message, "] --> ", message); throw; #endif } finally { Debug.Assert(false, message); } } // For use within SMDiagnostics. [Conditional("DEBUG")] [Obsolete("For SMDiagnostics.dll use only. Call DiagnosticUtility.DebugAssert instead")] internal static void DebugAssert(bool condition, string message) { if (!condition) { DebugAssert(message); } } [MethodImpl(MethodImplOptions.NoInlining)] [Conditional("DEBUG")] [Obsolete("For SMDiagnostics.dll use only. Call DiagnosticUtility.DebugAssert instead")] internal static void DebugAssert(string message) { DebugAssertCore(message); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------ // Copyright (c) Microsoft Corporation. All rights reserved. //----------------------------------------------------------- // This class needs to function even if it was built retail. That is, a debug caller calling against a retail // SMDiagnostics should still have asserts fire. To achieve that, we need to define DEBUG here. // We do not do the registry override in retail SMDiagnostics because that would require shipping a test hook. We // do not generally ship test hooks today. #if DEBUG #define DEBUG_FOR_REALS #else #define DEBUG #endif namespace System.ServiceModel.Diagnostics { using System; using System.Runtime; using System.Runtime.Interop; using System.Diagnostics; using System.Runtime.CompilerServices; using System.Diagnostics.CodeAnalysis; using Microsoft.Win32; static class AssertUtility { #if DEBUG_FOR_REALS const string WinFXRegistryKey = @"SOFTWARE\Microsoft\NET Framework Setup\NDP"; const string WcfRegistryKey = AssertUtility.WinFXRegistryKey + @"\CDF\v4.0\Debug"; const string AssertsFailFastName = "AssertsFailFast"; #endif [Obsolete("For SMDiagnostics.dll use only. Call DiagnosticUtility.DebugAssert instead")] [SuppressMessage(FxCop.Category.ReliabilityBasic, FxCop.Rule.InvariantAssertRule, Justification = "Assert implementation")] internal static void DebugAssertCore(string message) { try { #if DEBUG_FOR_REALS string debugMessage = "WCF Assert fired! --> " + message + "\r\n"; if (Debugger.IsAttached) { Debugger.Log(0, Debugger.DefaultCategory, debugMessage); Debugger.Break(); } if (UnsafeNativeMethods.IsDebuggerPresent()) { UnsafeNativeMethods.OutputDebugString(debugMessage); UnsafeNativeMethods.DebugBreak(); } // This can be switched to just FailFast (e.g. for the stress lab). RegistryKey key = Registry.LocalMachine.OpenSubKey(AssertUtility.WcfRegistryKey); if (key != null) { object value; using (key) { value = key.GetValue(AssertUtility.AssertsFailFastName); } if (value != null && typeof(int).IsAssignableFrom(value.GetType()) && ((int) value) != 0) { try { if (ExceptionUtility.mainInstance != null) { #pragma warning disable 618 ExceptionUtility.mainInstance.TraceFailFast(message); } else { ExceptionUtility.TraceFailFast(message, new EventLogger("System.ServiceModel", null)); } #pragma warning restore 618 } finally { Environment.FailFast(message); } } } } catch (Exception exception) { message = string.Concat("Exception during assert! [", exception.GetType().Name, ": ", exception.Message, "] --> ", message); throw; #endif } finally { Debug.Assert(false, message); } } // For use within SMDiagnostics. [Conditional("DEBUG")] [Obsolete("For SMDiagnostics.dll use only. Call DiagnosticUtility.DebugAssert instead")] internal static void DebugAssert(bool condition, string message) { if (!condition) { DebugAssert(message); } } [MethodImpl(MethodImplOptions.NoInlining)] [Conditional("DEBUG")] [Obsolete("For SMDiagnostics.dll use only. Call DiagnosticUtility.DebugAssert instead")] internal static void DebugAssert(string message) { DebugAssertCore(message); } } } // 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
- DrawingGroup.cs
- GeneralTransform3DTo2D.cs
- MultipleViewPattern.cs
- CodePropertyReferenceExpression.cs
- TypeUtil.cs
- ToolStripRenderer.cs
- SignatureHelper.cs
- WmfPlaceableFileHeader.cs
- ContentPresenter.cs
- SubstitutionList.cs
- ReadOnlyMetadataCollection.cs
- DataGridViewDesigner.cs
- SmiContext.cs
- PersonalizationDictionary.cs
- DataGridViewCellStyleContentChangedEventArgs.cs
- ViewGenResults.cs
- PopupRoot.cs
- DictionaryBase.cs
- AccessControlEntry.cs
- BamlMapTable.cs
- XmlSchemaComplexContentRestriction.cs
- HttpResponse.cs
- TextRunCacheImp.cs
- HtmlLabelAdapter.cs
- HtmlInputReset.cs
- HtmlInputText.cs
- TextOutput.cs
- RegexRunner.cs
- TypeListConverter.cs
- GridProviderWrapper.cs
- SettingsAttributeDictionary.cs
- OverflowException.cs
- BufferedWebEventProvider.cs
- TimeoutException.cs
- BitmapScalingModeValidation.cs
- IncrementalCompileAnalyzer.cs
- SingletonInstanceContextProvider.cs
- DesignSurfaceEvent.cs
- PageParser.cs
- ApplicationId.cs
- IntSecurity.cs
- UnknownBitmapEncoder.cs
- ModuleBuilderData.cs
- Setter.cs
- LicFileLicenseProvider.cs
- ToolboxComponentsCreatingEventArgs.cs
- ConditionCollection.cs
- XmlSyndicationContent.cs
- DirectionalLight.cs
- InstanceDataCollection.cs
- NotifyCollectionChangedEventArgs.cs
- CharAnimationUsingKeyFrames.cs
- ConnectionPoolRegistry.cs
- RootDesignerSerializerAttribute.cs
- TextRunCache.cs
- IPipelineRuntime.cs
- TrackingMemoryStream.cs
- RowToParametersTransformer.cs
- SelectedGridItemChangedEvent.cs
- WebPartEditorCancelVerb.cs
- ReadWriteObjectLock.cs
- MemberCollection.cs
- Opcode.cs
- Vector.cs
- SqlDataSourceConnectionPanel.cs
- XmlILConstructAnalyzer.cs
- WebPartUserCapability.cs
- QilInvoke.cs
- TdsParserStaticMethods.cs
- BitmapEffectGeneralTransform.cs
- BamlTreeMap.cs
- Color.cs
- HostProtectionPermission.cs
- EdmItemError.cs
- updateconfighost.cs
- StringConcat.cs
- ResourceAttributes.cs
- DbModificationCommandTree.cs
- ThemeableAttribute.cs
- SiteMapNodeItemEventArgs.cs
- TextTreeTextNode.cs
- XmlQueryOutput.cs
- IsolatedStorage.cs
- TableProvider.cs
- Font.cs
- IdentityReference.cs
- TextEditorDragDrop.cs
- InlineCollection.cs
- SkewTransform.cs
- SecondaryViewProvider.cs
- GraphicsPathIterator.cs
- ScrollChrome.cs
- GetWinFXPath.cs
- HtmlHead.cs
- Selection.cs
- CFStream.cs
- ItemCollection.cs
- HTTPNotFoundHandler.cs
- WebRequestModuleElementCollection.cs
- TableCellCollection.cs