java beans Introspector








Class java.beans.Introspector





All Packages Class Hierarchy This Package Previous Next Index


Class java.beans.Introspector


java.lang.Object
|
+----java.beans.Introspector



public class Introspector
extends Object

The Introspector class provides a standard way for tools to learn about
the properties, events, and methods supported by a target Java Bean.

For each of those three kinds of information, the Introspector will
separately analyze the bean's class and superclasses looking for
either explicit or implicit information and use that information to
build a BeanInfo object that comprehensively describes the target bean.

For each class "Foo", explicit information may be available if there exists
a corresponding "FooBeanInfo" class that provides a non-null value when
queried for the information. We first look for the BeanInfo class by
taking the full package-qualified name of the target bean class and
appending "BeanInfo" to form a new class name. If this fails, then
we take the final classname component of this name, and look for that
class in each of the packages specified in the BeanInfo package search
path.

Thus for a class such as "sun.xyz.OurButton" we would first look for a
BeanInfo class called "sun.xyz.OurButtonBeanInfo" and if that failed we'd
look in each package in the BeanInfo search path for an OurButtonBeanInfo
class. With the default search path, this would mean looking for
"sun.beans.infos.OurButtonBeanInfo".

If a class provides explicit BeanInfo about itself then we add that to
the BeanInfo information we obtained from analyzing any derived classes,
but we regard the explicit information as being definitive for the current
class and its base classes, and do not proceed any further up the superclass
chain.

If we don't find explicit BeanInfo on a class, we use low-level
reflection to study the methods of the class and apply standard design
patterns to identify property accessors, event sources, or public
methods. We then proceed to analyze the class's superclass and add
in the information from it (and possibly on up the superclass chain).








decapitalize(String)
Utility method to take a string and convert it to normal Java variable
name capitalization.

getBeanInfo(Class)
Introspect on a Java bean and learn about all its properties, exposed
methods, and events.

getBeanInfo(Class, Class)
Introspect on a Java bean and learn all about its properties, exposed
methods, below a given "stop" point.

getBeanInfoSearchPath()


setBeanInfoSearchPath(String[])
Change the list of package names that will be used for
finding BeanInfo classes.






getBeanInfo

public static BeanInfo getBeanInfo(Class beanClass) throws IntrospectionException


Introspect on a Java bean and learn about all its properties, exposed
methods, and events.


Parameters:
beanClass - The bean class to be analyzed.
Returns:
A BeanInfo object describing the target bean.
Throws: IntrospectionException
if an exception occurs during
introspection.



getBeanInfo

public static BeanInfo getBeanInfo(Class beanClass,
Class stopClass) throws IntrospectionException


Introspect on a Java bean and learn all about its properties, exposed
methods, below a given "stop" point.


Parameters:
bean - The bean class to be analyzed.
stopClass - The baseclass at which to stop the analysis. Any
methods/properties/events in the stopClass or in its baseclasses
will be ignored in the analysis.
Throws: IntrospectionException
if an exception occurs during
introspection.



decapitalize

public static String decapitalize(String name)


Utility method to take a string and convert it to normal Java variable
name capitalization. This normally means converting the first
character from upper case to lower case, but in the (unusual) special
case when there is more than one character and both the first and
second characters are upper case, we leave it alone.

Thus "FooBah" becomes "fooBah" and "X" becomes "x", but "URL" stays
as "URL".


Parameters:
name - The string to be decapitalized.
Returns:
The decapitalized version of the string.



getBeanInfoSearchPath

public static String[] getBeanInfoSearchPath()



Returns:
The array of package names that will be searched in
order to find BeanInfo classes.
This is initially set to {"sun.beans.infos"}.



setBeanInfoSearchPath

public static void setBeanInfoSearchPath(String path[])


Change the list of package names that will be used for
finding BeanInfo classes.


Parameters:
path - Array of package names.




All Packages Class Hierarchy This Package Previous Next Index

Submit a bug or feature - Version 1.1.7 of Java Platform API Specification
Java is a trademark or registered trademark of Sun Microsystems, Inc. in the US and other countries.
Copyright 1995-1998 Sun Microsystems, Inc. 901 San Antonio Road,
Palo Alto, California, 94303, U.S.A. All Rights Reserved.




Wyszukiwarka

Podobne podstrony:
java beans IntrospectionException
java beans PropertyChangeEvent
java beans Beans
java beans FeatureDescriptor
java beans PropertyEditor
java beans VetoableChangeSupport
java beans PropertyEditorManager
java beans PropertyDescriptor
java beans ParameterDescriptor
java beans IndexedPropertyDescriptor
java beans Customizer
Java Beans
java beans MethodDescriptor
Package java beans
java beans BeanDescriptor
java beans PropertyVetoException
java beans PropertyChangeSupport
java beans BeanInfo
java beans PropertyEditorSupport

więcej podobnych podstron