Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / whidbey / netfxsp / 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
- TemplateXamlTreeBuilder.cs
- LayoutDump.cs
- PolicyUnit.cs
- DocumentPaginator.cs
- XmlCompatibilityReader.cs
- Stopwatch.cs
- BeginEvent.cs
- Policy.cs
- AttributeAction.cs
- StylusDownEventArgs.cs
- SoapIncludeAttribute.cs
- MachineKeyValidationConverter.cs
- TextEditorParagraphs.cs
- BlurEffect.cs
- SqlCommand.cs
- SystemNetworkInterface.cs
- PropertyNames.cs
- TextEditorDragDrop.cs
- ScopeElement.cs
- HwndMouseInputProvider.cs
- TextBlock.cs
- HttpProfileBase.cs
- WindowsListViewSubItem.cs
- HttpCookieCollection.cs
- UIElement.cs
- NumericUpDown.cs
- Events.cs
- CatalogZoneBase.cs
- SqlDependency.cs
- SqlCacheDependencyDatabaseCollection.cs
- XPathAncestorIterator.cs
- ScopedKnownTypes.cs
- SinglePhaseEnlistment.cs
- EntityDataReader.cs
- TcpProcessProtocolHandler.cs
- NamespaceListProperty.cs
- SystemIPv4InterfaceProperties.cs
- EdmFunction.cs
- FormViewPagerRow.cs
- ArraySortHelper.cs
- CreateUserWizard.cs
- FindCriteriaCD1.cs
- HtmlContainerControl.cs
- XsdBuilder.cs
- HttpRuntimeSection.cs
- PeerToPeerException.cs
- DependencyPropertyKind.cs
- Size3D.cs
- DesigntimeLicenseContext.cs
- JournalEntryStack.cs
- DropDownList.cs
- Clipboard.cs
- DataGridViewSelectedCellsAccessibleObject.cs
- ClientRuntimeConfig.cs
- ResourceCategoryAttribute.cs
- DataGridAddNewRow.cs
- Preprocessor.cs
- TaiwanCalendar.cs
- CreateUserErrorEventArgs.cs
- XsdDuration.cs
- DecoratedNameAttribute.cs
- COSERVERINFO.cs
- BaseTreeIterator.cs
- StringResourceManager.cs
- BinHexEncoder.cs
- CompiledQueryCacheEntry.cs
- NonDualMessageSecurityOverHttp.cs
- WindowsListView.cs
- WebPartMenu.cs
- PerfCounters.cs
- ByteArrayHelperWithString.cs
- SynchronizationContext.cs
- SiteMembershipCondition.cs
- TextStore.cs
- LateBoundBitmapDecoder.cs
- TimeSpanMinutesOrInfiniteConverter.cs
- WebDescriptionAttribute.cs
- WebPartEditorApplyVerb.cs
- FacetDescription.cs
- Vector3DCollectionValueSerializer.cs
- SuppressMergeCheckAttribute.cs
- WebUtil.cs
- Run.cs
- FileReader.cs
- ClientRuntimeConfig.cs
- TypeSystemProvider.cs
- PrincipalPermission.cs
- SiteMapNodeItem.cs
- LocationUpdates.cs
- XmlDocument.cs
- RuleAttributes.cs
- WebConfigurationHost.cs
- OdbcInfoMessageEvent.cs
- DiscoveryExceptionDictionary.cs
- PagerSettings.cs
- UIAgentAsyncBeginRequest.cs
- Utils.cs
- CompositeDispatchFormatter.cs
- DBConnection.cs
- DataGridViewIntLinkedList.cs