Helper to display the "contents" of the Value Object : Type « Reflection « C# / C Sharp

Home
C# / C Sharp
1.2D Graphics
2.Class Interface
3.Collections Data Structure
4.Components
5.Data Types
6.Database ADO.net
7.Design Patterns
8.Development Class
9.Event
10.File Stream
11.Generics
12.GUI Windows Form
13.Language Basics
14.LINQ
15.Network
16.Office
17.Reflection
18.Regular Expressions
19.Security
20.Services Event
21.Thread
22.Web Services
23.Windows
24.Windows Presentation Foundation
25.XML
26.XML LINQ
C# / C Sharp by API
C# / CSharp Tutorial
C# / CSharp Open Source
C# / C Sharp » Reflection » TypeScreenshots 
Helper to display the "contents" of the Value Object
 

#region License and Copyright
/*
 * Dotnet Commons Reflection
 *
 * 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.IO;
using System.Reflection;
using System.Runtime.Serialization.Formatters.Binary;
using System.Text;

namespace Dotnet.Commons.Reflection
{
  /// -----------------------------------------------------------------------
  /// <summary>  
  /// This utility class contains a rich sets of utility methods that perform operations 
  /// on objects during runtime such as copying of property and field values
  /// between 2 objects, deep cloning of objects, etc.  
  /// </summary>
  /// -----------------------------------------------------------------------
  public abstract class ObjectUtils
  {

    /// ------------------------------------------------------------------------
    /// <summary>
    /// Helper to display the "contents" of the Value Object
    /// </summary>
    /// <param name="valueObject"></param>
    /// <returns></returns>
    /// ------------------------------------------------------------------------
    public static string ConvertToString(object valueObject
    {
      StringBuilder buffy = new StringBuilder(valueObject.GetType().FullName);


      // null objects cannot be reflected
      if(valueObject == null
      {
        buffy.Append(" is null.");
        return buffy.ToString();
      }

      buffy.Append("[\n");
      foreach(PropertyInfo objProperty in valueObject.GetType().GetProperties())
      {
        string nvp;

        nvp = "  <<Property>> " "<" + objProperty.PropertyType + "> " + objProperty.Name+"=";

        if (objProperty != null
        {
          object   value = valueObject
                   .GetType()
                   .InvokeMember(objProperty.Name,
                          BindingFlags.GetProperty,
                          null,
                          valueObject,
                          null);

          buffy.Append(nvp+value.ToString()+"\n");
        }
        else          
        {
          buffy.Append(nvp+"<null>\n");
        }
      }

      foreach(FieldInfo objField in valueObject.GetType().GetFields())
      {
        string nvp;

        nvp = "  <<Field>> " "<" + objField.FieldType + "> " + objField.Name +"=";

        if (objField != null
        {
          object   value = valueObject.GetType().InvokeMember(objField.Name,
                                    BindingFlags.GetField,                                    
                                    null,
                                    valueObject,
                                    null);

          buffy.Append(nvp+value.ToString()+"\n");
        }
        else          
        {
          buffy.Append(nvp+"<null>\n");
        }
      }
      // ----------- End ---------
      buffy.Append("]");
      return buffy.ToString();
    }

    }
}

   
  
Related examples in the same category
1.Call GetType() from StringBuilder
2.Call GetType for int data type
3.IsGeneric and IsGenericTypeDefinition
4.demonstrates both the instance and static GetType methods
5.Generic methods, like nongeneric methods, can be invoked dynamically at run time.
6.Type.GetGenericArguments and MethodInfo.GetGenericArguments:
7.Get Generic Type Definition
8.Query properties of a Type
9.Deeper Reflection:Listing All the Types in an AssemblyDeeper Reflection:Listing All the Types in an Assembly
10.Illustrates runtime type creation
11.The typeName parameter is a combination of the Assembly and Type names
12.Call static method GetType from Type to get the Type instance
13.Use GetCustomAttributes from Type to get custom attributes
14.Use Type.GetType to check the type of an object
15.Get object Type Name, UnderlyingSystemType, IsClass
16.Type.GetConstructors
17.Use Type.IsClass to check if a type is a class
18.Print Types
19.Determining the base classes and interfaces for a class.
20.Create Object from assembly name and class nameCreate Object from assembly name and class name
21.Makes a shallow copy of the object to a different class type (inherits from the original)
22.Makes a shallow copy of the object
23.Get all methods from an object
24.Get Derivation from an object
25.The full name of the Array type
26.Change type
27.Does a given Type have a Default Constructor
28.Is it a Nullable Type
29.Is Value Type Unitialized Value
30.Get Type Unitialized Value
31.Is Object Unitialized Value
32.Is it a SubClass for another class
33.Convert type from initial Value
34.Returns all assemblies and their properties
35.Get a public field value given its name
36.Deep Comparison two objects if they are alike.
37.Set the specified public field value of an object
38.Determine if a type is cloneable: either a value type or implementing ICloneable.
39.Provides a simple reflection based mapper to perform a Data Mapping between two types of objects
www.java2java.com | Contact Us
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.