Code:
/ FXUpdate3074 / FXUpdate3074 / 1.1 / DEVDIV / depot / DevDiv / releases / whidbey / QFE / ndp / fx / src / xsp / System / Web / UI / WebParts / PersonalizableAttribute.cs / 2 / PersonalizableAttribute.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.UI.WebControls.WebParts { using System; using System.Collections; using System.Collections.Specialized; using System.ComponentModel; using System.Security.Permissions; using System.Reflection; using System.Web; using System.Web.Util; ////// Used to mark a property as personalizable. /// [AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)] [AttributeUsage(AttributeTargets.Property)] public sealed class PersonalizableAttribute : Attribute { internal static readonly Type PersonalizableAttributeType = typeof(PersonalizableAttribute); private static readonly IDictionary PersonalizableTypeTable = Hashtable.Synchronized(new Hashtable()); ////// Indicates that the property is not personalizable. /// public static readonly PersonalizableAttribute NotPersonalizable = new PersonalizableAttribute(false); ////// Indicates that the property is personalizable. /// public static readonly PersonalizableAttribute Personalizable = new PersonalizableAttribute(true); ////// Indicates that the property is personalizable and can be changed per user. /// public static readonly PersonalizableAttribute UserPersonalizable = new PersonalizableAttribute(PersonalizationScope.User); ////// Indicates that the property is personalizable that can only be changed for all users. /// public static readonly PersonalizableAttribute SharedPersonalizable = new PersonalizableAttribute(PersonalizationScope.Shared); ////// The default personalizable attribute for a property or type. The default /// is to indicate that a property or type is not personalizable. /// public static readonly PersonalizableAttribute Default = NotPersonalizable; private bool _isPersonalizable; private bool _isSensitive; private PersonalizationScope _scope; ////// Initializes an instance of PersonalizableAttribute to indicate /// a personalizable property. /// By default personalized properties can be personalized per user. /// public PersonalizableAttribute() : this(true, PersonalizationScope.User, false) { } ////// Initializes an instance of PersonalizableAttribute with the /// specified value. /// public PersonalizableAttribute(bool isPersonalizable) : this(isPersonalizable, PersonalizationScope.User, false) { } ////// Initializes an instance of PersonalizableAttribute to indicate /// a personalizable property along with the specified personalization scope. /// public PersonalizableAttribute(PersonalizationScope scope) : this(true, scope, false) { } ////// Initializes an instance of PersonalizableAttribute to indicate /// a personalizable property along with the specified personalization scope and sensitivity. /// public PersonalizableAttribute(PersonalizationScope scope, bool isSensitive) : this(true, scope, isSensitive) { } ////// /// Initializes an instance of PersonalizableAttribute with the specified values. /// private PersonalizableAttribute(bool isPersonalizable, PersonalizationScope scope, bool isSensitive) { Debug.Assert((isPersonalizable == true || isSensitive == false), "Only Personalizable properties can be sensitive"); _isPersonalizable = isPersonalizable; _isSensitive = isSensitive; if (_isPersonalizable) { _scope = scope; } } ////// Whether the property or the type has been marked as personalizable. /// public bool IsPersonalizable { get { return _isPersonalizable; } } ////// Whether the property or the type has been marked as sensitive. /// public bool IsSensitive { get { return _isSensitive; } } ////// The personalization scope associated with the personalizable property. /// This property only has meaning when IsPersonalizable is true. /// public PersonalizationScope Scope { get { return _scope; } } ///public override bool Equals(object obj) { if (obj == this) { return true; } PersonalizableAttribute other = obj as PersonalizableAttribute; if (other != null) { return (other.IsPersonalizable == IsPersonalizable) && (other.Scope == Scope) && (other.IsSensitive == IsSensitive); } return false; } /// public override int GetHashCode() { return HashCodeCombiner.CombineHashCodes(_isPersonalizable.GetHashCode(), _scope.GetHashCode(), _isSensitive.GetHashCode()); } /// /// Returns the list of personalizable properties as a collection of /// PropertyInfos for the specified type. /// public static ICollection GetPersonalizableProperties(Type type) { Debug.Assert(type != null); PersonalizableTypeEntry typeEntry = (PersonalizableTypeEntry)PersonalizableTypeTable[type]; if (typeEntry == null) { typeEntry = new PersonalizableTypeEntry(type); PersonalizableTypeTable[type] = typeEntry; } return typeEntry.PropertyInfos; } ////// Returns the list of personalizable properties as a collection of /// PropertyInfos for the specified type. /// internal static IDictionary GetPersonalizablePropertyEntries(Type type) { Debug.Assert(type != null); PersonalizableTypeEntry typeEntry = (PersonalizableTypeEntry)PersonalizableTypeTable[type]; if (typeEntry == null) { typeEntry = new PersonalizableTypeEntry(type); PersonalizableTypeTable[type] = typeEntry; } return typeEntry.PropertyEntries; } ////// internal static IDictionary GetPersonalizablePropertyValues(Control control, PersonalizationScope scope, bool excludeSensitive) { IDictionary propertyBag = null; IDictionary propertyEntries = GetPersonalizablePropertyEntries(control.GetType()); if (propertyEntries.Count != 0) { foreach (DictionaryEntry entry in propertyEntries) { string name = (string)entry.Key; PersonalizablePropertyEntry propEntry = (PersonalizablePropertyEntry)entry.Value; if (excludeSensitive && propEntry.IsSensitive) { continue; } if ((scope == PersonalizationScope.User) && (propEntry.Scope == PersonalizationScope.Shared)) { continue; } if (propertyBag == null) { propertyBag = new HybridDictionary(propertyEntries.Count, /* caseInsensitive */ false); } object value = FastPropertyAccessor.GetProperty(control, name); propertyBag[name] = new Pair(propEntry.PropertyInfo, value); } } if (propertyBag == null) { propertyBag = new HybridDictionary(/* caseInsensitive */ false); } return propertyBag; } ///public override bool IsDefaultAttribute() { return this.Equals(Default); } /// public override bool Match(object obj) { if (obj == this) { return true; } PersonalizableAttribute other = obj as PersonalizableAttribute; if (other != null) { return (other.IsPersonalizable == IsPersonalizable); } return false; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved. //------------------------------------------------------------------------------ // // Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.UI.WebControls.WebParts { using System; using System.Collections; using System.Collections.Specialized; using System.ComponentModel; using System.Security.Permissions; using System.Reflection; using System.Web; using System.Web.Util; ////// Used to mark a property as personalizable. /// [AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)] [AttributeUsage(AttributeTargets.Property)] public sealed class PersonalizableAttribute : Attribute { internal static readonly Type PersonalizableAttributeType = typeof(PersonalizableAttribute); private static readonly IDictionary PersonalizableTypeTable = Hashtable.Synchronized(new Hashtable()); ////// Indicates that the property is not personalizable. /// public static readonly PersonalizableAttribute NotPersonalizable = new PersonalizableAttribute(false); ////// Indicates that the property is personalizable. /// public static readonly PersonalizableAttribute Personalizable = new PersonalizableAttribute(true); ////// Indicates that the property is personalizable and can be changed per user. /// public static readonly PersonalizableAttribute UserPersonalizable = new PersonalizableAttribute(PersonalizationScope.User); ////// Indicates that the property is personalizable that can only be changed for all users. /// public static readonly PersonalizableAttribute SharedPersonalizable = new PersonalizableAttribute(PersonalizationScope.Shared); ////// The default personalizable attribute for a property or type. The default /// is to indicate that a property or type is not personalizable. /// public static readonly PersonalizableAttribute Default = NotPersonalizable; private bool _isPersonalizable; private bool _isSensitive; private PersonalizationScope _scope; ////// Initializes an instance of PersonalizableAttribute to indicate /// a personalizable property. /// By default personalized properties can be personalized per user. /// public PersonalizableAttribute() : this(true, PersonalizationScope.User, false) { } ////// Initializes an instance of PersonalizableAttribute with the /// specified value. /// public PersonalizableAttribute(bool isPersonalizable) : this(isPersonalizable, PersonalizationScope.User, false) { } ////// Initializes an instance of PersonalizableAttribute to indicate /// a personalizable property along with the specified personalization scope. /// public PersonalizableAttribute(PersonalizationScope scope) : this(true, scope, false) { } ////// Initializes an instance of PersonalizableAttribute to indicate /// a personalizable property along with the specified personalization scope and sensitivity. /// public PersonalizableAttribute(PersonalizationScope scope, bool isSensitive) : this(true, scope, isSensitive) { } ////// /// Initializes an instance of PersonalizableAttribute with the specified values. /// private PersonalizableAttribute(bool isPersonalizable, PersonalizationScope scope, bool isSensitive) { Debug.Assert((isPersonalizable == true || isSensitive == false), "Only Personalizable properties can be sensitive"); _isPersonalizable = isPersonalizable; _isSensitive = isSensitive; if (_isPersonalizable) { _scope = scope; } } ////// Whether the property or the type has been marked as personalizable. /// public bool IsPersonalizable { get { return _isPersonalizable; } } ////// Whether the property or the type has been marked as sensitive. /// public bool IsSensitive { get { return _isSensitive; } } ////// The personalization scope associated with the personalizable property. /// This property only has meaning when IsPersonalizable is true. /// public PersonalizationScope Scope { get { return _scope; } } ///public override bool Equals(object obj) { if (obj == this) { return true; } PersonalizableAttribute other = obj as PersonalizableAttribute; if (other != null) { return (other.IsPersonalizable == IsPersonalizable) && (other.Scope == Scope) && (other.IsSensitive == IsSensitive); } return false; } /// public override int GetHashCode() { return HashCodeCombiner.CombineHashCodes(_isPersonalizable.GetHashCode(), _scope.GetHashCode(), _isSensitive.GetHashCode()); } /// /// Returns the list of personalizable properties as a collection of /// PropertyInfos for the specified type. /// public static ICollection GetPersonalizableProperties(Type type) { Debug.Assert(type != null); PersonalizableTypeEntry typeEntry = (PersonalizableTypeEntry)PersonalizableTypeTable[type]; if (typeEntry == null) { typeEntry = new PersonalizableTypeEntry(type); PersonalizableTypeTable[type] = typeEntry; } return typeEntry.PropertyInfos; } ////// Returns the list of personalizable properties as a collection of /// PropertyInfos for the specified type. /// internal static IDictionary GetPersonalizablePropertyEntries(Type type) { Debug.Assert(type != null); PersonalizableTypeEntry typeEntry = (PersonalizableTypeEntry)PersonalizableTypeTable[type]; if (typeEntry == null) { typeEntry = new PersonalizableTypeEntry(type); PersonalizableTypeTable[type] = typeEntry; } return typeEntry.PropertyEntries; } ////// internal static IDictionary GetPersonalizablePropertyValues(Control control, PersonalizationScope scope, bool excludeSensitive) { IDictionary propertyBag = null; IDictionary propertyEntries = GetPersonalizablePropertyEntries(control.GetType()); if (propertyEntries.Count != 0) { foreach (DictionaryEntry entry in propertyEntries) { string name = (string)entry.Key; PersonalizablePropertyEntry propEntry = (PersonalizablePropertyEntry)entry.Value; if (excludeSensitive && propEntry.IsSensitive) { continue; } if ((scope == PersonalizationScope.User) && (propEntry.Scope == PersonalizationScope.Shared)) { continue; } if (propertyBag == null) { propertyBag = new HybridDictionary(propertyEntries.Count, /* caseInsensitive */ false); } object value = FastPropertyAccessor.GetProperty(control, name); propertyBag[name] = new Pair(propEntry.PropertyInfo, value); } } if (propertyBag == null) { propertyBag = new HybridDictionary(/* caseInsensitive */ false); } return propertyBag; } ///public override bool IsDefaultAttribute() { return this.Equals(Default); } /// public override bool Match(object obj) { if (obj == this) { return true; } PersonalizableAttribute other = obj as PersonalizableAttribute; if (other != null) { return (other.IsPersonalizable == IsPersonalizable); } return false; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. // Copyright (c) Microsoft Corporation. All rights reserved.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- DoubleCollectionValueSerializer.cs
- OleDbCommand.cs
- Converter.cs
- SafeThreadHandle.cs
- __Filters.cs
- Style.cs
- WebPartVerbsEventArgs.cs
- TreeView.cs
- MSAAWinEventWrap.cs
- SelfIssuedAuthRSAPKCS1SignatureFormatter.cs
- CapabilitiesRule.cs
- PropertyConverter.cs
- TeredoHelper.cs
- UICuesEvent.cs
- SQLDateTimeStorage.cs
- WebPartConnectionsCloseVerb.cs
- SqlPersistenceProviderFactory.cs
- DelegatingConfigHost.cs
- PropertyState.cs
- StrongNameUtility.cs
- AttributeUsageAttribute.cs
- XmlTextEncoder.cs
- ContentDisposition.cs
- BufferedGraphicsManager.cs
- PathParser.cs
- ClientProxyGenerator.cs
- IPipelineRuntime.cs
- ComponentResourceKey.cs
- DrawingVisualDrawingContext.cs
- RoutingConfiguration.cs
- TextTreeInsertUndoUnit.cs
- CodeDirectionExpression.cs
- HttpGetClientProtocol.cs
- RecommendedAsConfigurableAttribute.cs
- CellRelation.cs
- CharUnicodeInfo.cs
- WebUtility.cs
- MimeTypeMapper.cs
- TableRowCollection.cs
- XmlIlVisitor.cs
- EventLogPermissionAttribute.cs
- RtfToXamlReader.cs
- X509SecurityToken.cs
- TouchFrameEventArgs.cs
- RootAction.cs
- DataColumn.cs
- TypeConstant.cs
- RootBuilder.cs
- SqlParameterCollection.cs
- ChangeConflicts.cs
- Style.cs
- MenuScrollingVisibilityConverter.cs
- CombinedHttpChannel.cs
- QuotedPairReader.cs
- Underline.cs
- securitycriticaldataClass.cs
- TabControlAutomationPeer.cs
- ViewStateModeByIdAttribute.cs
- ConfigurationLoaderException.cs
- CornerRadius.cs
- TransactionTraceIdentifier.cs
- SynchronousChannelMergeEnumerator.cs
- DetailsViewUpdateEventArgs.cs
- _DisconnectOverlappedAsyncResult.cs
- AttributedMetaModel.cs
- JsonWriterDelegator.cs
- SiteMapDataSource.cs
- DataTablePropertyDescriptor.cs
- ModelUtilities.cs
- DataColumnMapping.cs
- WebPartCollection.cs
- AssociationType.cs
- OdbcDataAdapter.cs
- _DigestClient.cs
- ResourceReader.cs
- XmlBinaryReader.cs
- RecognizedWordUnit.cs
- TableLayoutPanelResizeGlyph.cs
- SqlTypesSchemaImporter.cs
- Executor.cs
- SemaphoreSecurity.cs
- SHA512.cs
- GenerateTemporaryTargetAssembly.cs
- PixelShader.cs
- SqlBuilder.cs
- InternalUserCancelledException.cs
- TraceContext.cs
- NativeMethods.cs
- SupportingTokenSpecification.cs
- SharedPerformanceCounter.cs
- GridViewRowEventArgs.cs
- ScaleTransform.cs
- SourceFileInfo.cs
- TraceSection.cs
- RequestReplyCorrelator.cs
- GenericArgumentsUpdater.cs
- BitmapCodecInfo.cs
- EntitySqlException.cs
- TextServicesCompartment.cs
- FileSecurity.cs