Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / 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
- ToolStripSettings.cs
- LogWriteRestartAreaState.cs
- EmbossBitmapEffect.cs
- WindowsTokenRoleProvider.cs
- HttpTransportBindingElement.cs
- InfoCardCryptoHelper.cs
- TypeForwardedToAttribute.cs
- BinaryCommonClasses.cs
- ExecutionContext.cs
- BindingMAnagerBase.cs
- OutputBuffer.cs
- XmlDocumentType.cs
- Sql8ExpressionRewriter.cs
- IdentifierCollection.cs
- NativeMethods.cs
- Bold.cs
- TrackingLocation.cs
- Timer.cs
- LineInfo.cs
- HtmlElementCollection.cs
- CorrelationValidator.cs
- MetadataUtil.cs
- NameTable.cs
- FileNotFoundException.cs
- SqlCacheDependencyDatabase.cs
- VectorCollection.cs
- UserControl.cs
- TypeConverterHelper.cs
- ErrorTableItemStyle.cs
- ModelUIElement3D.cs
- EndPoint.cs
- ApplicationServiceManager.cs
- FixedHighlight.cs
- XmlSchemaInfo.cs
- TimeSpanSecondsOrInfiniteConverter.cs
- SoapSchemaExporter.cs
- GridViewDeletedEventArgs.cs
- CompiledQuery.cs
- NameTable.cs
- UriSection.cs
- TreeNode.cs
- HostingEnvironmentSection.cs
- TypeKeyValue.cs
- WizardForm.cs
- RelationalExpressions.cs
- Utility.cs
- BindingContext.cs
- StructuralObject.cs
- DesignerActionList.cs
- ValueExpressions.cs
- TabItem.cs
- SetterBase.cs
- ImageSourceValueSerializer.cs
- SoapClientMessage.cs
- ServiceMemoryGates.cs
- ParserContext.cs
- XmlTextWriter.cs
- ArgumentDesigner.xaml.cs
- KeyedCollection.cs
- DeviceContext.cs
- ColumnResizeUndoUnit.cs
- CapabilitiesPattern.cs
- TreeNodeEventArgs.cs
- DbProviderFactories.cs
- FrameworkElementAutomationPeer.cs
- XmlDataImplementation.cs
- WebPartConnectionsCloseVerb.cs
- RegexTree.cs
- Menu.cs
- ControlTemplate.cs
- RepeatInfo.cs
- EventBindingService.cs
- KnowledgeBase.cs
- ContractMapping.cs
- ErrorFormatter.cs
- PageSettings.cs
- StrongNameKeyPair.cs
- SafeEventLogWriteHandle.cs
- EventProviderWriter.cs
- QilReplaceVisitor.cs
- EntityKey.cs
- AuthenticationException.cs
- PictureBoxDesigner.cs
- QilInvoke.cs
- SystemWebCachingSectionGroup.cs
- XmlMtomReader.cs
- DrawingBrush.cs
- ClickablePoint.cs
- ColumnReorderedEventArgs.cs
- CheckBoxList.cs
- DataSourceConverter.cs
- AdPostCacheSubstitution.cs
- COM2Enum.cs
- WebPartManagerInternals.cs
- UnsafeNativeMethods.cs
- DataGridViewCellStyleEditor.cs
- oledbconnectionstring.cs
- CatalogPartCollection.cs
- ObsoleteAttribute.cs
- FilterableData.cs