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
- WebPartConnectionsCloseVerb.cs
- SafeProcessHandle.cs
- PrivilegedConfigurationManager.cs
- ListControlDataBindingHandler.cs
- ConfigurationStrings.cs
- WindowsPen.cs
- AutomationPropertyInfo.cs
- FontCacheUtil.cs
- ReflectEventDescriptor.cs
- MsmqTransportElement.cs
- DSGeneratorProblem.cs
- BatchWriter.cs
- EntityContainerEntitySetDefiningQuery.cs
- CodeStatementCollection.cs
- DayRenderEvent.cs
- AutomationTextAttribute.cs
- InstanceLockedException.cs
- SimpleWebHandlerParser.cs
- ColumnHeaderConverter.cs
- XmlnsDictionary.cs
- PriorityRange.cs
- WpfKnownTypeInvoker.cs
- _NetRes.cs
- RegionData.cs
- KernelTypeValidation.cs
- TypeBuilder.cs
- ObjectDataSourceWizardForm.cs
- MarginCollapsingState.cs
- Animatable.cs
- EntityViewGenerator.cs
- ToolTipAutomationPeer.cs
- WebZone.cs
- LayoutEvent.cs
- FunctionGenerator.cs
- XmlAttribute.cs
- StreamGeometry.cs
- InfoCardSchemas.cs
- UInt16Storage.cs
- DoubleMinMaxAggregationOperator.cs
- TreeChangeInfo.cs
- SuppressMessageAttribute.cs
- AmbientProperties.cs
- TreeNodeBinding.cs
- VisualStyleTypesAndProperties.cs
- Int32CollectionConverter.cs
- KeyBinding.cs
- UIElementParaClient.cs
- UnsafeNativeMethods.cs
- PaperSize.cs
- SoapAttributeOverrides.cs
- UserControlCodeDomTreeGenerator.cs
- ColorTranslator.cs
- TextEndOfParagraph.cs
- PackWebRequest.cs
- SpecialFolderEnumConverter.cs
- EventLogReader.cs
- Compilation.cs
- XmlSignificantWhitespace.cs
- Executor.cs
- ConfigurationFileMap.cs
- DeleteCardRequest.cs
- MobileTextWriter.cs
- ConcurrentQueue.cs
- SiteIdentityPermission.cs
- GorillaCodec.cs
- DataFieldConverter.cs
- XmlCDATASection.cs
- SerializerDescriptor.cs
- SiteMap.cs
- Semaphore.cs
- XamlToRtfWriter.cs
- UMPAttributes.cs
- XmlUrlEditor.cs
- DbgUtil.cs
- ResourceDefaultValueAttribute.cs
- ObjectDataSourceView.cs
- InstanceKeyCollisionException.cs
- MultipartContentParser.cs
- DataKey.cs
- PropertyInfoSet.cs
- CrossAppDomainChannel.cs
- GeneralTransform.cs
- WinFormsComponentEditor.cs
- HtmlInputCheckBox.cs
- CollectionsUtil.cs
- AuthenticationModuleElement.cs
- FileUpload.cs
- InputProviderSite.cs
- SingleAnimationUsingKeyFrames.cs
- RadioButtonList.cs
- OptimizedTemplateContent.cs
- ToolboxItemAttribute.cs
- ComponentResourceKey.cs
- EncryptionUtility.cs
- nulltextcontainer.cs
- AmbientValueAttribute.cs
- HighlightComponent.cs
- PointValueSerializer.cs
- unsafenativemethodsother.cs
- CryptoKeySecurity.cs