Code:
/ 4.0 / 4.0 / untmp / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / DataEntity / System / Data / Common / Utils / Boolean / NegationPusher.cs / 1305376 / 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.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- DataTableExtensions.cs
- DigestComparer.cs
- BasicExpressionVisitor.cs
- RichTextBoxConstants.cs
- ComponentDispatcherThread.cs
- SharedStatics.cs
- InteropTrackingRecord.cs
- DiffuseMaterial.cs
- EntityParameter.cs
- ObsoleteAttribute.cs
- ValidationEventArgs.cs
- FontFamily.cs
- ConfigurationPropertyAttribute.cs
- ErrorInfoXmlDocument.cs
- IisNotInstalledException.cs
- ReferenceSchema.cs
- StorageInfo.cs
- GeometryValueSerializer.cs
- State.cs
- ToolTip.cs
- DBPropSet.cs
- AsyncPostBackTrigger.cs
- Int64AnimationUsingKeyFrames.cs
- TriState.cs
- WebPartMenuStyle.cs
- GlyphRunDrawing.cs
- EntityContainer.cs
- PreviewKeyDownEventArgs.cs
- FragmentQueryKB.cs
- ColumnResizeAdorner.cs
- LockingPersistenceProvider.cs
- BitFlagsGenerator.cs
- SchemaNotation.cs
- ExecutedRoutedEventArgs.cs
- WebPartEditorCancelVerb.cs
- PageAdapter.cs
- AutoResetEvent.cs
- StreamBodyWriter.cs
- SqlNodeAnnotations.cs
- ActivityScheduledQuery.cs
- PageContentAsyncResult.cs
- IndicShape.cs
- PenThreadPool.cs
- SiteOfOriginContainer.cs
- QilInvokeEarlyBound.cs
- securestring.cs
- RtType.cs
- webclient.cs
- ContractsBCL.cs
- Converter.cs
- TextViewSelectionProcessor.cs
- MemberAccessException.cs
- PlainXmlSerializer.cs
- XamlVector3DCollectionSerializer.cs
- RedirectionProxy.cs
- Empty.cs
- IIS7UserPrincipal.cs
- WebBrowserNavigatingEventHandler.cs
- BinaryObjectInfo.cs
- PerformanceCounterManager.cs
- UnsafeMethods.cs
- ElementMarkupObject.cs
- HtmlTable.cs
- WindowsFormsHelpers.cs
- MetabaseSettingsIis7.cs
- VerificationException.cs
- ToolboxItemImageConverter.cs
- GeneralTransform.cs
- NetworkCredential.cs
- AnnouncementInnerClientCD1.cs
- UserControlCodeDomTreeGenerator.cs
- StackSpiller.Generated.cs
- CollectionBuilder.cs
- WebPartPersonalization.cs
- ImageCodecInfoPrivate.cs
- PipelineModuleStepContainer.cs
- ImageKeyConverter.cs
- FormsAuthenticationUser.cs
- SqlStatistics.cs
- XmlComplianceUtil.cs
- DiscoveryClientReferences.cs
- HtmlTernaryTree.cs
- PageWrapper.cs
- SqlBuffer.cs
- DeclaredTypeValidatorAttribute.cs
- SqlProcedureAttribute.cs
- NotSupportedException.cs
- DataMisalignedException.cs
- ParallelForEach.cs
- PropertyRef.cs
- TextChange.cs
- SafeNativeMethods.cs
- SizeAnimationUsingKeyFrames.cs
- ColumnResizeAdorner.cs
- DataDocumentXPathNavigator.cs
- CrossAppDomainChannel.cs
- PageParser.cs
- ProfileModule.cs
- Bits.cs
- SqlDependency.cs