Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / xsp / System / Web / UI / PropertyConverter.cs / 1305376 / 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; ////// /// 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; ////// /// 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
- WCFModelStrings.Designer.cs
- Overlapped.cs
- OleDbCommand.cs
- unsafeIndexingFilterStream.cs
- GenericAuthenticationEventArgs.cs
- _SpnDictionary.cs
- AuthenticationModuleElement.cs
- SystemWebCachingSectionGroup.cs
- EntityDataSourceWrapper.cs
- CompilationAssemblyInstallComponent.cs
- AdRotatorDesigner.cs
- ContextProperty.cs
- ReliabilityContractAttribute.cs
- CheckedPointers.cs
- securitycriticaldata.cs
- ElapsedEventArgs.cs
- XPathDocument.cs
- ConfigsHelper.cs
- XmlHierarchicalDataSourceView.cs
- EventWaitHandleSecurity.cs
- SafeHandles.cs
- TileBrush.cs
- ScaleTransform.cs
- NumericExpr.cs
- DbConnectionOptions.cs
- EventListener.cs
- FilterRepeater.cs
- IsolatedStorage.cs
- BrowserDefinition.cs
- AppendHelper.cs
- LicFileLicenseProvider.cs
- BasicHttpSecurity.cs
- xml.cs
- CaseInsensitiveComparer.cs
- EncryptedKey.cs
- BooleanExpr.cs
- TextEffect.cs
- SemanticResolver.cs
- SqlMethodCallConverter.cs
- ControlValuePropertyAttribute.cs
- SQLInt32.cs
- TextContainerChangeEventArgs.cs
- TextProviderWrapper.cs
- ToolBar.cs
- SessionEndingEventArgs.cs
- CodeTypeDeclarationCollection.cs
- HtmlTable.cs
- GPStream.cs
- HashMembershipCondition.cs
- BaseServiceProvider.cs
- SqlDataSourceConnectionPanel.cs
- Repeater.cs
- FixedSOMPageConstructor.cs
- ToolboxItemLoader.cs
- FindCriteriaApril2005.cs
- CompiledRegexRunner.cs
- ClientSettingsProvider.cs
- RemoteWebConfigurationHostStream.cs
- DetailsViewActionList.cs
- CryptoApi.cs
- ObjectDataSourceStatusEventArgs.cs
- GridViewDeletedEventArgs.cs
- ClientRolePrincipal.cs
- DSASignatureFormatter.cs
- WizardStepBase.cs
- RecommendedAsConfigurableAttribute.cs
- OleDbConnectionFactory.cs
- XmlValidatingReaderImpl.cs
- XmlSchema.cs
- Process.cs
- DynamicDataRouteHandler.cs
- XsltInput.cs
- ResourceProviderFactory.cs
- FieldBuilder.cs
- Error.cs
- Common.cs
- PageEventArgs.cs
- XmlDownloadManager.cs
- InfoCardTrace.cs
- ModelVisual3D.cs
- TextEncodedRawTextWriter.cs
- AdornerDecorator.cs
- TabPage.cs
- SoapExtensionTypeElementCollection.cs
- SafeNativeMemoryHandle.cs
- SafeNativeMethods.cs
- DbModificationClause.cs
- AutoCompleteStringCollection.cs
- ElementUtil.cs
- DESCryptoServiceProvider.cs
- _BasicClient.cs
- RoleManagerSection.cs
- EntityContainerRelationshipSet.cs
- TimeZoneNotFoundException.cs
- ValidationPropertyAttribute.cs
- FieldNameLookup.cs
- Debug.cs
- CardSpaceSelector.cs
- BoolExpressionVisitors.cs
- ReadOnlyHierarchicalDataSource.cs