Code:
/ Dotnetfx_Win7_3.5.1 / Dotnetfx_Win7_3.5.1 / 3.5.1 / DEVDIV / depot / DevDiv / releases / whidbey / NetFXspW7 / ndp / fx / src / xsp / System / Web / UI / PropertyConverter.cs / 1 / PropertyConverter.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.UI { using System; using System.ComponentModel; using System.Globalization; using System.Reflection; using System.Runtime.Serialization.Formatters; using System.Security.Permissions; ////// /// [AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)] public static class PropertyConverter { private static readonly Type[] s_parseMethodTypes = new Type[] { typeof(string) }; private static readonly Type[] s_parseMethodTypesWithSOP = new Type[] { typeof(string), typeof(IServiceProvider) }; /* * Contains helpers to convert properties from strings to their types and vice versa. */ /* * Converts a persisted enumeration value into its numeric value. * Hyphen characters in the persisted format are converted to underscores. */ ////// public static object EnumFromString(Type enumType, string value) { try { return Enum.Parse(enumType, value, true); } catch { return null; } } /* * Converts a numeric enumerated value into its persisted form, which is the * code name with underscores replaced by hyphens. */ ////// public static string EnumToString(Type enumType, object enumValue) { string value = Enum.Format(enumType, enumValue, "G"); // return value.Replace('_','-'); } /* * Converts the persisted string into an object using the object's * FromString method. */ ////// public static object ObjectFromString(Type objType, MemberInfo propertyInfo, string value) { if (value == null) return null; // Blank valued bools don't map with FromString. Return null to allow // caller to interpret. if (objType.Equals(typeof(bool)) && value.Length == 0) { return null; } bool useParseMethod = true; object ret = null; try { if (objType.IsEnum) { useParseMethod = false; ret = EnumFromString(objType, value); } else if (objType.Equals(typeof(string))) { useParseMethod = false; ret = value; } else { PropertyDescriptor pd = null; if (propertyInfo != null) { pd = TypeDescriptor.GetProperties(propertyInfo.ReflectedType)[propertyInfo.Name]; } if (pd != null) { TypeConverter converter = pd.Converter; if (converter != null && converter.CanConvertFrom(typeof(string))) { useParseMethod = false; ret = converter.ConvertFromInvariantString(value); } } } } catch { } if (useParseMethod) { // resort to Parse static method on the type // First try Parse(string, IServiceProvider); MethodInfo methodInfo = objType.GetMethod("Parse", s_parseMethodTypesWithSOP); if (methodInfo != null) { object[] parameters = new object[2]; parameters[0] = value; parameters[1] = CultureInfo.InvariantCulture; try { ret = Util.InvokeMethod(methodInfo, null, parameters); } catch { } } else { // Try the simpler: Parse(string); methodInfo = objType.GetMethod("Parse", s_parseMethodTypes); if (methodInfo != null) { object[] parameters = new object[1]; parameters[0] = value; try { ret = Util.InvokeMethod(methodInfo, null, parameters); } catch { } } } } if (ret == null) { // Unhandled... throw an exception, so user sees an error at parse time // Note that we don't propagate inner exceptions here, since they usually // do not give any information about where the bad value existed on // the object being initialized, whereas, our exception gives that // information. throw new HttpException(SR.GetString(SR.Type_not_creatable_from_string, objType.FullName, value, propertyInfo.Name)); } return ret; } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.UI { using System; using System.ComponentModel; using System.Globalization; using System.Reflection; using System.Runtime.Serialization.Formatters; using System.Security.Permissions; ////// /// [AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)] public static class PropertyConverter { private static readonly Type[] s_parseMethodTypes = new Type[] { typeof(string) }; private static readonly Type[] s_parseMethodTypesWithSOP = new Type[] { typeof(string), typeof(IServiceProvider) }; /* * Contains helpers to convert properties from strings to their types and vice versa. */ /* * Converts a persisted enumeration value into its numeric value. * Hyphen characters in the persisted format are converted to underscores. */ ////// public static object EnumFromString(Type enumType, string value) { try { return Enum.Parse(enumType, value, true); } catch { return null; } } /* * Converts a numeric enumerated value into its persisted form, which is the * code name with underscores replaced by hyphens. */ ////// public static string EnumToString(Type enumType, object enumValue) { string value = Enum.Format(enumType, enumValue, "G"); // return value.Replace('_','-'); } /* * Converts the persisted string into an object using the object's * FromString method. */ ////// public static object ObjectFromString(Type objType, MemberInfo propertyInfo, string value) { if (value == null) return null; // Blank valued bools don't map with FromString. Return null to allow // caller to interpret. if (objType.Equals(typeof(bool)) && value.Length == 0) { return null; } bool useParseMethod = true; object ret = null; try { if (objType.IsEnum) { useParseMethod = false; ret = EnumFromString(objType, value); } else if (objType.Equals(typeof(string))) { useParseMethod = false; ret = value; } else { PropertyDescriptor pd = null; if (propertyInfo != null) { pd = TypeDescriptor.GetProperties(propertyInfo.ReflectedType)[propertyInfo.Name]; } if (pd != null) { TypeConverter converter = pd.Converter; if (converter != null && converter.CanConvertFrom(typeof(string))) { useParseMethod = false; ret = converter.ConvertFromInvariantString(value); } } } } catch { } if (useParseMethod) { // resort to Parse static method on the type // First try Parse(string, IServiceProvider); MethodInfo methodInfo = objType.GetMethod("Parse", s_parseMethodTypesWithSOP); if (methodInfo != null) { object[] parameters = new object[2]; parameters[0] = value; parameters[1] = CultureInfo.InvariantCulture; try { ret = Util.InvokeMethod(methodInfo, null, parameters); } catch { } } else { // Try the simpler: Parse(string); methodInfo = objType.GetMethod("Parse", s_parseMethodTypes); if (methodInfo != null) { object[] parameters = new object[1]; parameters[0] = value; try { ret = Util.InvokeMethod(methodInfo, null, parameters); } catch { } } } } if (ret == null) { // Unhandled... throw an exception, so user sees an error at parse time // Note that we don't propagate inner exceptions here, since they usually // do not give any information about where the bad value existed on // the object being initialized, whereas, our exception gives that // information. throw new HttpException(SR.GetString(SR.Type_not_creatable_from_string, objType.FullName, value, propertyInfo.Name)); } return ret; } } } // 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
- OleDbStruct.cs
- HtmlTitle.cs
- Vector3DAnimationBase.cs
- ClientBuildManagerCallback.cs
- CheckBoxFlatAdapter.cs
- OrthographicCamera.cs
- EncoderFallback.cs
- ServiceProviders.cs
- MetabaseSettings.cs
- AttributeSetAction.cs
- ObjectListComponentEditor.cs
- Pair.cs
- LocalizeDesigner.cs
- WebPartZone.cs
- PersonalizationProviderHelper.cs
- CodeStatement.cs
- HashSetEqualityComparer.cs
- UrlUtility.cs
- FontWeightConverter.cs
- ZipIOCentralDirectoryDigitalSignature.cs
- SmiSettersStream.cs
- DefinitionBase.cs
- ConfigXmlCDataSection.cs
- KoreanLunisolarCalendar.cs
- TextBlock.cs
- GlyphRunDrawing.cs
- ArcSegment.cs
- RelationshipFixer.cs
- FormViewUpdatedEventArgs.cs
- Types.cs
- XDRSchema.cs
- ConvertEvent.cs
- QilGeneratorEnv.cs
- AncillaryOps.cs
- AssemblyCollection.cs
- MetafileHeaderEmf.cs
- ConstrainedDataObject.cs
- DateTimeUtil.cs
- Compiler.cs
- DeclaredTypeValidator.cs
- CodeSnippetStatement.cs
- ReadOnlyState.cs
- ClientScriptManagerWrapper.cs
- ManipulationBoundaryFeedbackEventArgs.cs
- ProcessInfo.cs
- WaitHandleCannotBeOpenedException.cs
- LabelAutomationPeer.cs
- HttpContextBase.cs
- GregorianCalendar.cs
- RewritingProcessor.cs
- PhysicalAddress.cs
- Imaging.cs
- OutputBuffer.cs
- ActiveXSite.cs
- ActivityWithResultValueSerializer.cs
- GAC.cs
- DiscoveryMessageSequenceCD1.cs
- SQLInt32Storage.cs
- LogicalExpr.cs
- Message.cs
- ResourceIDHelper.cs
- SyntaxCheck.cs
- RuntimeWrappedException.cs
- XmlDocumentFieldSchema.cs
- ErasingStroke.cs
- SafeRegistryHandle.cs
- TextLineBreak.cs
- Stylesheet.cs
- XPathScanner.cs
- IPGlobalProperties.cs
- TabOrder.cs
- MissingMemberException.cs
- SafeFileHandle.cs
- WebPartMinimizeVerb.cs
- DomainConstraint.cs
- TextServicesLoader.cs
- Policy.cs
- DesignTimeVisibleAttribute.cs
- StyleXamlTreeBuilder.cs
- UnhandledExceptionEventArgs.cs
- FontEmbeddingManager.cs
- AnnouncementEventArgs.cs
- BooleanFacetDescriptionElement.cs
- OperationInfo.cs
- MediaContext.cs
- DataGridViewComboBoxColumn.cs
- WebBrowserContainer.cs
- SizeF.cs
- PathData.cs
- CompoundFileStreamReference.cs
- ModelItemExtensions.cs
- CompiledQueryCacheKey.cs
- ProtectedConfigurationSection.cs
- TreeBuilderXamlTranslator.cs
- HyperLinkField.cs
- WebEventTraceProvider.cs
- UserPersonalizationStateInfo.cs
- BevelBitmapEffect.cs
- ReflectTypeDescriptionProvider.cs
- NullRuntimeConfig.cs