Set the value of a property that has been declared as an Enum type using reflection : PropertyInfo « Reflection « C# / C Sharp






Set the value of a property that has been declared as an Enum type using reflection

    

#region License and Copyright
/*
 * Dotnet Commons Reflection 
 *
 * Copyright  2005. EDWARD LIM
 *
 * This library is free software; you can redistribute it and/or modify it 
 * under the terms of the GNU Lesser General Public License as published by 
 * the Free Software Foundation; either version 2.1 of the License, or 
 * (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful, but 
 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY 
 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License 
 * for more details. 
 *
 * You should have received a copy of the GNU Lesser General Public License 
 * along with this library; if not, write to the 
 * Free Software Foundation, Inc., 
 * 59 Temple Place, 
 * Suite 330, 
 * Boston, 
 * MA 02111-1307 
 * USA 
 * 
 */
#endregion

using System;
using System.Collections;
using System.Collections.Specialized;
using System.Reflection;

//using Dotnet.Commons.Lang;


namespace Dotnet.Commons.Reflection
{
  ///  
  /// <summary>
  /// This class contains utility methods that perform operations on object properties. 
  /// </summary>
  /// 
  /// <remarks> 
  ///  Copyright 2006 by Edward Lim.
  /// All rights reserved.
  /// </remarks>
  /// 
  public sealed class PropertyUtils
  {
    private PropertyUtils()  {}



    ///  --------------------------------------------------------------------
    /// <summary>
    /// Set the value of a property that has been declared as an Enum type using reflection
    /// </summary>
    /// <param name="targetObj">target object in which property is to be set</param>
    /// <param name="propertyName">name of the property</param>
    /// <param name="propertyValue">value of the object to be set</param>
    /// <param name="ignoreCase">ignore case sensitivity</param>
    /// <returns>null if target object or is null, else target object with property set if property if found</returns>
    /// <exception cref="ArgumentException">if the propertyName is null or empty</exception>    
    ///  --------------------------------------------------------------------
    public static object SetEnumTypeProperty(object targetObj, string propertyName, object propertyValue, bool ignoreCase)
    {
      if (targetObj == null)      
        return null;

      if ((propertyName == null) || (propertyName.Length < 1))
      {
        throw new ArgumentException("propertyName cannot be null or empty.");
      }

      if (propertyValue == null)
        return targetObj;
      
      PropertyInfo propInfo = targetObj.GetType().GetProperty(propertyName);

      if (propInfo == null)
        return targetObj;


      if (!propInfo.PropertyType.IsEnum)
        throw new ArgumentException("property " + propertyName + " is not an Enum type");

      if (propertyValue is String)
        propertyValue = Enum.Parse(propInfo.PropertyType, (string) propertyValue, ignoreCase);
      
      propInfo.SetValue(targetObj, Enum.ToObject(propInfo.PropertyType, Convert.ToUInt64(propertyValue)), null);

      return targetObj;
    }
    }
}

   
    
    
    
  








Related examples in the same category

1.Obtaining member information from a class.
2.Print Property Info
3.Type.GetProperties
4.IsClass, Namespace, FullName, IsAbstract, IsPublic, IsInterface, IsEnum
5.Determines whether the member is an indexed property.
6.Determines whether the property is an indexed property.
7.Get Fields And Properties
8.Get Properties
9.Gets a property's value
10.Gets a property's type
11.Gets a property's parent object
12.Get Property from Property path
13.Copies a field value
14.Get the names of all the properties of an object
15.Determine if a property exists in an object
16.Get the type of the Property.
17.Determine if a property's Type is an enum
18.Return true> if the specified property name identifies a readable property on the specified object;
19.Return true> if the specified property name identifies a writeable property on the specified object;
20.Integration Property To String
21.Gets the value of a static property on a specific type.
22.Gets the name of the property held within the expression
23.Gets the specified attribute from the PropertyDescriptor.
24.Get a property value given its name
25.Gets the attributes for this property.
26.Gets a value indicating whether the property can be read.
27.Gets a value indicating whether the property can be written to.
28.Returns an array whose elements reflect the public, non-public get, set, and other accessors
29.Returns the public or non-public get accessor for this property.
30.Get an array of all the index parameters for the property.
31.Get the set accessor for this property.
32.Returns the value of the property with optional index values for indexed properties.
33.Gets a MemberTypes value indicating that this member is a property.
34.Gets the type of this property.
35.Sets the property value for the given object to the given value.
36.Searches for the specified property, using the specified binding constraints.
37.Searches for the public property with the specified name and return type.
38.Get Non-Pubic Property
39.Set Non-Pubic Property
40.Gets a string with all of the properties that are not null.
41.Get Writable Properties
42.Get Property Name