Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / Orcas / SP / ndp / fx / src / DataEntity / System / Data / Map / ViewGeneration / Structures / OneOfTypeConst.cs / 2 / OneOfTypeConst.cs
//---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // // // @owner [....] // @backupOwner [....] //--------------------------------------------------------------------- using System.Data.Common.Utils; using System.Data.Common.Utils.Boolean; using System.Collections.Generic; using System.Text; using System.Diagnostics; using System.Data.Mapping.ViewGeneration.CqlGeneration; using System.Data.Metadata.Edm; namespace System.Data.Mapping.ViewGeneration.Structures { using DomainBoolExpr = BoolExpr>; using CellConstantSet = Set ; // A class that denotes the boolean expression: "varType in values" // See the comments in OneOfConst for partially and fully-done objects internal class OneOfTypeConst : OneOfConst { #region Constructors // effects: Creates a partial OneOfTypeConst of the form "node in values" internal OneOfTypeConst(JoinTreeNode node, IEnumerable values) : base(new JoinTreeSlot(node), CreateTypeConstants(values)) { } // effects: Creates a partial OneOfTypeConst of the form "node = values" internal OneOfTypeConst(JoinTreeNode node, CellConstant value) : base(new JoinTreeSlot(node), value) { Debug.Assert(value is TypeConstant || value.IsNull(), "Type or NULL expected"); } // effects: Creates an expression of the form "type of node in type constants // corresponding to values", i.e., a boolean expression of the form "TypeOf(slot) in values" // possibleValues are all the values that node's type can take internal OneOfTypeConst(JoinTreeNode node, IEnumerable values, IEnumerable possibleValues) : base(new JoinTreeSlot(node), CreateTypeConstants(values), CreateTypeConstants(possibleValues)) { } // effects: Creates a "fully-done" OneOfTypeConst that represents // "node in values". possibleValues are all the values that node's type can take internal OneOfTypeConst(JoinTreeNode node, IEnumerable values, IEnumerable possibleValues) : base(new JoinTreeSlot(node), values, possibleValues) { } // effects: Creates an expression of the form "slot = value" // possibleValues are all the values that slot can take internal OneOfTypeConst(JoinTreeNode node, CellConstant value, IEnumerable possibleValues) : base(new JoinTreeSlot(node), value, possibleValues) { Debug.Assert(value is TypeConstant || value.IsNull(), "Type or NULL expected"); } // effects: Creates an expression of the form "slot in domain" internal OneOfTypeConst(JoinTreeSlot slot, CellConstantDomain domain) : base(slot, domain) { } #endregion #region Helper static methods // effects: Given a list of types (which can contain nulls), // returns a corresponding list of Type Constants for those types private static IEnumerable CreateTypeConstants(IEnumerable types) { foreach (EdmType type in types) { if (type == null) { yield return CellConstant.Null; } else { yield return new TypeConstant(type); } } } #endregion #region Methods // requires: IsFullyDone is true // effects: Fixes the range of this in accordance with range internal override DomainBoolExpr FixRange(Set range, MemberDomainMap memberDomainMap) { Debug.Assert(IsFullyDone, "Ranges are fixed only for fully done OneOfConsts"); IEnumerable possibleValues = memberDomainMap.GetDomain(Slot.MemberPath); BoolLiteral newLiteral = new OneOfTypeConst(Slot, new CellConstantDomain(range, possibleValues)); return newLiteral.GetDomainBoolExpression(memberDomainMap); } internal override StringBuilder AsCql(StringBuilder builder, string blockAlias, bool canSkipIsNotNull) { // type comparison: make a big OR // Important to enclose all the OR statements in () ! if (Values.Count > 1) { builder.Append('('); } bool isFirst = true; // Add Cql of the form "(T.A IS OF (ONLY Person) OR .....)" foreach (CellConstant constant in Values.Values) { TypeConstant typeConstant = constant as TypeConstant; Debug.Assert(typeConstant != null || constant.IsNull(), "Constants for type checks must be type constants or NULLs"); if (isFirst == false) { builder.Append(" OR "); } isFirst = false; if (Slot.MemberPath.EdmType is RefType) { builder.Append("Deref("); Slot.MemberPath.AsCql(builder, blockAlias); builder.Append(')'); } else { // non-reference type Slot.MemberPath.AsCql(builder, blockAlias); } if (constant.IsNull()) { builder.Append(" IS NULL"); } else { // type constant builder.Append(" IS OF (ONLY "); CqlWriter.AppendEscapedTypeName(builder, typeConstant.CdmType); builder.Append(')'); } } if (Values.Count > 1) { builder.Append(')'); } return builder; } internal override StringBuilder AsUserString(StringBuilder builder, string blockAlias, bool canSkipIsNotNull) { // Add user readable string of the form "(T.A IS OF (ONLY Person) OR .....)" if (Slot.MemberPath.EdmType is RefType) { builder.Append("Deref("); Slot.MemberPath.AsCql(builder, blockAlias); builder.Append(')'); } else { // non-reference type Slot.MemberPath.AsCql(builder, blockAlias); } if (Values.Count > 1) { builder.Append(" is a ("); } else { builder.Append(" is type "); } bool isFirst = true; foreach (CellConstant constant in Values.Values) { TypeConstant typeConstant = constant as TypeConstant; Debug.Assert(typeConstant != null || constant.IsNull(), "Constants for type checks must be type constants or NULLs"); if (isFirst == false) { builder.Append(" OR "); } if (constant.IsNull()) { builder.Append(" NULL"); } else { CqlWriter.AppendEscapedTypeName(builder, typeConstant.CdmType); } isFirst = false; } if (Values.Count > 1) { builder.Append(')'); } return builder; } #endregion #region String methods internal override void ToCompactString(StringBuilder builder) { builder.Append("type("); Slot.ToCompactString(builder); builder.Append(") IN ("); StringUtil.ToCommaSeparatedStringSorted(builder, Values.Values); builder.Append(")"); } #endregion } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //---------------------------------------------------------------------- // // Copyright (c) Microsoft Corporation. All rights reserved. // // // @owner [....] // @backupOwner [....] //--------------------------------------------------------------------- using System.Data.Common.Utils; using System.Data.Common.Utils.Boolean; using System.Collections.Generic; using System.Text; using System.Diagnostics; using System.Data.Mapping.ViewGeneration.CqlGeneration; using System.Data.Metadata.Edm; namespace System.Data.Mapping.ViewGeneration.Structures { using DomainBoolExpr = BoolExpr>; using CellConstantSet = Set ; // A class that denotes the boolean expression: "varType in values" // See the comments in OneOfConst for partially and fully-done objects internal class OneOfTypeConst : OneOfConst { #region Constructors // effects: Creates a partial OneOfTypeConst of the form "node in values" internal OneOfTypeConst(JoinTreeNode node, IEnumerable values) : base(new JoinTreeSlot(node), CreateTypeConstants(values)) { } // effects: Creates a partial OneOfTypeConst of the form "node = values" internal OneOfTypeConst(JoinTreeNode node, CellConstant value) : base(new JoinTreeSlot(node), value) { Debug.Assert(value is TypeConstant || value.IsNull(), "Type or NULL expected"); } // effects: Creates an expression of the form "type of node in type constants // corresponding to values", i.e., a boolean expression of the form "TypeOf(slot) in values" // possibleValues are all the values that node's type can take internal OneOfTypeConst(JoinTreeNode node, IEnumerable values, IEnumerable possibleValues) : base(new JoinTreeSlot(node), CreateTypeConstants(values), CreateTypeConstants(possibleValues)) { } // effects: Creates a "fully-done" OneOfTypeConst that represents // "node in values". possibleValues are all the values that node's type can take internal OneOfTypeConst(JoinTreeNode node, IEnumerable values, IEnumerable possibleValues) : base(new JoinTreeSlot(node), values, possibleValues) { } // effects: Creates an expression of the form "slot = value" // possibleValues are all the values that slot can take internal OneOfTypeConst(JoinTreeNode node, CellConstant value, IEnumerable possibleValues) : base(new JoinTreeSlot(node), value, possibleValues) { Debug.Assert(value is TypeConstant || value.IsNull(), "Type or NULL expected"); } // effects: Creates an expression of the form "slot in domain" internal OneOfTypeConst(JoinTreeSlot slot, CellConstantDomain domain) : base(slot, domain) { } #endregion #region Helper static methods // effects: Given a list of types (which can contain nulls), // returns a corresponding list of Type Constants for those types private static IEnumerable CreateTypeConstants(IEnumerable types) { foreach (EdmType type in types) { if (type == null) { yield return CellConstant.Null; } else { yield return new TypeConstant(type); } } } #endregion #region Methods // requires: IsFullyDone is true // effects: Fixes the range of this in accordance with range internal override DomainBoolExpr FixRange(Set range, MemberDomainMap memberDomainMap) { Debug.Assert(IsFullyDone, "Ranges are fixed only for fully done OneOfConsts"); IEnumerable possibleValues = memberDomainMap.GetDomain(Slot.MemberPath); BoolLiteral newLiteral = new OneOfTypeConst(Slot, new CellConstantDomain(range, possibleValues)); return newLiteral.GetDomainBoolExpression(memberDomainMap); } internal override StringBuilder AsCql(StringBuilder builder, string blockAlias, bool canSkipIsNotNull) { // type comparison: make a big OR // Important to enclose all the OR statements in () ! if (Values.Count > 1) { builder.Append('('); } bool isFirst = true; // Add Cql of the form "(T.A IS OF (ONLY Person) OR .....)" foreach (CellConstant constant in Values.Values) { TypeConstant typeConstant = constant as TypeConstant; Debug.Assert(typeConstant != null || constant.IsNull(), "Constants for type checks must be type constants or NULLs"); if (isFirst == false) { builder.Append(" OR "); } isFirst = false; if (Slot.MemberPath.EdmType is RefType) { builder.Append("Deref("); Slot.MemberPath.AsCql(builder, blockAlias); builder.Append(')'); } else { // non-reference type Slot.MemberPath.AsCql(builder, blockAlias); } if (constant.IsNull()) { builder.Append(" IS NULL"); } else { // type constant builder.Append(" IS OF (ONLY "); CqlWriter.AppendEscapedTypeName(builder, typeConstant.CdmType); builder.Append(')'); } } if (Values.Count > 1) { builder.Append(')'); } return builder; } internal override StringBuilder AsUserString(StringBuilder builder, string blockAlias, bool canSkipIsNotNull) { // Add user readable string of the form "(T.A IS OF (ONLY Person) OR .....)" if (Slot.MemberPath.EdmType is RefType) { builder.Append("Deref("); Slot.MemberPath.AsCql(builder, blockAlias); builder.Append(')'); } else { // non-reference type Slot.MemberPath.AsCql(builder, blockAlias); } if (Values.Count > 1) { builder.Append(" is a ("); } else { builder.Append(" is type "); } bool isFirst = true; foreach (CellConstant constant in Values.Values) { TypeConstant typeConstant = constant as TypeConstant; Debug.Assert(typeConstant != null || constant.IsNull(), "Constants for type checks must be type constants or NULLs"); if (isFirst == false) { builder.Append(" OR "); } if (constant.IsNull()) { builder.Append(" NULL"); } else { CqlWriter.AppendEscapedTypeName(builder, typeConstant.CdmType); } isFirst = false; } if (Values.Count > 1) { builder.Append(')'); } return builder; } #endregion #region String methods internal override void ToCompactString(StringBuilder builder) { builder.Append("type("); Slot.ToCompactString(builder); builder.Append(") IN ("); StringUtil.ToCommaSeparatedStringSorted(builder, Values.Values); builder.Append(")"); } #endregion } } // 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
- StreamedWorkflowDefinitionContext.cs
- JumpList.cs
- Timeline.cs
- RegionData.cs
- Preprocessor.cs
- CroppedBitmap.cs
- WorkflowNamespace.cs
- PointLightBase.cs
- HotCommands.cs
- InputDevice.cs
- EncryptedXml.cs
- ControllableStoryboardAction.cs
- StructuralObject.cs
- ErrorHandler.cs
- ObjectViewQueryResultData.cs
- GcHandle.cs
- DetailsViewInsertEventArgs.cs
- ContentElementCollection.cs
- WebExceptionStatus.cs
- EpmContentDeSerializer.cs
- OpCellTreeNode.cs
- TextCharacters.cs
- SqlCommandSet.cs
- ValueSerializerAttribute.cs
- RangeEnumerable.cs
- xmlfixedPageInfo.cs
- Label.cs
- CustomTypeDescriptor.cs
- FakeModelItemImpl.cs
- ColumnMapTranslator.cs
- arclist.cs
- FrameworkTemplate.cs
- XmlReflectionImporter.cs
- ConfigurationValues.cs
- ManagementScope.cs
- TypeDelegator.cs
- WindowsGraphics.cs
- DecoderExceptionFallback.cs
- __ComObject.cs
- MeshGeometry3D.cs
- MonthCalendar.cs
- EmbossBitmapEffect.cs
- LambdaCompiler.cs
- TableProviderWrapper.cs
- RtfNavigator.cs
- FullTextBreakpoint.cs
- CallSiteHelpers.cs
- PermissionToken.cs
- AsyncContentLoadedEventArgs.cs
- DataSourceCache.cs
- ListViewItemSelectionChangedEvent.cs
- processwaithandle.cs
- SqlProvider.cs
- IChannel.cs
- GridViewRowPresenterBase.cs
- MessageSecurityProtocol.cs
- FormDocumentDesigner.cs
- WebServiceErrorEvent.cs
- XmlQuerySequence.cs
- RSAOAEPKeyExchangeDeformatter.cs
- NTAccount.cs
- SizeValueSerializer.cs
- HttpModuleActionCollection.cs
- isolationinterop.cs
- CodeRemoveEventStatement.cs
- AuthenticationSection.cs
- SelectedDatesCollection.cs
- Padding.cs
- SortedList.cs
- LinqDataSourceContextData.cs
- Debug.cs
- XmlSchemaAnnotated.cs
- SignatureHelper.cs
- RuleSetReference.cs
- InheritedPropertyChangedEventArgs.cs
- TraceSource.cs
- FilterQueryOptionExpression.cs
- KeyInfo.cs
- FullTrustAssembly.cs
- LinearKeyFrames.cs
- SiteMapDataSource.cs
- QuaternionAnimation.cs
- GenericsInstances.cs
- Oci.cs
- CodeValidator.cs
- ResourcePermissionBase.cs
- Transform.cs
- EntityReference.cs
- PropertyTabAttribute.cs
- EntityDataSourceUtil.cs
- HelpProvider.cs
- Encoding.cs
- HttpContext.cs
- objectquery_tresulttype.cs
- SoapExtensionTypeElement.cs
- DataGridViewRowsRemovedEventArgs.cs
- ChameleonKey.cs
- KeyValuePair.cs
- EncodingInfo.cs
- HtmlInputSubmit.cs