Return true> if the specified property name identifies a writeable property on the specified object;
#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>
/// Return <b>true</b> if the specified property name identifies a
/// writeable property on the specified object;
/// otherwise, return <b>false</b>.
/// </summary>
/// <param name="obj"></param>
/// <param name="propertyName"></param>
/// <param name="ignoreCase">ignore case sensitivity</param>
/// <returns></returns>
/// <exception cref="ArgumentNullException">If obj parameter is null</exception>
/// <exception cref="ArgumentException">if the propertyName supplied
/// cannot be found in the object</exception>
/// ----------------------------------------------------------------
public static bool IsWritable(Object obj, string propertyName, bool ignoreCase)
{
if (obj == null) throw new ArgumentNullException("obj");
BindingFlags bindingAttrs = BindingFlags.Instance | BindingFlags.NonPublic | BindingFlags.Public;
bindingAttrs = (ignoreCase) ? bindingAttrs | BindingFlags.IgnoreCase : bindingAttrs;
PropertyInfo pi = obj.GetType().GetProperty(propertyName,bindingAttrs);
if (pi == null)
throw new ArgumentException(string.Format("The '{0}' object does not have a '{1}' property", obj.GetType().FullName, propertyName));
return pi.CanWrite;
}
}
}
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. | Set the value of a property that has been declared as an Enum type using reflection | | |
18. | Determine if a property's Type is an enum | | |
19. | Return true> if the specified property name identifies a readable 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 | | |