Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / Orcas / QFE / ndp / fx / src / DataEntity / System / Data / Common / Utils / Boolean / NegationPusher.cs / 2 / NegationPusher.cs
//---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // // // @owner [....] // @backupOwner [....] //--------------------------------------------------------------------- using System; using System.Collections.Generic; using System.Text; using System.Diagnostics; using System.Linq; namespace System.Data.Common.Utils.Boolean { // Top-down push-down of negation in Boolean expressions. // - !(A or B) iff. !A and !B // - !(A and B) iff. !A or !B // - !!A iff. A // Uses two visitor classes: one to handle negated subtrees (essentially creates // an inverted tree) and one to handle non-negated subtrees (replicates until it // encounters NotExpr) internal static class NegationPusher { internal static BoolExpr> EliminateNot (BoolExpr > expression) { return expression.Accept(NonNegatedDomainConstraintTreeVisitor .Instance); } private class NonNegatedTreeVisitor : BasicVisitor { internal static readonly NonNegatedTreeVisitor Instance = new NonNegatedTreeVisitor (); protected NonNegatedTreeVisitor() { } internal override BoolExpr VisitNot(NotExpr expression) { return expression.Child.Accept(NegatedTreeVisitor .Instance); } } private class NegatedTreeVisitor : Visitor > { internal static readonly NegatedTreeVisitor Instance = new NegatedTreeVisitor (); protected NegatedTreeVisitor() { } internal override BoolExpr VisitTrue(TrueExpr expression) { return FalseExpr .Value; } internal override BoolExpr VisitFalse(FalseExpr expression) { return TrueExpr .Value; } internal override BoolExpr VisitTerm(TermExpr expression) { return new NotExpr (expression); } internal override BoolExpr VisitNot(NotExpr expression) { return expression.Child.Accept(NonNegatedTreeVisitor .Instance); } internal override BoolExpr VisitAnd(AndExpr expression) { return new OrExpr (expression.Children.Select(child => child.Accept(this))); } internal override BoolExpr VisitOr(OrExpr expression) { return new AndExpr (expression.Children.Select(child => child.Accept(this))); } } private class NonNegatedDomainConstraintTreeVisitor : NonNegatedTreeVisitor > { internal new static readonly NonNegatedDomainConstraintTreeVisitor Instance = new NonNegatedDomainConstraintTreeVisitor (); private NonNegatedDomainConstraintTreeVisitor() { } internal override BoolExpr > VisitNot(NotExpr > expression) { return expression.Child.Accept(NegatedDomainConstraintTreeVisitor .Instance); } } private class NegatedDomainConstraintTreeVisitor : NegatedTreeVisitor > { internal new static readonly NegatedDomainConstraintTreeVisitor Instance = new NegatedDomainConstraintTreeVisitor (); private NegatedDomainConstraintTreeVisitor() { } internal override BoolExpr > VisitNot(NotExpr > expression) { return expression.Child.Accept(NonNegatedDomainConstraintTreeVisitor .Instance); } internal override BoolExpr > VisitTerm(TermExpr > expression) { return new TermExpr >(expression.Identifier.InvertDomainConstraint()); } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //---------------------------------------------------------------------- // // Copyright (c) Microsoft Corporation. All rights reserved. // // // @owner [....] // @backupOwner [....] //--------------------------------------------------------------------- using System; using System.Collections.Generic; using System.Text; using System.Diagnostics; using System.Linq; namespace System.Data.Common.Utils.Boolean { // Top-down push-down of negation in Boolean expressions. // - !(A or B) iff. !A and !B // - !(A and B) iff. !A or !B // - !!A iff. A // Uses two visitor classes: one to handle negated subtrees (essentially creates // an inverted tree) and one to handle non-negated subtrees (replicates until it // encounters NotExpr) internal static class NegationPusher { internal static BoolExpr> EliminateNot (BoolExpr > expression) { return expression.Accept(NonNegatedDomainConstraintTreeVisitor .Instance); } private class NonNegatedTreeVisitor : BasicVisitor { internal static readonly NonNegatedTreeVisitor Instance = new NonNegatedTreeVisitor (); protected NonNegatedTreeVisitor() { } internal override BoolExpr VisitNot(NotExpr expression) { return expression.Child.Accept(NegatedTreeVisitor .Instance); } } private class NegatedTreeVisitor : Visitor > { internal static readonly NegatedTreeVisitor Instance = new NegatedTreeVisitor (); protected NegatedTreeVisitor() { } internal override BoolExpr VisitTrue(TrueExpr expression) { return FalseExpr .Value; } internal override BoolExpr VisitFalse(FalseExpr expression) { return TrueExpr .Value; } internal override BoolExpr VisitTerm(TermExpr expression) { return new NotExpr (expression); } internal override BoolExpr VisitNot(NotExpr expression) { return expression.Child.Accept(NonNegatedTreeVisitor .Instance); } internal override BoolExpr VisitAnd(AndExpr expression) { return new OrExpr (expression.Children.Select(child => child.Accept(this))); } internal override BoolExpr VisitOr(OrExpr expression) { return new AndExpr (expression.Children.Select(child => child.Accept(this))); } } private class NonNegatedDomainConstraintTreeVisitor : NonNegatedTreeVisitor > { internal new static readonly NonNegatedDomainConstraintTreeVisitor Instance = new NonNegatedDomainConstraintTreeVisitor (); private NonNegatedDomainConstraintTreeVisitor() { } internal override BoolExpr > VisitNot(NotExpr > expression) { return expression.Child.Accept(NegatedDomainConstraintTreeVisitor .Instance); } } private class NegatedDomainConstraintTreeVisitor : NegatedTreeVisitor > { internal new static readonly NegatedDomainConstraintTreeVisitor Instance = new NegatedDomainConstraintTreeVisitor (); private NegatedDomainConstraintTreeVisitor() { } internal override BoolExpr > VisitNot(NotExpr > expression) { return expression.Child.Accept(NonNegatedDomainConstraintTreeVisitor .Instance); } internal override BoolExpr > VisitTerm(TermExpr > expression) { return new TermExpr >(expression.Identifier.InvertDomainConstraint()); } } } } // 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
- ReflectionUtil.cs
- SystemException.cs
- NativeMethods.cs
- WindowsPrincipal.cs
- GPStream.cs
- Window.cs
- ConfigurationElementCollection.cs
- HostProtectionException.cs
- VisualStyleElement.cs
- ColumnClickEvent.cs
- ChannelSinkStacks.cs
- DbConnectionFactory.cs
- CursorConverter.cs
- HttpModuleActionCollection.cs
- GlobalizationAssembly.cs
- HtmlPageAdapter.cs
- KnownIds.cs
- CharUnicodeInfo.cs
- ActivityExecutionFilter.cs
- BamlRecordReader.cs
- WebPartsPersonalizationAuthorization.cs
- SiteMapNodeItemEventArgs.cs
- WebBrowserNavigatedEventHandler.cs
- ReflectionPermission.cs
- DefaultPrintController.cs
- OfTypeExpression.cs
- CodeDefaultValueExpression.cs
- AttachedAnnotationChangedEventArgs.cs
- ReadOnlyDataSource.cs
- SchemaObjectWriter.cs
- ImageFormatConverter.cs
- SnapshotChangeTrackingStrategy.cs
- GCHandleCookieTable.cs
- CompiledRegexRunnerFactory.cs
- LoadMessageLogger.cs
- MeshGeometry3D.cs
- SplayTreeNode.cs
- EntityParameterCollection.cs
- CodeAttributeArgument.cs
- NativeMethods.cs
- DeadCharTextComposition.cs
- UserPreferenceChangedEventArgs.cs
- DSACryptoServiceProvider.cs
- TextEditorSpelling.cs
- PersonalizableTypeEntry.cs
- LabelLiteral.cs
- ColorPalette.cs
- MSAAWinEventWrap.cs
- dataSvcMapFileLoader.cs
- CommandPlan.cs
- ViewSimplifier.cs
- XsltInput.cs
- SignatureResourcePool.cs
- MailDefinition.cs
- ObjectPersistData.cs
- ListViewGroup.cs
- DataGridViewCellValidatingEventArgs.cs
- RTTrackingProfile.cs
- COM2AboutBoxPropertyDescriptor.cs
- ClientBuildManager.cs
- PropertyEmitterBase.cs
- WeakReadOnlyCollection.cs
- TableLayoutPanelCellPosition.cs
- HashCodeCombiner.cs
- ExpressionNormalizer.cs
- BuildResultCache.cs
- DbDataRecord.cs
- ErrorFormatterPage.cs
- ClientRoleProvider.cs
- GraphicsContext.cs
- ApplicationFileCodeDomTreeGenerator.cs
- UnsettableComboBox.cs
- PartBasedPackageProperties.cs
- SerializerDescriptor.cs
- EncoderExceptionFallback.cs
- DataGrid.cs
- smtppermission.cs
- ReflectionUtil.cs
- MinimizableAttributeTypeConverter.cs
- WebZone.cs
- TreeBuilder.cs
- MouseBinding.cs
- DbFunctionCommandTree.cs
- SoapParser.cs
- SystemWebExtensionsSectionGroup.cs
- filewebresponse.cs
- recordstatescratchpad.cs
- PrinterSettings.cs
- EntityCodeGenerator.cs
- DragDeltaEventArgs.cs
- Membership.cs
- XPathNavigatorReader.cs
- Membership.cs
- DbBuffer.cs
- columnmapfactory.cs
- OptimalTextSource.cs
- KeyToListMap.cs
- SimpleMailWebEventProvider.cs
- SafePointer.cs
- XmlSerializerNamespaces.cs