/* * Copyright (c) 1997, 2012, Oracle and/or its affiliates. All rights reserved. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * This code is free software; you can redistribute it and/or modify it * under the terms of the GNU General Public License version 2 only, as * published by the Free Software Foundation. Oracle designates this * particular file as subject to the "Classpath" exception as provided * by Oracle in the LICENSE file that accompanied this code. * * This code 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 General Public License * version 2 for more details (a copy is included in the LICENSE file that * accompanied this code). * * You should have received a copy of the GNU General Public License version * 2 along with this work; if not, write to the Free Software Foundation, * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. * * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA * or visit www.oracle.com if you need additional information or have any * questions. */ package com.sun.xml.internal.bind.v2.model.core; import java.util.List; import javax.xml.bind.annotation.XmlTransient; import javax.xml.bind.annotation.XmlValue; /** * Information about JAXB-bound class. * *

* All the JAXB annotations are already reflected to the model so that * the caller doesn't have to worry about them. For this reason, you * cannot access annotations on properties. * *

XML representation

*

* A JAXB-bound class always have at least one representation * (called "type representation"),but it can optionally have another * representation ("element representation"). * *

* In the type representaion, a class * is represented as a set of attributes and (elements or values). * You can inspect the details of those attributes/elements/values by {@link #getProperties()}. * This representation corresponds to a complex/simple type in XML Schema. * You can obtain the schema type name by {@link #getTypeName()}. * *

* If a class has an element representation, {@link #isElement()} returns true. * This representation is mostly similar to the type representation * except that the whoe attributes/elements/values are wrapped into * one element. You can obtain the name of this element through {@link #asElement()}. * * @author Kohsuke Kawaguchi (kk@kohsuke.org) */ public interface ClassInfo extends MaybeElement { /** * Obtains the information about the base class. * * @return null * if this info extends from {@link Object}. */ ClassInfo getBaseClass(); /** * Gets the declaration this object is wrapping. */ C getClazz(); /** * Gets the fully-qualified name of the class. */ String getName(); /** * Returns all the properties newly declared in this class. * *

* This excludes properties defined in the super class. * *

* If the properties are {@link #isOrdered() ordered}, * it will be returned in the order that appear in XML. * Otherwise it will be returned in no particular order. * *

* Properties marked with {@link XmlTransient} will not show up * in this list. As far as JAXB is concerned, they are considered * non-existent. * * @return * always non-null, but can be empty. */ List> getProperties(); /** * Returns true if this class or its ancestor has {@link XmlValue} * property. */ boolean hasValueProperty(); /** * Gets the property that has the specified name. * *

* This is just a convenience method for: *

     * for( PropertyInfo p : getProperties() ) {
     *   if(p.getName().equals(name))
     *     return p;
     * }
     * return null;
     * 
* * @return null * if the property was not found. * * @see PropertyInfo#getName() */ PropertyInfo getProperty(String name); /** * If the class has properties, return true. This is only * true if the Collection object returned by {@link #getProperties()} * is not empty. */ boolean hasProperties(); /** * If this class is abstract and thus shall never be directly instanciated. */ boolean isAbstract(); /** * Returns true if the properties of this class is ordered in XML. * False if it't not. * *

* In RELAX NG context, ordered properties mean {@code } and * unordered properties mean {@code }. */ boolean isOrdered(); /** * If this class is marked as final and no further extension/restriction is allowed. */ boolean isFinal(); /** * True if there's a known sub-type of this class in {@link TypeInfoSet}. */ boolean hasSubClasses(); /** * Returns true if this bean class has an attribute wildcard. * *

* This is true if the class declares an attribute wildcard, * or it is inherited from its super classes. * * @see #inheritsAttributeWildcard() */ boolean hasAttributeWildcard(); /** * Returns true iff this class inherits a wildcard attribute * from its ancestor classes. */ boolean inheritsAttributeWildcard(); /** * Returns true iff this class declares a wildcard attribute. */ boolean declaresAttributeWildcard(); }