All Packages Class Hierarchy This Package Previous Next Index
java.lang.Object | +----java.beans.Introspector
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. The name of the bean info class is formed by taking the full name of the target bean class (such as "sun.stuff.OurButton") and appending "BeanInfo" to form a new class name (e.g. "sun.stuff.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).
public static BeanInfo getBeanInfo(Class beanClass) throws IntrospectionException
public static BeanInfo getBeanInfo(Class beanClass, Class stopClass) throws IntrospectionException
public static String decapitalize(String name)
Thus "FooBah" becomes "fooBah" and "X" becomes "x", but "URL" stays as "URL".
All Packages Class Hierarchy This Package Previous Next Index