Debug Utilities : Debug « Development Class « Java






Debug Utilities

     
/*
 ** Copyright (c) 1998 by Timothy Gerard Endres
 ** <mailto:time@ice.com>  <http://www.ice.com>
 ** 
 ** This program is free software.
 ** 
 ** You may redistribute it and/or modify it under the terms of the GNU
 ** General Public License as published by the Free Software Foundation.
 ** Version 2 of the license should be included with this distribution in
 ** the file LICENSE, as well as License.html. If the license is not
 ** included with this distribution, you may find a copy at the FSF web
 ** site at 'www.gnu.org' or 'www.fsf.org', or you may write to the
 ** Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139 USA.
 **
 ** THIS SOFTWARE IS PROVIDED AS-IS WITHOUT WARRANTY OF ANY KIND,
 ** NOT EVEN THE IMPLIED WARRANTY OF MERCHANTABILITY. THE AUTHOR
 ** OF THIS SOFTWARE, ASSUMES _NO_ RESPONSIBILITY FOR ANY
 ** CONSEQUENCE RESULTING FROM THE USE, MODIFICATION, OR
 ** REDISTRIBUTION OF THIS SOFTWARE. 
 ** 
 */

import java.io.PrintWriter;

public class DebugUtilities {
  public static void printClassHierarchy(Class aClass, PrintWriter writer, String prefix) {
    String subPrefix = "-->";

    for (int i = 0;; ++i) {
      writer.println(prefix + " " + subPrefix + " " + aClass.getName());

      aClass = aClass.getSuperclass();

      if (aClass == Object.class)
        break;

      subPrefix = "--" + subPrefix;
    }
  }

  public static void printContainerComponents(java.awt.Container cont, PrintWriter writer,
      String prefix, boolean recurse) {
    java.awt.Component[] comps = cont.getComponents();

    if (comps.length < 1) {
      writer.println(prefix + "Contains no components.");
    }

    for (int i = 0; i < comps.length; ++i) {
      DebugUtilities.printClassHierarchy(comps[i].getClass(), writer, prefix + "[" + i + "]");

      if (recurse) {
        Class c = java.awt.Container.class;
        if (c.isAssignableFrom(comps[i].getClass())) {
          DebugUtilities.printContainerComponents((java.awt.Container) comps[i], writer, (prefix
              + "[" + i + "] "), recurse);
        }
      }
    }
  }

}

   
    
    
    
    
  








Related examples in the same category

1.A simple logging facility.
2.Debug InputStream
3.Methods for printing Debug messages
4.Trace InputStream
5.Trace OutputStream
6.Debug Utility
7.Debugging utility that reports, in a brute force manner, any internal data of a class instance
8.Swing Console
9.How to do Benchmark
10.Methods for logging events
11.Printing indented text
12.Prints messages formatted for a specific line width.
13.Class providing static methods to log diagnostics
14.A bean that can be used to keep track of a counter
15.An integer synchronized counter class.
16.Counts down from a specified value the number of bytes actually read from the wrapped InputStream.
17.A long integer counter class
18.Logging class to record errors or unexpected behavior to a file
19.Handle obtaining string timestamps
20.Scans java source files in cvs tree and validates the license header
21.Debug Util
22.Array debug util
23.A simple frame that allows quick and easy visualisation of something