Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / whidbey / NetFXspW7 / ndp / clr / src / BCL / System / Diagnostics / Assert.cs / 1 / Assert.cs
// ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== namespace System.Diagnostics { using System; using System.Security.Permissions; using System.IO; using System.Reflection; using System.Runtime.CompilerServices; // Class which handles code asserts. Asserts are used to explicitly protect // assumptions made in the code. In general if an assert fails, it indicates // a program bug so is immediately called to the attention of the user. // Only static data members, does not need to be marked with the serializable attribute internal static class Assert { private static AssertFilter[] ListOfFilters; private static int iNumOfFilters; private static int iFilterArraySize; static Assert() { Assert.AddFilter(new DefaultFilter()); } // AddFilter adds a new assert filter. This replaces the current // filter, unless the filter returns FailContinue. // public static void AddFilter(AssertFilter filter) { if (iFilterArraySize <= iNumOfFilters) { AssertFilter[] newFilterArray = new AssertFilter [iFilterArraySize+2]; if (iNumOfFilters > 0) Array.Copy(ListOfFilters, newFilterArray, iNumOfFilters); iFilterArraySize += 2; ListOfFilters = newFilterArray; } ListOfFilters [iNumOfFilters++] = filter; } // Called when an assertion is being made. // public static void Check(bool condition, String conditionString, String message) { if (!condition) { Fail (conditionString, message); } } public static void Fail(String conditionString, String message) { // get the stacktrace StackTrace st = new StackTrace(); // Run through the list of filters backwards (the last filter in the list // is the default filter. So we're guaranteed that there will be atleast // one filter to handle the assert. int iTemp = iNumOfFilters; while (iTemp > 0) { AssertFilters iResult = ListOfFilters [--iTemp].AssertFailure (conditionString, message, st); if (iResult == AssertFilters.FailDebug) { if (Debugger.IsAttached == true) Debugger.Break(); else { if (Debugger.Launch() == false) { throw new InvalidOperationException( Environment.GetResourceString("InvalidOperation_DebuggerLaunchFailed")); } } break; } else if (iResult == AssertFilters.FailTerminate) Environment.Exit(-1); else if (iResult == AssertFilters.FailIgnore) break; // If none of the above, it means that the Filter returned FailContinue. // So invoke the next filter. } } // Called when an assert happens. // [MethodImplAttribute(MethodImplOptions.InternalCall)] public extern static int ShowDefaultAssertDialog(String conditionString, String message); } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // ==++== // // Copyright (c) Microsoft Corporation. All rights reserved. // // ==--== namespace System.Diagnostics { using System; using System.Security.Permissions; using System.IO; using System.Reflection; using System.Runtime.CompilerServices; // Class which handles code asserts. Asserts are used to explicitly protect // assumptions made in the code. In general if an assert fails, it indicates // a program bug so is immediately called to the attention of the user. // Only static data members, does not need to be marked with the serializable attribute internal static class Assert { private static AssertFilter[] ListOfFilters; private static int iNumOfFilters; private static int iFilterArraySize; static Assert() { Assert.AddFilter(new DefaultFilter()); } // AddFilter adds a new assert filter. This replaces the current // filter, unless the filter returns FailContinue. // public static void AddFilter(AssertFilter filter) { if (iFilterArraySize <= iNumOfFilters) { AssertFilter[] newFilterArray = new AssertFilter [iFilterArraySize+2]; if (iNumOfFilters > 0) Array.Copy(ListOfFilters, newFilterArray, iNumOfFilters); iFilterArraySize += 2; ListOfFilters = newFilterArray; } ListOfFilters [iNumOfFilters++] = filter; } // Called when an assertion is being made. // public static void Check(bool condition, String conditionString, String message) { if (!condition) { Fail (conditionString, message); } } public static void Fail(String conditionString, String message) { // get the stacktrace StackTrace st = new StackTrace(); // Run through the list of filters backwards (the last filter in the list // is the default filter. So we're guaranteed that there will be atleast // one filter to handle the assert. int iTemp = iNumOfFilters; while (iTemp > 0) { AssertFilters iResult = ListOfFilters [--iTemp].AssertFailure (conditionString, message, st); if (iResult == AssertFilters.FailDebug) { if (Debugger.IsAttached == true) Debugger.Break(); else { if (Debugger.Launch() == false) { throw new InvalidOperationException( Environment.GetResourceString("InvalidOperation_DebuggerLaunchFailed")); } } break; } else if (iResult == AssertFilters.FailTerminate) Environment.Exit(-1); else if (iResult == AssertFilters.FailIgnore) break; // If none of the above, it means that the Filter returned FailContinue. // So invoke the next filter. } } // Called when an assert happens. // [MethodImplAttribute(MethodImplOptions.InternalCall)] public extern static int ShowDefaultAssertDialog(String conditionString, String 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
- UInt32Storage.cs
- Visual3D.cs
- SimplePropertyEntry.cs
- EdmComplexPropertyAttribute.cs
- InputEventArgs.cs
- CallbackHandler.cs
- ValidatingPropertiesEventArgs.cs
- DataServiceQueryOfT.cs
- DateTimePicker.cs
- Help.cs
- Function.cs
- FontConverter.cs
- EntityViewGenerationConstants.cs
- SerializationStore.cs
- SupportsEventValidationAttribute.cs
- SafeMILHandle.cs
- CodeAttributeArgument.cs
- XsltLoader.cs
- DataGridColumn.cs
- SqlProcedureAttribute.cs
- ViewGenerator.cs
- XPathDocumentIterator.cs
- MexTcpBindingCollectionElement.cs
- Page.cs
- ServicePointManagerElement.cs
- HtmlInputSubmit.cs
- OperationPickerDialog.cs
- SourceSwitch.cs
- BooleanSwitch.cs
- precedingsibling.cs
- ReadingWritingEntityEventArgs.cs
- DataGridViewTopLeftHeaderCell.cs
- RadioButtonList.cs
- Repeater.cs
- RsaSecurityTokenAuthenticator.cs
- TypedAsyncResult.cs
- DataSourceCache.cs
- ProcessHostFactoryHelper.cs
- DbDataRecord.cs
- XamlReader.cs
- DesignSurfaceCollection.cs
- XmlHierarchicalDataSourceView.cs
- ColumnMapCopier.cs
- SelectionListComponentEditor.cs
- PenLineCapValidation.cs
- WindowShowOrOpenTracker.cs
- BindingExpressionBase.cs
- HttpHandlerActionCollection.cs
- MetadataElement.cs
- RenderingBiasValidation.cs
- ThemeableAttribute.cs
- srgsitem.cs
- ProfileProvider.cs
- ValueTypePropertyReference.cs
- Stylus.cs
- WsatConfiguration.cs
- CompressStream.cs
- SSmlParser.cs
- Object.cs
- ConcurrencyMode.cs
- ControlFilterExpression.cs
- SoapAttributes.cs
- RemotingSurrogateSelector.cs
- MembershipPasswordException.cs
- WindowAutomationPeer.cs
- TextServicesLoader.cs
- BrowserCapabilitiesFactory.cs
- CommonDialog.cs
- returneventsaver.cs
- ModuleElement.cs
- TextElementAutomationPeer.cs
- _NestedMultipleAsyncResult.cs
- ComplexBindingPropertiesAttribute.cs
- TimerEventSubscription.cs
- SoapCodeExporter.cs
- Int64Converter.cs
- AssociationSetMetadata.cs
- UnsafeNativeMethodsMilCoreApi.cs
- DataColumnMapping.cs
- ManagementOperationWatcher.cs
- HandleCollector.cs
- Pointer.cs
- ListViewInsertEventArgs.cs
- ParserExtension.cs
- DefaultHttpHandler.cs
- MetabaseSettings.cs
- GenericTypeParameterBuilder.cs
- UserControlDesigner.cs
- DataGridViewColumnStateChangedEventArgs.cs
- HttpCapabilitiesBase.cs
- Win32.cs
- UIElementIsland.cs
- MSAANativeProvider.cs
- DefaultMemberAttribute.cs
- ConstructorBuilder.cs
- LinkArea.cs
- ResourceExpressionBuilder.cs
- CultureSpecificStringDictionary.cs
- MenuItemStyle.cs
- XmlWellformedWriter.cs