Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / Orcas / NetFXw7 / ndp / fx / src / DataEntity / System / Data / Common / Utils / Boolean / NegationPusher.cs / 1 / 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
- DataService.cs
- PrintPageEvent.cs
- AlignmentYValidation.cs
- XmlSerializableWriter.cs
- SmiConnection.cs
- ToolStripOverflowButton.cs
- Trace.cs
- XmlSchemaSimpleTypeUnion.cs
- ServiceAppDomainAssociationProvider.cs
- DecoderFallback.cs
- documentsequencetextcontainer.cs
- XmlName.cs
- ManipulationPivot.cs
- XmlSchemaAnyAttribute.cs
- ContentPresenter.cs
- DataGridLengthConverter.cs
- XmlUrlResolver.cs
- UIEndRequest.cs
- EpmContentDeSerializer.cs
- CommandSet.cs
- SliderAutomationPeer.cs
- XamlPoint3DCollectionSerializer.cs
- MapPathBasedVirtualPathProvider.cs
- RoleGroupCollection.cs
- XslAst.cs
- ContainerUIElement3D.cs
- DrawListViewColumnHeaderEventArgs.cs
- SHA256Managed.cs
- MetabaseSettings.cs
- XmlDataSourceDesigner.cs
- WindowsServiceCredential.cs
- RevocationPoint.cs
- IChannel.cs
- TextInfo.cs
- MaskInputRejectedEventArgs.cs
- ToolStripDropDownButton.cs
- GenericAuthenticationEventArgs.cs
- ZipIOZip64EndOfCentralDirectoryBlock.cs
- FontNamesConverter.cs
- Site.cs
- PixelFormatConverter.cs
- ConsumerConnectionPoint.cs
- COAUTHINFO.cs
- NotifyParentPropertyAttribute.cs
- Error.cs
- Internal.cs
- RIPEMD160.cs
- Rfc2898DeriveBytes.cs
- SoapObjectReader.cs
- AuthenticationException.cs
- LinearQuaternionKeyFrame.cs
- HttpResponseInternalWrapper.cs
- BoundsDrawingContextWalker.cs
- TranslateTransform3D.cs
- SafeSystemMetrics.cs
- SafeHandles.cs
- DataGridColumn.cs
- LogExtentCollection.cs
- EncryptedData.cs
- Rotation3DAnimationBase.cs
- ThicknessAnimationUsingKeyFrames.cs
- BindingRestrictions.cs
- BoolExpr.cs
- DecodeHelper.cs
- ContentFilePart.cs
- EmptyEnumerator.cs
- RegexMatch.cs
- TypeDescriptorFilterService.cs
- XmlAttributeCollection.cs
- GC.cs
- ToolboxItemCollection.cs
- ReceiveContent.cs
- MessageHeader.cs
- ImageInfo.cs
- Evidence.cs
- ListenerConnectionModeReader.cs
- ToggleButtonAutomationPeer.cs
- ParseElementCollection.cs
- MarginsConverter.cs
- ResourceReferenceKeyNotFoundException.cs
- XmlStreamStore.cs
- GradientStop.cs
- DataGridCell.cs
- OpacityConverter.cs
- NetCodeGroup.cs
- sqlpipe.cs
- CalendarDataBindingHandler.cs
- DefaultPrintController.cs
- MgmtConfigurationRecord.cs
- SecurityTokenRequirement.cs
- CoreChannel.cs
- CodeChecksumPragma.cs
- DiscreteKeyFrames.cs
- CommandHelper.cs
- brushes.cs
- DesignTimeXamlWriter.cs
- Misc.cs
- TrackPoint.cs
- ModelTypeConverter.cs
- RenderData.cs