You've already forked linux-packaging-mono
							
							
		
			
				
	
	
		
			152 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			152 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
| //------------------------------------------------------------------------------
 | |
| // <copyright file="PropertyConverter.cs" company="Microsoft">
 | |
| //     Copyright (c) Microsoft Corporation.  All rights reserved.
 | |
| // </copyright>                                                                
 | |
| //------------------------------------------------------------------------------
 | |
| 
 | |
| namespace System.Web.UI {
 | |
|     using System;
 | |
|     using System.ComponentModel;
 | |
|     using System.Globalization;
 | |
|     using System.Reflection;
 | |
|     using System.Runtime.Serialization.Formatters;
 | |
| 
 | |
|     /// <internalonly/>
 | |
|     /// <devdoc>
 | |
|     /// </devdoc>
 | |
|     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.
 | |
|          */
 | |
| 
 | |
|         /// <devdoc>
 | |
|         /// </devdoc>
 | |
|         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.
 | |
|          */
 | |
| 
 | |
|         /// <devdoc>
 | |
|         /// </devdoc>
 | |
|         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.
 | |
|          */
 | |
| 
 | |
|         /// <devdoc>
 | |
|         /// </devdoc>
 | |
|         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;
 | |
|         }
 | |
|     }
 | |
| }
 | |
| 
 |