Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / Orcas / QFE / ndp / fx / src / DataEntity / System / Data / Query / PlanCompiler / TypeUtils.cs / 2 / TypeUtils.cs
//---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // // // @owner [....], [....] //--------------------------------------------------------------------- using System; using System.Collections.Generic; //using System.Diagnostics; // Please use PlanCompiler.Assert instead of Debug.Assert in this class... using System.Globalization; using System.Data.Common; using md = System.Data.Metadata.Edm; // // This module contains a few utility functions that make it easier to operate // with type metadata // namespace System.Data.Query.PlanCompiler { ////// This class is used as a Comparer for Types all through the PlanCompiler. /// It has a pretty strict definition of type equality - which pretty much devolves /// to equality of the "Identity" of the Type (not the TypeUsage). /// /// NOTE: Unlike other parts of the query pipeline, record types follow /// a much stricter equality condition here - the field names must be the same, and /// the field types must be equal. /// /// NOTE: Primitive types are considered equal, if their Identities are equal. This doesn't /// take into account any of the facets that are represented external to the type (size, for instance). /// Again, this is different from other parts of the query pipeline; and we're much stricter here /// /// sealed internal class TypeUsageEqualityComparer : IEqualityComparer{ private TypeUsageEqualityComparer() { } internal static readonly TypeUsageEqualityComparer Instance = new TypeUsageEqualityComparer(); #region IEqualityComparer Members public bool Equals(System.Data.Metadata.Edm.TypeUsage x, System.Data.Metadata.Edm.TypeUsage y) { if (x == null || y == null) { return false; } return TypeUsageEqualityComparer.Equals(x.EdmType, y.EdmType); } public int GetHashCode(System.Data.Metadata.Edm.TypeUsage obj) { return obj.EdmType.Identity.GetHashCode(); } #endregion internal static bool Equals(md.EdmType x, md.EdmType y) { return x.Identity.Equals(y.Identity); } } internal static class TypeUtils { /// /// Is this type a UDT? (ie) a structural type supported by the store /// /// the type in question ///true, if the type was a UDT internal static bool IsUdt(md.TypeUsage type) { return IsUdt(type.EdmType); } ////// Is this type a UDT? (ie) a structural type supported by the store /// /// the type in question ///true, if the type was a UDT internal static bool IsUdt(md.EdmType type) { #if UDT_SUPPORT // Ideally this should be as simple as: // return TypeUsage.HasExtendedAttribute(type, MetadataConstants.UdtAttribute); // The definition below is 'Type is a ComplexType defined in the store'. return (BuiltInTypeKind.ComplexType == type.BuiltInTypeKind && TypeHelpers.HasExtendedAttribute(type, MetadataConstants.TargetAttribute)); #else return false; #endif } ////// Is this a structured type? /// Note: Structured, in this context means structured outside the server. /// UDTs for instance, are considered to be scalar types - all WinFS types, /// would by this argument, be scalar types. /// /// The type to check ///true, if the type is a structured type internal static bool IsStructuredType(md.TypeUsage type) { return (md.TypeSemantics.IsReferenceType(type) || md.TypeSemantics.IsRowType(type) || md.TypeSemantics.IsEntityType(type) || md.TypeSemantics.IsRelationshipType(type) || (md.TypeSemantics.IsComplexType(type) && !IsUdt(type))); } ////// Is this type a collection type? /// /// the current type ///true, if this is a collection type internal static bool IsCollectionType(md.TypeUsage type) { return md.TypeSemantics.IsCollectionType(type); } ////// Create a new collection type based on the supplied element type /// /// element type of the collection ///the new collection type internal static md.TypeUsage CreateCollectionType(md.TypeUsage elementType) { return TypeHelpers.CreateCollectionTypeUsage(elementType); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // // // @owner [....], [....] //--------------------------------------------------------------------- using System; using System.Collections.Generic; //using System.Diagnostics; // Please use PlanCompiler.Assert instead of Debug.Assert in this class... using System.Globalization; using System.Data.Common; using md = System.Data.Metadata.Edm; // // This module contains a few utility functions that make it easier to operate // with type metadata // namespace System.Data.Query.PlanCompiler { ////// This class is used as a Comparer for Types all through the PlanCompiler. /// It has a pretty strict definition of type equality - which pretty much devolves /// to equality of the "Identity" of the Type (not the TypeUsage). /// /// NOTE: Unlike other parts of the query pipeline, record types follow /// a much stricter equality condition here - the field names must be the same, and /// the field types must be equal. /// /// NOTE: Primitive types are considered equal, if their Identities are equal. This doesn't /// take into account any of the facets that are represented external to the type (size, for instance). /// Again, this is different from other parts of the query pipeline; and we're much stricter here /// /// sealed internal class TypeUsageEqualityComparer : IEqualityComparer{ private TypeUsageEqualityComparer() { } internal static readonly TypeUsageEqualityComparer Instance = new TypeUsageEqualityComparer(); #region IEqualityComparer Members public bool Equals(System.Data.Metadata.Edm.TypeUsage x, System.Data.Metadata.Edm.TypeUsage y) { if (x == null || y == null) { return false; } return TypeUsageEqualityComparer.Equals(x.EdmType, y.EdmType); } public int GetHashCode(System.Data.Metadata.Edm.TypeUsage obj) { return obj.EdmType.Identity.GetHashCode(); } #endregion internal static bool Equals(md.EdmType x, md.EdmType y) { return x.Identity.Equals(y.Identity); } } internal static class TypeUtils { /// /// Is this type a UDT? (ie) a structural type supported by the store /// /// the type in question ///true, if the type was a UDT internal static bool IsUdt(md.TypeUsage type) { return IsUdt(type.EdmType); } ////// Is this type a UDT? (ie) a structural type supported by the store /// /// the type in question ///true, if the type was a UDT internal static bool IsUdt(md.EdmType type) { #if UDT_SUPPORT // Ideally this should be as simple as: // return TypeUsage.HasExtendedAttribute(type, MetadataConstants.UdtAttribute); // The definition below is 'Type is a ComplexType defined in the store'. return (BuiltInTypeKind.ComplexType == type.BuiltInTypeKind && TypeHelpers.HasExtendedAttribute(type, MetadataConstants.TargetAttribute)); #else return false; #endif } ////// Is this a structured type? /// Note: Structured, in this context means structured outside the server. /// UDTs for instance, are considered to be scalar types - all WinFS types, /// would by this argument, be scalar types. /// /// The type to check ///true, if the type is a structured type internal static bool IsStructuredType(md.TypeUsage type) { return (md.TypeSemantics.IsReferenceType(type) || md.TypeSemantics.IsRowType(type) || md.TypeSemantics.IsEntityType(type) || md.TypeSemantics.IsRelationshipType(type) || (md.TypeSemantics.IsComplexType(type) && !IsUdt(type))); } ////// Is this type a collection type? /// /// the current type ///true, if this is a collection type internal static bool IsCollectionType(md.TypeUsage type) { return md.TypeSemantics.IsCollectionType(type); } ////// Create a new collection type based on the supplied element type /// /// element type of the collection ///the new collection type internal static md.TypeUsage CreateCollectionType(md.TypeUsage elementType) { return TypeHelpers.CreateCollectionTypeUsage(elementType); } } } // 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
- HtmlAnchor.cs
- SecUtil.cs
- RuntimeConfigLKG.cs
- ImageDrawing.cs
- ConfigurationStrings.cs
- EnvironmentPermission.cs
- WsdlInspector.cs
- DesignDataSource.cs
- StrongNameKeyPair.cs
- EditingCoordinator.cs
- FunctionOverloadResolver.cs
- _BufferOffsetSize.cs
- AnchorEditor.cs
- EqualityComparer.cs
- RowCache.cs
- MethodBody.cs
- Internal.cs
- AutomationPattern.cs
- DataSourceSelectArguments.cs
- CompiledRegexRunnerFactory.cs
- MenuBindingsEditor.cs
- ChtmlPageAdapter.cs
- ResolveMatchesMessage11.cs
- DataBinder.cs
- Empty.cs
- DataGridViewCellStyleContentChangedEventArgs.cs
- ModelItemExtensions.cs
- ApplicationHost.cs
- TypedElement.cs
- Int32CAMarshaler.cs
- CompiledXpathExpr.cs
- RijndaelCryptoServiceProvider.cs
- _NegoState.cs
- PenThreadWorker.cs
- SoapSchemaMember.cs
- DataGridGeneralPage.cs
- InputLanguageManager.cs
- PeerResolverElement.cs
- basevalidator.cs
- AutoResizedEvent.cs
- CodeAttributeDeclarationCollection.cs
- EmptyArray.cs
- VisualBasicSettingsHandler.cs
- srgsitem.cs
- CompilationUtil.cs
- ResourcesChangeInfo.cs
- ConfigurationElementProperty.cs
- ColorTranslator.cs
- SqlInternalConnection.cs
- ResXDataNode.cs
- WrappedReader.cs
- AutomationEventArgs.cs
- _SslStream.cs
- RepeaterItemCollection.cs
- LogArchiveSnapshot.cs
- InputBinder.cs
- RSAPKCS1SignatureFormatter.cs
- SqlDataSourceSelectingEventArgs.cs
- ComboBoxAutomationPeer.cs
- RadioButton.cs
- InfocardChannelParameter.cs
- NameValueCollection.cs
- UrlMappingsSection.cs
- DataFormats.cs
- ServiceRoute.cs
- UITypeEditors.cs
- HighlightVisual.cs
- MaterializeFromAtom.cs
- SingleObjectCollection.cs
- XNodeValidator.cs
- ErrorReporting.cs
- SBCSCodePageEncoding.cs
- XmlSchemaDatatype.cs
- ByValueEqualityComparer.cs
- TemplateEditingService.cs
- ExtensibleClassFactory.cs
- Brush.cs
- xmlsaver.cs
- DesignerGenericWebPart.cs
- BlockUIContainer.cs
- PersistChildrenAttribute.cs
- AdCreatedEventArgs.cs
- RuntimeIdentifierPropertyAttribute.cs
- IPipelineRuntime.cs
- ColumnResizeAdorner.cs
- ParseNumbers.cs
- TimeoutException.cs
- WebSysDescriptionAttribute.cs
- PlatformCulture.cs
- TouchEventArgs.cs
- EmptyEnumerator.cs
- BezierSegment.cs
- WpfWebRequestHelper.cs
- ThreadStartException.cs
- OneOfElement.cs
- Schema.cs
- FrameworkElement.cs
- Font.cs
- CompilerError.cs
- StorageComplexPropertyMapping.cs