Gets a property's parent object
/*
Copyright (c) 2010 <a href="http://www.gutgames.com">James Craig</a>
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.*/
#region Usings
using System;
using System.IO;
using System.Reflection;
using System.Text;
using System.Linq.Expressions;
using System.Collections;
#endregion
namespace Utilities
{
/// <summary>
/// Utility class that handles various
/// functions dealing with reflection.
/// </summary>
public static class Reflection
{
/// <summary>
/// Gets a property's parent object
/// </summary>
/// <param name="SourceObject">Source object</param>
/// <param name="PropertyPath">Path of the property (ex: Prop1.Prop2.Prop3 would be
/// the Prop1 of the source object, which then has a Prop2 on it, which in turn
/// has a Prop3 on it.)</param>
/// <param name="PropertyInfo">Property info that is sent back</param>
/// <returns>The property's parent object</returns>
public static object GetPropertyParent(object SourceObject, string PropertyPath, out PropertyInfo PropertyInfo)
{
try
{
if (SourceObject == null)
{
PropertyInfo = null;
return null;
}
string[] Splitter = { "." };
string[] SourceProperties = PropertyPath.Split(Splitter, StringSplitOptions.None);
object TempSourceProperty = SourceObject;
Type PropertyType = SourceObject.GetType();
PropertyInfo = PropertyType.GetProperty(SourceProperties[0]);
PropertyType = PropertyInfo.PropertyType;
for (int x = 1; x < SourceProperties.Length; ++x)
{
if (TempSourceProperty != null)
{
TempSourceProperty = PropertyInfo.GetValue(TempSourceProperty, null);
}
PropertyInfo = PropertyType.GetProperty(SourceProperties[x]);
PropertyType = PropertyInfo.PropertyType;
}
return TempSourceProperty;
}
catch { throw; }
}
}
}
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. | Get Property from Property path | | |
12. | Copies a field value | | |
13. | Get the names of all the properties of an object | | |
14. | Determine if a property exists in an object | | |
15. | Get the type of the Property. | | |
16. | Set the value of a property that has been declared as an Enum type using reflection | | |
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 | | |