Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / DataWeb / Client / System / Data / Services / Client / EntityPropertyMappingAttribute.cs / 1305376 / EntityPropertyMappingAttribute.cs
//---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // //// EntityPropertyMapping attribute implementation // // // @owner [....] //--------------------------------------------------------------------- namespace System.Data.Services.Common { using System; using System.Data.Services.Client; ////// List of syndication properties settable through ////// /// Potentially the following atom specific elements could also be considered: /// * Author* /// * Category* /// * Content? /// * Contributor* /// * Id /// * Link* /// * Source? /// public enum SyndicationItemProperty { ////// User specified a non-syndication property /// CustomProperty, ////// author/email /// AuthorEmail, ////// author/name /// AuthorName, // Author* ////// author/uri /// AuthorUri, ////// contributor/email /// ContributorEmail, ////// contributor/name /// ContributorName, // Contributor* ////// contributor/uri /// ContributorUri, ////// updated /// Updated, // CategoryTerm, // Category* // CategoryScheme, // CategoryLabel, // LinkHref, // Link* // LinkRel, // LinkType, // LinkHrefLang, // LinkTitle, // LinkLength, ////// published /// Published, ////// rights /// Rights, ////// summary /// Summary, ////// title /// Title } ////// Type of content for a public enum SyndicationTextContentKind { ///if the property /// is of text type /// /// Plaintext /// Plaintext, ////// HTML /// Html, ////// XHTML /// Xhtml } ////// Attribute used for mapping a given property or sub-property of a ResourceType to /// an xml element/attribute with arbitrary nesting /// [AttributeUsage(AttributeTargets.Class, AllowMultiple = true, Inherited = true)] public sealed class EntityPropertyMappingAttribute : Attribute { #region Private Members ///Schema Namespace prefix for atom. private const string AtomNamespacePrefix = "atom"; ////// Source property path /// private readonly String sourcePath; ////// Target Xml element/attribute /// private readonly String targetPath; ////// If mapping to syndication element, the name of syndication item /// private readonly SyndicationItemProperty targetSyndicationItem; ////// If mapping to syndication content, the content type of syndication item /// private readonly SyndicationTextContentKind targetTextContentKind; ////// If mapping to non-syndication element/attribute, the namespace prefix for the /// target element/attribute /// private readonly String targetNamespacePrefix; ////// If mapping to non-syndication element/attribute, the namespace for the /// target element/attribute /// private readonly String targetNamespaceUri; ////// The content can optionally be kept in the original location along with the /// newly mapping location by setting this option to true, false by default /// private readonly bool keepInContent; #endregion #region Constructors ////// Used for mapping a resource property to syndication content /// /// Source property path /// Syndication item to which theis mapped /// Syndication content kind for /// If true the property value is kept in the content section as before, /// when false the property value is only placed at the mapped location public EntityPropertyMappingAttribute(String sourcePath, SyndicationItemProperty targetSyndicationItem, SyndicationTextContentKind targetTextContentKind, bool keepInContent) { if (String.IsNullOrEmpty(sourcePath)) { throw new ArgumentException(Strings.EntityPropertyMapping_EpmAttribute("sourcePath")); } this.sourcePath = sourcePath; this.targetPath = SyndicationItemPropertyToPath(targetSyndicationItem); this.targetSyndicationItem = targetSyndicationItem; this.targetTextContentKind = targetTextContentKind; this.targetNamespacePrefix = EntityPropertyMappingAttribute.AtomNamespacePrefix; this.targetNamespaceUri = XmlConstants.AtomNamespace; this.keepInContent = keepInContent; } /// /// Used for mapping a resource property to arbitrary xml element/attribute /// /// Source property path /// Target element/attribute path /// Namespace prefix for theto which belongs /// Uri of the namespace to which belongs /// If true the property value is kept in the content section as before, /// when false the property value is only placed at the mapped location public EntityPropertyMappingAttribute(String sourcePath, String targetPath, String targetNamespacePrefix, String targetNamespaceUri, bool keepInContent) { if (String.IsNullOrEmpty(sourcePath)) { throw new ArgumentException(Strings.EntityPropertyMapping_EpmAttribute("sourcePath")); } this.sourcePath = sourcePath; if (String.IsNullOrEmpty(targetPath)) { throw new ArgumentException(Strings.EntityPropertyMapping_EpmAttribute("targetPath")); } if (targetPath[0] == '@') { throw new ArgumentException(Strings.EpmTargetTree_InvalidTargetPath(targetPath)); } this.targetPath = targetPath; this.targetSyndicationItem = SyndicationItemProperty.CustomProperty; this.targetTextContentKind = SyndicationTextContentKind.Plaintext; this.targetNamespacePrefix = targetNamespacePrefix; if (String.IsNullOrEmpty(targetNamespaceUri)) { throw new ArgumentException(Strings.EntityPropertyMapping_EpmAttribute("targetNamespaceUri")); } this.targetNamespaceUri = targetNamespaceUri; Uri uri; if (!Uri.TryCreate(targetNamespaceUri, UriKind.Absolute, out uri)) { throw new ArgumentException(Strings.EntityPropertyMapping_TargetNamespaceUriNotValid(targetNamespaceUri)); } this.keepInContent = keepInContent; } #region Properties /// /// Source property path /// public String SourcePath { get { return this.sourcePath; } } ////// Target Xml element/attribute /// public String TargetPath { get { return this.targetPath; } } ////// If mapping to syndication element, the name of syndication item /// public SyndicationItemProperty TargetSyndicationItem { get { return this.targetSyndicationItem; } } ////// If mapping to non-syndication element/attribute, the namespace prefix for the /// target element/attribute /// public String TargetNamespacePrefix { get { return this.targetNamespacePrefix; } } ////// If mapping to non-syndication element/attribute, the namespace for the /// target element/attribute /// public String TargetNamespaceUri { get { return this.targetNamespaceUri; } } ////// If mapping to syndication content, the content type of syndication item /// public SyndicationTextContentKind TargetTextContentKind { get { return this.targetTextContentKind; } } ////// The content can optionally be kept in the original location along with the /// newly mapping location by setting this option to true, false by default /// public bool KeepInContent { get { return this.keepInContent; } } #endregion ////// Maps the enumeration of allowed /// Value of thevalues to their string representations /// given in /// the contstructor /// String representing the xml element path in the syndication property internal static String SyndicationItemPropertyToPath(SyndicationItemProperty targetSyndicationItem) { switch (targetSyndicationItem) { case SyndicationItemProperty.AuthorEmail: return "author/email"; case SyndicationItemProperty.AuthorName: return "author/name"; case SyndicationItemProperty.AuthorUri: return "author/uri"; case SyndicationItemProperty.ContributorEmail: return "contributor/email"; case SyndicationItemProperty.ContributorName: return "contributor/name"; case SyndicationItemProperty.ContributorUri: return "contributor/uri"; case SyndicationItemProperty.Updated: return "updated"; case SyndicationItemProperty.Published: return "published"; case SyndicationItemProperty.Rights: return "rights"; case SyndicationItemProperty.Summary: return "summary"; case SyndicationItemProperty.Title: return "title"; default: throw new ArgumentException(Strings.EntityPropertyMapping_EpmAttribute("targetSyndicationItem")); } } #endregion } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //---------------------------------------------------------------------- //// Copyright (c) Microsoft Corporation. All rights reserved. // //// EntityPropertyMapping attribute implementation // // // @owner [....] //--------------------------------------------------------------------- namespace System.Data.Services.Common { using System; using System.Data.Services.Client; ////// List of syndication properties settable through ////// /// Potentially the following atom specific elements could also be considered: /// * Author* /// * Category* /// * Content? /// * Contributor* /// * Id /// * Link* /// * Source? /// public enum SyndicationItemProperty { ////// User specified a non-syndication property /// CustomProperty, ////// author/email /// AuthorEmail, ////// author/name /// AuthorName, // Author* ////// author/uri /// AuthorUri, ////// contributor/email /// ContributorEmail, ////// contributor/name /// ContributorName, // Contributor* ////// contributor/uri /// ContributorUri, ////// updated /// Updated, // CategoryTerm, // Category* // CategoryScheme, // CategoryLabel, // LinkHref, // Link* // LinkRel, // LinkType, // LinkHrefLang, // LinkTitle, // LinkLength, ////// published /// Published, ////// rights /// Rights, ////// summary /// Summary, ////// title /// Title } ////// Type of content for a public enum SyndicationTextContentKind { ///if the property /// is of text type /// /// Plaintext /// Plaintext, ////// HTML /// Html, ////// XHTML /// Xhtml } ////// Attribute used for mapping a given property or sub-property of a ResourceType to /// an xml element/attribute with arbitrary nesting /// [AttributeUsage(AttributeTargets.Class, AllowMultiple = true, Inherited = true)] public sealed class EntityPropertyMappingAttribute : Attribute { #region Private Members ///Schema Namespace prefix for atom. private const string AtomNamespacePrefix = "atom"; ////// Source property path /// private readonly String sourcePath; ////// Target Xml element/attribute /// private readonly String targetPath; ////// If mapping to syndication element, the name of syndication item /// private readonly SyndicationItemProperty targetSyndicationItem; ////// If mapping to syndication content, the content type of syndication item /// private readonly SyndicationTextContentKind targetTextContentKind; ////// If mapping to non-syndication element/attribute, the namespace prefix for the /// target element/attribute /// private readonly String targetNamespacePrefix; ////// If mapping to non-syndication element/attribute, the namespace for the /// target element/attribute /// private readonly String targetNamespaceUri; ////// The content can optionally be kept in the original location along with the /// newly mapping location by setting this option to true, false by default /// private readonly bool keepInContent; #endregion #region Constructors ////// Used for mapping a resource property to syndication content /// /// Source property path /// Syndication item to which theis mapped /// Syndication content kind for /// If true the property value is kept in the content section as before, /// when false the property value is only placed at the mapped location public EntityPropertyMappingAttribute(String sourcePath, SyndicationItemProperty targetSyndicationItem, SyndicationTextContentKind targetTextContentKind, bool keepInContent) { if (String.IsNullOrEmpty(sourcePath)) { throw new ArgumentException(Strings.EntityPropertyMapping_EpmAttribute("sourcePath")); } this.sourcePath = sourcePath; this.targetPath = SyndicationItemPropertyToPath(targetSyndicationItem); this.targetSyndicationItem = targetSyndicationItem; this.targetTextContentKind = targetTextContentKind; this.targetNamespacePrefix = EntityPropertyMappingAttribute.AtomNamespacePrefix; this.targetNamespaceUri = XmlConstants.AtomNamespace; this.keepInContent = keepInContent; } /// /// Used for mapping a resource property to arbitrary xml element/attribute /// /// Source property path /// Target element/attribute path /// Namespace prefix for theto which belongs /// Uri of the namespace to which belongs /// If true the property value is kept in the content section as before, /// when false the property value is only placed at the mapped location public EntityPropertyMappingAttribute(String sourcePath, String targetPath, String targetNamespacePrefix, String targetNamespaceUri, bool keepInContent) { if (String.IsNullOrEmpty(sourcePath)) { throw new ArgumentException(Strings.EntityPropertyMapping_EpmAttribute("sourcePath")); } this.sourcePath = sourcePath; if (String.IsNullOrEmpty(targetPath)) { throw new ArgumentException(Strings.EntityPropertyMapping_EpmAttribute("targetPath")); } if (targetPath[0] == '@') { throw new ArgumentException(Strings.EpmTargetTree_InvalidTargetPath(targetPath)); } this.targetPath = targetPath; this.targetSyndicationItem = SyndicationItemProperty.CustomProperty; this.targetTextContentKind = SyndicationTextContentKind.Plaintext; this.targetNamespacePrefix = targetNamespacePrefix; if (String.IsNullOrEmpty(targetNamespaceUri)) { throw new ArgumentException(Strings.EntityPropertyMapping_EpmAttribute("targetNamespaceUri")); } this.targetNamespaceUri = targetNamespaceUri; Uri uri; if (!Uri.TryCreate(targetNamespaceUri, UriKind.Absolute, out uri)) { throw new ArgumentException(Strings.EntityPropertyMapping_TargetNamespaceUriNotValid(targetNamespaceUri)); } this.keepInContent = keepInContent; } #region Properties /// /// Source property path /// public String SourcePath { get { return this.sourcePath; } } ////// Target Xml element/attribute /// public String TargetPath { get { return this.targetPath; } } ////// If mapping to syndication element, the name of syndication item /// public SyndicationItemProperty TargetSyndicationItem { get { return this.targetSyndicationItem; } } ////// If mapping to non-syndication element/attribute, the namespace prefix for the /// target element/attribute /// public String TargetNamespacePrefix { get { return this.targetNamespacePrefix; } } ////// If mapping to non-syndication element/attribute, the namespace for the /// target element/attribute /// public String TargetNamespaceUri { get { return this.targetNamespaceUri; } } ////// If mapping to syndication content, the content type of syndication item /// public SyndicationTextContentKind TargetTextContentKind { get { return this.targetTextContentKind; } } ////// The content can optionally be kept in the original location along with the /// newly mapping location by setting this option to true, false by default /// public bool KeepInContent { get { return this.keepInContent; } } #endregion ////// Maps the enumeration of allowed /// Value of thevalues to their string representations /// given in /// the contstructor /// String representing the xml element path in the syndication property internal static String SyndicationItemPropertyToPath(SyndicationItemProperty targetSyndicationItem) { switch (targetSyndicationItem) { case SyndicationItemProperty.AuthorEmail: return "author/email"; case SyndicationItemProperty.AuthorName: return "author/name"; case SyndicationItemProperty.AuthorUri: return "author/uri"; case SyndicationItemProperty.ContributorEmail: return "contributor/email"; case SyndicationItemProperty.ContributorName: return "contributor/name"; case SyndicationItemProperty.ContributorUri: return "contributor/uri"; case SyndicationItemProperty.Updated: return "updated"; case SyndicationItemProperty.Published: return "published"; case SyndicationItemProperty.Rights: return "rights"; case SyndicationItemProperty.Summary: return "summary"; case SyndicationItemProperty.Title: return "title"; default: throw new ArgumentException(Strings.EntityPropertyMapping_EpmAttribute("targetSyndicationItem")); } } #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
- TableCellCollection.cs
- ExpiredSecurityTokenException.cs
- UniqueID.cs
- Int32AnimationBase.cs
- DictionaryContent.cs
- CompilerTypeWithParams.cs
- ContentTextAutomationPeer.cs
- SessionStateSection.cs
- Fault.cs
- COAUTHINFO.cs
- TreePrinter.cs
- FreezableOperations.cs
- ScrollPatternIdentifiers.cs
- webproxy.cs
- IsolatedStorage.cs
- ParameterEditorUserControl.cs
- GeometryHitTestParameters.cs
- ButtonBaseDesigner.cs
- ViewBox.cs
- InputProcessorProfiles.cs
- SecurityTokenProvider.cs
- WindowsPen.cs
- DtdParser.cs
- SafeRegistryHandle.cs
- TagElement.cs
- BuildDependencySet.cs
- TextParagraphProperties.cs
- DefaultDialogButtons.cs
- DataListCommandEventArgs.cs
- TrackingQueryElement.cs
- UniqueEventHelper.cs
- XdrBuilder.cs
- Model3DCollection.cs
- Fault.cs
- sqlinternaltransaction.cs
- CopyOfAction.cs
- GrammarBuilderWildcard.cs
- SiteOfOriginPart.cs
- InteropAutomationProvider.cs
- Stylesheet.cs
- Comparer.cs
- MemoryRecordBuffer.cs
- ProxyOperationRuntime.cs
- BrowserCapabilitiesFactoryBase.cs
- KeyConstraint.cs
- SafeEventLogReadHandle.cs
- GenericWebPart.cs
- BitmapEffectrendercontext.cs
- Knowncolors.cs
- IDQuery.cs
- COM2ExtendedTypeConverter.cs
- TextTreeInsertElementUndoUnit.cs
- DocumentNUp.cs
- OrderByQueryOptionExpression.cs
- AutomationElementCollection.cs
- CodeTypeMember.cs
- Columns.cs
- TextDecorationCollection.cs
- LayoutUtils.cs
- IndentTextWriter.cs
- ScrollChrome.cs
- RoutedEventConverter.cs
- TextViewElement.cs
- UseManagedPresentationElement.cs
- StorageEndPropertyMapping.cs
- DocumentXPathNavigator.cs
- PageStatePersister.cs
- StorageEntityContainerMapping.cs
- ContentPlaceHolder.cs
- BuildManagerHost.cs
- WebPartDeleteVerb.cs
- CodeDOMUtility.cs
- ZipPackage.cs
- KeySplineConverter.cs
- DesignBinding.cs
- OleDbConnection.cs
- HatchBrush.cs
- XamlSerializerUtil.cs
- RequestNavigateEventArgs.cs
- SymmetricKeyWrap.cs
- ProfileGroupSettings.cs
- InfoCardSymmetricAlgorithm.cs
- HttpCacheVaryByContentEncodings.cs
- VectorCollectionValueSerializer.cs
- BmpBitmapDecoder.cs
- ResourceReferenceExpressionConverter.cs
- WindowsPrincipal.cs
- WindowsStartMenu.cs
- RIPEMD160Managed.cs
- BamlLocalizabilityResolver.cs
- XmlSchemaObjectCollection.cs
- OraclePermissionAttribute.cs
- Events.cs
- WebPartVerb.cs
- DefaultParameterValueAttribute.cs
- Function.cs
- KoreanCalendar.cs
- SamlAuthorityBinding.cs
- TheQuery.cs
- Baml2006KeyRecord.cs