com.sun.tools.xjc.model
Class CElementInfo

java.lang.Object
  extended by com.sun.tools.xjc.model.CElementInfo
All Implemented Interfaces:
CClassInfoParent, CCustomizable, CElement, CTypeInfo, NType, Locatable, Element<NType,NClass>, ElementInfo<NType,NClass>, TypeInfo<NType,NClass>

public final class CElementInfo
extends Object
implements ElementInfo<NType,NClass>, NType, CClassInfoParent

ElementInfo implementation for the compile-time model.

As an NType, it represents the Java representation of this element (either JAXBElement<T> or Foo).

Author:
Kohsuke Kawaguchi

Nested Class Summary
 
Nested classes/interfaces inherited from interface com.sun.tools.xjc.model.CClassInfoParent
CClassInfoParent.Package, CClassInfoParent.Visitor<T>
 
Field Summary
 CClassInfoParent parent
          If this element is global, the element info is considered to be package-level, and this points to the package in which this element lives in.
 
Constructor Summary
CElementInfo(Model model, QName tagName, CClassInfoParent parent, String className, CCustomizations customizations, Locator location)
          Creates an element with a class in the given parent.
CElementInfo(Model model, QName tagName, CClassInfoParent parent, TypeUse contentType, XmlString defaultValue, XSElementDecl source, CCustomizations customizations, Locator location)
          Creates an element in the given parent.
 
Method Summary
 JPackage _package()
           
<T> T
accept(CClassInfoParent.Visitor<T> visitor)
           
 boolean canBeReferencedByIDREF()
          Deprecated. why are you calling an unimplemented method?
 JExpression createConstant(Outline outline, XmlString lexical)
           
 String fullName()
          Human readable name of this type.
 CAdapter getAdapterUse()
           
 NType getContentInMemoryType()
           
 CNonElement getContentType()
           
 CCustomizations getCustomizations()
          Gets the list of customizations attached to this model component.
 String getDefaultValue()
           
 QName getElementName()
           
 MimeType getExpectedMimeType()
          No default MimeType.
 Location getLocation()
           
 Locator getLocator()
          Gets the source location in the schema from which this model component is created.
 JPackage getOwnerPackage()
          Gets the nearest JPackage.
 CElementPropertyInfo getProperty()
           
 XSComponent getSchemaComponent()
          If this model object is built from XML Schema, this property returns a schema component from which the model is built.
 CClassInfo getScope()
           
 String getSqueezedName()
          Returns the "squeezed name" of this element.
 CElementInfo getSubstitutionHead()
           
 Collection<CElementInfo> getSubstitutionMembers()
           
 NType getType()
          Deprecated. why are you calling a method that returns this?
 Locatable getUpstream()
           
 boolean hasClass()
          True if this element has its own class (as opposed to be represented as an instance of JAXBElement.
 ID idUse()
           
 void initContentType(TypeUse contentType, XSElementDecl source, XmlString defaultValue)
           
 boolean isAbstract()
          Returns true iff this element is an abstract element.
 boolean isBoxedType()
          Returns true iff this type represents a class that has a unboxed form.
 boolean isCollection()
           
 void setAbstract()
          Marks this element as an abstract element.
 void setSubstitutionHead(CElementInfo substitutionHead)
           
 String shortName()
           
 JType toType(Outline o, Aspect aspect)
          Returns the representation of this type in code model.
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 
Methods inherited from interface com.sun.xml.bind.v2.model.core.TypeInfo
canBeReferencedByIDREF
 
Methods inherited from interface com.sun.xml.bind.v2.model.annotation.Locatable
getLocation, getUpstream
 
Methods inherited from interface com.sun.tools.xjc.model.CCustomizable
getCustomizations, getSchemaComponent
 

Field Detail

parent

public final CClassInfoParent parent
If this element is global, the element info is considered to be package-level, and this points to the package in which this element lives in.

For local elements, this points to the parent CClassInfo.

Constructor Detail

CElementInfo

public CElementInfo(Model model,
                    QName tagName,
                    CClassInfoParent parent,
                    TypeUse contentType,
                    XmlString defaultValue,
                    XSElementDecl source,
                    CCustomizations customizations,
                    Locator location)
Creates an element in the given parent.

When using this construction, initContentType(TypeUse, XSElementDecl, XmlString) must not be invoked.


CElementInfo

public CElementInfo(Model model,
                    QName tagName,
                    CClassInfoParent parent,
                    String className,
                    CCustomizations customizations,
                    Locator location)
Creates an element with a class in the given parent.

When using this construction, the caller must use initContentType(TypeUse, XSElementDecl, XmlString) to fill in the content type later. This is to avoid a circular model construction dependency between buidling a type inside an element and element itself. To build a content type, you need to have CElementInfo for a parent, so we can't take it as a constructor parameter.

Method Detail

initContentType

public void initContentType(TypeUse contentType,
                            @Nullable
                            XSElementDecl source,
                            XmlString defaultValue)

getDefaultValue

public final String getDefaultValue()

_package

public final JPackage _package()

getContentType

public CNonElement getContentType()
Specified by:
getContentType in interface ElementInfo<NType,NClass>

getContentInMemoryType

public NType getContentInMemoryType()
Specified by:
getContentInMemoryType in interface ElementInfo<NType,NClass>

getProperty

public CElementPropertyInfo getProperty()
Specified by:
getProperty in interface ElementInfo<NType,NClass>

getScope

public CClassInfo getScope()
Specified by:
getScope in interface Element<NType,NClass>

getType

public NType getType()
Deprecated. why are you calling a method that returns this?

Specified by:
getType in interface ElementInfo<NType,NClass>
Specified by:
getType in interface TypeInfo<NType,NClass>

getElementName

public QName getElementName()
Specified by:
getElementName in interface Element<NType,NClass>

toType

public JType toType(Outline o,
                    Aspect aspect)
Description copied from interface: NType
Returns the representation of this type in code model.

This operation requires the whole model to be built, and hence it takes Outline.

Under some code generation strategy, some bean classes are considered implementation specific (such as impl.FooImpl class) These classes always have accompanying "exposed" type (such as the Foo interface).

For such Jekyll and Hyde type, the aspect parameter determines which personality is returned.

Specified by:
toType in interface CTypeInfo
Specified by:
toType in interface NType
aspect - If Aspect.IMPLEMENTATION, this method returns the implementation specific class that this type represents. If Aspect.EXPOSED, this method returns the publicly exposed type that this type represents. For ordinary classes, the aspect parameter is meaningless.
See Also:
NType.toType(Outline, Aspect)

getSqueezedName

public String getSqueezedName()
Returns the "squeezed name" of this element.

See Also:
CClassInfo.getSqueezedName()

getSubstitutionHead

public CElementInfo getSubstitutionHead()
Specified by:
getSubstitutionHead in interface Element<NType,NClass>
Specified by:
getSubstitutionHead in interface ElementInfo<NType,NClass>

getSubstitutionMembers

public Collection<CElementInfo> getSubstitutionMembers()
Specified by:
getSubstitutionMembers in interface ElementInfo<NType,NClass>

setSubstitutionHead

public void setSubstitutionHead(CElementInfo substitutionHead)

isBoxedType

public boolean isBoxedType()
Description copied from interface: NType
Returns true iff this type represents a class that has a unboxed form. For example, for String this is false, but for Integer this is true.

Specified by:
isBoxedType in interface NType

fullName

public String fullName()
Description copied from interface: NType
Human readable name of this type.

Specified by:
fullName in interface CClassInfoParent
Specified by:
fullName in interface NType

accept

public <T> T accept(CClassInfoParent.Visitor<T> visitor)
Specified by:
accept in interface CClassInfoParent

getOwnerPackage

public JPackage getOwnerPackage()
Description copied from interface: CClassInfoParent
Gets the nearest JPackage.

Specified by:
getOwnerPackage in interface CClassInfoParent

shortName

public String shortName()

hasClass

public boolean hasClass()
True if this element has its own class (as opposed to be represented as an instance of JAXBElement.


getLocator

public Locator getLocator()
Description copied from interface: CCustomizable
Gets the source location in the schema from which this model component is created.

Specified by:
getLocator in interface CCustomizable
Returns:
never null.

isAbstract

public boolean isAbstract()
Description copied from interface: CElement
Returns true iff this element is an abstract element.

Specified by:
isAbstract in interface CElement

setAbstract

public void setAbstract()
Description copied from interface: CElement
Marks this element as an abstract element.

Specified by:
setAbstract in interface CElement

isCollection

public final boolean isCollection()

getAdapterUse

public final CAdapter getAdapterUse()

idUse

public final ID idUse()

getSchemaComponent

public final XSComponent getSchemaComponent()
Description copied from interface: CCustomizable
If this model object is built from XML Schema, this property returns a schema component from which the model is built.

Specified by:
getSchemaComponent in interface CCustomizable
Returns:
null if the model is built from sources other than XML Schema (such as DTD.)

canBeReferencedByIDREF

public final boolean canBeReferencedByIDREF()
Deprecated. why are you calling an unimplemented method?

Specified by:
canBeReferencedByIDREF in interface TypeInfo<NType,NClass>

getExpectedMimeType

public MimeType getExpectedMimeType()
No default MimeType.


getCustomizations

public CCustomizations getCustomizations()
Description copied from interface: CCustomizable
Gets the list of customizations attached to this model component.

Specified by:
getCustomizations in interface CCustomizable
Returns:
can be an empty list but never be null. The returned list is read-only. Do not modify.
See Also:
Plugin.getCustomizationURIs()

createConstant

public JExpression createConstant(Outline outline,
                                  XmlString lexical)

getUpstream

public final Locatable getUpstream()
Specified by:
getUpstream in interface Locatable

getLocation

public final Location getLocation()
Specified by:
getLocation in interface Locatable


Copyright © 2005-2015 Oracle Corporation. All Rights Reserved.