Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / Orcas / QFE / ndp / fx / src / DataEntity / System / Data / Metadata / Perspective.cs / 2 / Perspective.cs
//---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // // // @owner [....],[....] //--------------------------------------------------------------------- using System.Diagnostics; namespace System.Data.Metadata.Edm { using System.Collections.Generic; ////// Internal helper class for query /// internal abstract class Perspective { #region Constructors ////// Creates a new instance of perspective class so that query can work /// ignorant of all spaces /// /// runtime metadata container /// target dataspace for the perspective internal Perspective(MetadataWorkspace metadataWorkspace, DataSpace targetDataspace) { EntityUtil.CheckArgumentNull(metadataWorkspace, "metadataWorkspace"); m_metadataWorkspace = metadataWorkspace; m_targetDataspace = targetDataspace; } #endregion #region Fields private MetadataWorkspace m_metadataWorkspace; private DataSpace m_targetDataspace; #endregion #region Methods ////// Given the type in the target space and the member name in the source space, /// get the corresponding member in the target space /// For e.g. consider a Conceptual Type 'Foo' with a member 'Bar' and a CLR type /// 'XFoo' with a member 'YBar'. If one has a reference to Foo one can /// invoke GetMember(Foo,"YBar") to retrieve the member metadata for bar /// /// The type in the target perspective /// the name of the member in the source perspective /// Whether to do case-sensitive member look up or not /// returns the member in target space, if a match is found ///internal virtual bool TryGetMember(StructuralType type, String memberName, bool ignoreCase, out EdmMember outMember) { EntityUtil.CheckArgumentNull(type, "type"); EntityUtil.CheckStringArgument(memberName, "memberName"); outMember = null; // If a normal member is not present, check for navigation property with that name return type.Members.TryGetValue(memberName, ignoreCase, out outMember); } /// /// Returns the extent in the target space, for the given entity container /// /// name of the entity container in target space /// name of the extent /// Whether to do case-sensitive member look up or not /// extent in target space, if a match is found ///returns true, if a match is found otherwise returns false internal bool TryGetExtent(EntityContainer entityContainer, String extentName, bool ignoreCase, out EntitySetBase outSet) { // There are no entity container and extents in the OSpace. So there is no mapping // involved. Hence the name should be a valid name in the CSpace. return entityContainer.BaseEntitySets.TryGetValue(extentName, ignoreCase, out outSet); } ////// Get the default entity container /// returns null for any perspective other /// than the CLR perspective /// ///The default container internal virtual EntityContainer GetDefaultContainer() { return null; } ////// Get an entity container based upon the strong name of the container /// If no entity container is found, returns null, else returns the first one/// /// name of the entity container /// true for case-insensitive lookup /// returns the entity container if a match is found ///returns true if a match is found, otherwise false internal virtual bool TryGetEntityContainer(string name, bool ignoreCase, out EntityContainer entityContainer) { return MetadataWorkspace.TryGetEntityContainer(name, ignoreCase, TargetDataspace, out entityContainer); } ////// Gets the type with the given name in the target space /// /// full name of the type /// true for case-insensitive lookup /// TypeUsage for the type you are looking for ///returns true if a match is found, otherwise returns false internal abstract bool TryGetTypeByName(string fullName, bool ignoreCase, out TypeUsage typeUsage); ////// Returns the list of all the function with the given name /// /// name of the function /// namespace of the function /// whether to do a case-insensitive lookup or not ///internal System.Collections.ObjectModel.ReadOnlyCollection GetFunctions( string name, string namespaceName, bool ignoreCase) { EntityUtil.CheckStringArgument(name, "name"); EntityUtil.CheckStringArgument(namespaceName, "namespaceName"); string functionFullName = namespaceName + "." + name; System.Collections.ObjectModel.ReadOnlyCollection functionOverloads; // First lookup canonical functions EdmItemCollection edmItemCollection = (EdmItemCollection)m_metadataWorkspace.GetItemCollection(DataSpace.CSpace); functionOverloads = edmItemCollection.GetFunctions(functionFullName, ignoreCase); if (null == functionOverloads || 0 == functionOverloads.Count) { StoreItemCollection storeItemCollection = (StoreItemCollection)m_metadataWorkspace.GetItemCollection(DataSpace.SSpace); return storeItemCollection.GetCTypeFunctions(functionFullName, ignoreCase); } return functionOverloads; } /// /// Return the metadata workspace /// internal MetadataWorkspace MetadataWorkspace { get { return m_metadataWorkspace; } } ////// returns the primitive type for a given primitive type kind. /// /// /// ///internal virtual bool TryGetMappedPrimitiveType(PrimitiveTypeKind primitiveTypeKind, out PrimitiveType primitiveType) { primitiveType = m_metadataWorkspace.GetMappedPrimitiveType(primitiveTypeKind, DataSpace.CSpace); return (null != primitiveType); } // // This property will be needed to construct keys for transient types // /// /// Returns the target dataspace for this perspective /// internal DataSpace TargetDataspace { get { return m_targetDataspace; } } #endregion } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // // // @owner [....],[....] //--------------------------------------------------------------------- using System.Diagnostics; namespace System.Data.Metadata.Edm { using System.Collections.Generic; ////// Internal helper class for query /// internal abstract class Perspective { #region Constructors ////// Creates a new instance of perspective class so that query can work /// ignorant of all spaces /// /// runtime metadata container /// target dataspace for the perspective internal Perspective(MetadataWorkspace metadataWorkspace, DataSpace targetDataspace) { EntityUtil.CheckArgumentNull(metadataWorkspace, "metadataWorkspace"); m_metadataWorkspace = metadataWorkspace; m_targetDataspace = targetDataspace; } #endregion #region Fields private MetadataWorkspace m_metadataWorkspace; private DataSpace m_targetDataspace; #endregion #region Methods ////// Given the type in the target space and the member name in the source space, /// get the corresponding member in the target space /// For e.g. consider a Conceptual Type 'Foo' with a member 'Bar' and a CLR type /// 'XFoo' with a member 'YBar'. If one has a reference to Foo one can /// invoke GetMember(Foo,"YBar") to retrieve the member metadata for bar /// /// The type in the target perspective /// the name of the member in the source perspective /// Whether to do case-sensitive member look up or not /// returns the member in target space, if a match is found ///internal virtual bool TryGetMember(StructuralType type, String memberName, bool ignoreCase, out EdmMember outMember) { EntityUtil.CheckArgumentNull(type, "type"); EntityUtil.CheckStringArgument(memberName, "memberName"); outMember = null; // If a normal member is not present, check for navigation property with that name return type.Members.TryGetValue(memberName, ignoreCase, out outMember); } /// /// Returns the extent in the target space, for the given entity container /// /// name of the entity container in target space /// name of the extent /// Whether to do case-sensitive member look up or not /// extent in target space, if a match is found ///returns true, if a match is found otherwise returns false internal bool TryGetExtent(EntityContainer entityContainer, String extentName, bool ignoreCase, out EntitySetBase outSet) { // There are no entity container and extents in the OSpace. So there is no mapping // involved. Hence the name should be a valid name in the CSpace. return entityContainer.BaseEntitySets.TryGetValue(extentName, ignoreCase, out outSet); } ////// Get the default entity container /// returns null for any perspective other /// than the CLR perspective /// ///The default container internal virtual EntityContainer GetDefaultContainer() { return null; } ////// Get an entity container based upon the strong name of the container /// If no entity container is found, returns null, else returns the first one/// /// name of the entity container /// true for case-insensitive lookup /// returns the entity container if a match is found ///returns true if a match is found, otherwise false internal virtual bool TryGetEntityContainer(string name, bool ignoreCase, out EntityContainer entityContainer) { return MetadataWorkspace.TryGetEntityContainer(name, ignoreCase, TargetDataspace, out entityContainer); } ////// Gets the type with the given name in the target space /// /// full name of the type /// true for case-insensitive lookup /// TypeUsage for the type you are looking for ///returns true if a match is found, otherwise returns false internal abstract bool TryGetTypeByName(string fullName, bool ignoreCase, out TypeUsage typeUsage); ////// Returns the list of all the function with the given name /// /// name of the function /// namespace of the function /// whether to do a case-insensitive lookup or not ///internal System.Collections.ObjectModel.ReadOnlyCollection GetFunctions( string name, string namespaceName, bool ignoreCase) { EntityUtil.CheckStringArgument(name, "name"); EntityUtil.CheckStringArgument(namespaceName, "namespaceName"); string functionFullName = namespaceName + "." + name; System.Collections.ObjectModel.ReadOnlyCollection functionOverloads; // First lookup canonical functions EdmItemCollection edmItemCollection = (EdmItemCollection)m_metadataWorkspace.GetItemCollection(DataSpace.CSpace); functionOverloads = edmItemCollection.GetFunctions(functionFullName, ignoreCase); if (null == functionOverloads || 0 == functionOverloads.Count) { StoreItemCollection storeItemCollection = (StoreItemCollection)m_metadataWorkspace.GetItemCollection(DataSpace.SSpace); return storeItemCollection.GetCTypeFunctions(functionFullName, ignoreCase); } return functionOverloads; } /// /// Return the metadata workspace /// internal MetadataWorkspace MetadataWorkspace { get { return m_metadataWorkspace; } } ////// returns the primitive type for a given primitive type kind. /// /// /// ///internal virtual bool TryGetMappedPrimitiveType(PrimitiveTypeKind primitiveTypeKind, out PrimitiveType primitiveType) { primitiveType = m_metadataWorkspace.GetMappedPrimitiveType(primitiveTypeKind, DataSpace.CSpace); return (null != primitiveType); } // // This property will be needed to construct keys for transient types // /// /// Returns the target dataspace for this perspective /// internal DataSpace TargetDataspace { get { return m_targetDataspace; } } #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
- TextEditorTables.cs
- DTCTransactionManager.cs
- BuildResult.cs
- Adorner.cs
- TextCompositionEventArgs.cs
- GlobalProxySelection.cs
- WindowsRichEdit.cs
- StaticResourceExtension.cs
- SmtpTransport.cs
- TextServicesLoader.cs
- SingleTagSectionHandler.cs
- Compiler.cs
- DataSetUtil.cs
- Matrix.cs
- DocumentApplicationJournalEntry.cs
- ReferenceConverter.cs
- _ScatterGatherBuffers.cs
- ResourceDescriptionAttribute.cs
- ValidatorCompatibilityHelper.cs
- Literal.cs
- __Filters.cs
- ClientTargetCollection.cs
- FileSystemInfo.cs
- Quaternion.cs
- SoapServerProtocol.cs
- ProxyFragment.cs
- DbDataReader.cs
- ValidationRule.cs
- NamedElement.cs
- XNameConverter.cs
- ViewManager.cs
- QilIterator.cs
- HtmlTableRow.cs
- ButtonField.cs
- PeerNodeAddress.cs
- DetailsViewInsertedEventArgs.cs
- WpfWebRequestHelper.cs
- ISessionStateStore.cs
- ObjectManager.cs
- SchemaNotation.cs
- RegisteredScript.cs
- TypeForwardedFromAttribute.cs
- RegexRunner.cs
- RegexCharClass.cs
- __TransparentProxy.cs
- util.cs
- XmlSchemaInferenceException.cs
- TextContainerChangeEventArgs.cs
- TypeDefinition.cs
- RewritingValidator.cs
- AsyncStreamReader.cs
- SQLInt16Storage.cs
- QueryGenerator.cs
- Menu.cs
- CollectionContainer.cs
- MultipleViewProviderWrapper.cs
- WebConfigurationFileMap.cs
- ColorAnimationBase.cs
- DataGridViewAccessibleObject.cs
- MediaElementAutomationPeer.cs
- ExtractedStateEntry.cs
- FixedSOMTableCell.cs
- Normalization.cs
- VoiceChangeEventArgs.cs
- MapPathBasedVirtualPathProvider.cs
- PathFigureCollection.cs
- SelectionProcessor.cs
- ResourceDescriptionAttribute.cs
- infer.cs
- HtmlSelect.cs
- Mappings.cs
- ToolStripLocationCancelEventArgs.cs
- GregorianCalendarHelper.cs
- IssuanceLicense.cs
- ColorMatrix.cs
- RequestSecurityTokenForGetBrowserToken.cs
- Matrix3D.cs
- LongCountAggregationOperator.cs
- WindowsIdentity.cs
- GcSettings.cs
- Events.cs
- RegexInterpreter.cs
- AssociationTypeEmitter.cs
- ConfigsHelper.cs
- CompilerScopeManager.cs
- RowUpdatedEventArgs.cs
- ColorConverter.cs
- SocketException.cs
- SafeThreadHandle.cs
- ThicknessAnimationUsingKeyFrames.cs
- XmlSchemaImport.cs
- JoinSymbol.cs
- CLSCompliantAttribute.cs
- storagemappingitemcollection.viewdictionary.cs
- FontCacheUtil.cs
- nulltextnavigator.cs
- FileUpload.cs
- BookmarkNameHelper.cs
- XmlSerializationGeneratedCode.cs
- DataGridLength.cs