Package com.saxonica.ee.schema.sdoc
Class SchemaElement
- java.lang.Object
- 
- net.sf.saxon.tree.linked.NodeImpl
- 
- net.sf.saxon.tree.linked.ParentNodeImpl
- 
- net.sf.saxon.tree.linked.ElementImpl
- 
- com.saxonica.ee.schema.sdoc.SchemaElement
 
 
 
 
- 
- All Implemented Interfaces:
- javax.xml.transform.Source,- javax.xml.transform.SourceLocator,- GroundedValue,- Item,- MutableNodeInfo,- NamespaceResolver,- NodeInfo,- Sequence,- Location,- SteppingNode<NodeImpl>,- SiblingCountingNode,- org.xml.sax.Locator
 - Direct Known Subclasses:
- AnnotationParent,- UnknownElement,- XSDAnnotation,- XSDAttribute,- XSDAttributeGroup,- XSDComplexContent,- XSDComplexContentRestriction,- XSDComplexType,- XSDCompositor,- XSDDocumentation,- XSDElement,- XSDExtension,- XSDGroup,- XSDIdentityConstraint,- XSDList,- XSDOverride,- XSDRedefine,- XSDSchema,- XSDSimpleContent,- XSDSimpleContentRestriction,- XSDSimpleType,- XSDSimpleTypeRestriction,- XSDUnion
 
 public abstract class SchemaElement extends ElementImpl An element in an XML Schema document. This is an abstract superclass for the elements in the schema document; many of its methods are designed to be called from the subclasses
- 
- 
Nested Class SummaryNested Classes Modifier and Type Class Description protected classSchemaElement.XPathStaticContext
 - 
Field SummaryFields Modifier and Type Field Description protected static java.lang.StringNAMESPACE_ANYprotected static java.lang.StringNAMESPACE_LOCALprotected static java.lang.StringNAMESPACE_OTHERprotected static java.lang.StringNAMESPACE_TARGETstatic intREQUIRE_NULL_NSOption indicating "no namespace prefix is allowed; the name is in the null Namespace"static intREQUIRE_TARGET_NSOption indicating "no namespace prefix is allowed; the name is in the targetNamespace"static intUSE_DEFAULT_NSOption indicating "use the default element namespace when unprefixed"static intUSE_DEFAULT_NS_WITHOUT_IMPORTOption indicating "use the default element namespace when unprefixed", but without a requirement to have an xs:import- 
Fields inherited from class net.sf.saxon.tree.linked.NodeImplNODE_LETTER
 - 
Fields inherited from interface net.sf.saxon.om.NodeInfoIS_DTD_TYPE, IS_NILLED
 
- 
 - 
Constructor SummaryConstructors Constructor Description SchemaElement()Construct a SchemaElement
 - 
Method SummaryAll Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description protected NodeNameallocateAnonymousTypeCode()Allocate a name to an anonymous type.voidallowAttributes(AttributeMap atts, java.lang.String[] allowed)Check the attributes of an element against a list of allowed attributes.protected voidcheckContentModel(int[][] stateTerms, int[][] stateTargets, boolean allowWildcards)Check the content model of an element in the schema.voidcheckLocalTargetNamespace(java.lang.String elementOrAttribute)For an element or attribute declaration with a targetNamespace attribute (XSD 1.1), check the highly-paternalistic rules for when this attribute is permitted.protected voidcheckMutuallyExclusiveAttributes(java.lang.String name1, java.lang.String name2)This method tests whether two attributes coexist and reports an error if they doprotected voidcheckOnlyChildIsAnnotation()Check that the only child element of this element is an (optional and non-repeatable) xs:annotation elementvoidcheckPermittedType(int fp, java.lang.String name, java.lang.String role)Check that a given type is a permitted typeprotected voidduplicate(java.lang.String category, java.lang.String name)This method is called when two objects in the same symbol space within a schema have duplicate namesprotected voidduplicateElement(java.lang.String name)This method is called when two occurrences of a child element are found and only one is allowed.protected voiderror(java.lang.String err)This method is called for a general error.protected voiderror(SchemaException exception)This method is called for a general error.protected StructuredQNamegetComponentName(java.lang.String name, int option)This method is called to check that a lexical QName is valid and allocate a nameCode for the name in the namePool.protected UserComplexTypegetContainingComplexType()Get the complexType associated with the containing xs:complexType elementprotected SimpleTypeDefinitiongetContainingSimpleType()Get the simpleTypeDefinition associated with the containing xs:simpleType elementprotected intgetFingerprint(java.lang.String name, int option)This method is called to check that a QName is valid and allocate a fingerprint for the name in the namePool.protected SingleNamespaceSchemagetSchema()Get the schema corresponding to the contents of the schema document containing this elementSchemaNodeFactorygetSchemaNodeFactory()Get the nodeFactory used to create this element.XSDSchemagetXSDSchema()Get the owning XSDSchema element.protected voidillegalElement(NodeInfo child)This method is called when an illegal Element is encountered.protected java.lang.StringindefiniteArticle(java.lang.String word, java.lang.String start)Construct an indefinite article in EnglishvoidinvalidAttributeValue(java.lang.String name, java.lang.String value, java.lang.String message)This method is called when an invalid attribute value is foundprotected booleanisFinalState(int state)For elements whose content model is parsed using a finite state machine, test whether a given state is a final state.protected booleanisTopLevel()Return true if this element is a child of xs:schema or xs:redefineprotected NamespaceResolvermakeNamespaceContext()Make a NamespaceContext object representing the list of in-scope namespaces.voidmissingAttribute(java.lang.String name)This method is called when a required attribute is not foundvoidmissingChildElement(java.lang.String name)This method is called when a required child element is not foundprotected voidmustBeFirstElement(java.lang.String name)This method is called when a child element is required to be the first child, but is found elsewhereprotected voidmustPrecede(java.lang.String name1, java.lang.String name2)This method is called when two child elements are found in the wrong order.protected voidmutuallyExclusive(java.lang.String name1, java.lang.String name2)This method is called when two child elements may not coexistprotected voidmutuallyExclusiveAttributes(java.lang.String name1, java.lang.String name2)This method is called when two attributes may not coexistprotected voidmutuallyExclusiveElementAndAttribute(java.lang.String elem, java.lang.String att)This method is called when an attribute and a child elements may not coexistbooleanparseBooleanAttribute(java.lang.String name, java.lang.String value)Parse a boolean attribute valueintparseFinalOrBlock(java.lang.String attrName, java.lang.String finalValue, int allowed)Parse a list of blocked or final derivations.voidpostValidate(SchemaCompiler compiler)Hook to allow additional validation of a parent element immediately after its children have been validated.abstract voidprepareAttributes()Set the attribute list for the element.voidprocessAllAttributes()Process the attributes of this element and all its childrenprotected voidprocessAllowedNamespaces(java.lang.String attValue, Wildcard wildcard)Process the namespaces attribute of XSDAny or XSDAnyAttributeprotected voidprocessDisallowedNamespaces(java.lang.String attValue, Wildcard wildcard)Process the notNamespaces attribute of XSDAny or XSDAnyAttributeprotected voidprocessDisallowedQNames(java.lang.String attValue, Wildcard wildcard)Process the notQNames attribute of XSDAny or XSDAnyAttributevoidprocessId()Process an @id attribute on the schema element: if present, check that it is a valid ID, and that it is unique in the schema documentintprocessMaxOccurs(java.lang.String attValue)Process the value of a maxOccurs attribute on any element where it appearsintprocessMinOccurs(java.lang.String attValue)Process the value of a minOccurs attribute on any element where it appearsvoidrequireAttribute(AttributeMap atts, java.lang.String required)Indicate that a particular attribute is requiredvoidsetSchemaNodeFactory(SchemaNodeFactory factory)Set the nodeFactory used to create this element.voidvalidate(SchemaCompiler compiler)Check that the schema element is valid.protected voidvalidateChildren(SchemaCompiler compiler)Validate the children of this node, recursively.voidvalidateSubtree(SchemaCompiler compiler)Recursive walk through the schema to validate all nodesprotected voidwarning(java.lang.String err)Report a warning- 
Methods inherited from class net.sf.saxon.tree.linked.ElementImpladdAttribute, addNamespace, addNamespace, attributes, checkNotNamespaceSensitiveElement, copy, delete, fixupInsertedNamespaces, generateId, getAllNamespaces, getAttributeValue, getBaseURI, getColumnNumber, getDeclaredNamespaces, getLineNumber, getNodeKind, getNodeName, getRoot, getSchemaType, getSystemId, getURIForPrefix, initialise, isId, isIdref, isInScopeNamespace, isNilled, iteratePrefixes, removeAttribute, removeNamespace, removeTypeAnnotation, rename, replaceStringValue, setAttributeInfo, setAttributes, setLocation, setNamespaceMap, setNilled, setNodeName, setSystemId, setTypeAnnotation
 - 
Methods inherited from class net.sf.saxon.tree.linked.ParentNodeImpladdChild, children, compact, getFirstChild, getLastChild, getNthChild, getNumberOfChildren, getRawSequenceNumber, getSequenceNumber, getStringValue, getStringValueCS, hasChildNodes, insertChildren, iterateChildren, removeChild, replaceChildrenAt, setChildren, setRawSequenceNumber
 - 
Methods inherited from class net.sf.saxon.tree.linked.NodeImplatomize, compareOrder, effectiveBooleanValue, equals, getConfiguration, getDisplayName, getFingerprint, getLocalPart, getNamePool, getNextInDocument, getNextSibling, getParent, getPhysicalRoot, getPrefix, getPreviousInDocument, getPreviousSibling, getRawParent, getSiblingPosition, getSuccessorElement, getTreeInfo, getURI, hasFingerprint, head, insertSiblings, isDeleted, iterateAxis, iterateAxis, newBuilder, replace, saveLocation, setRawParent, setSiblingPosition
 - 
Methods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 - 
Methods inherited from interface net.sf.saxon.om.GroundedValueasIterable, concatenate, containsNode, materialize
 - 
Methods inherited from interface net.sf.saxon.om.ItemgetLength, itemAt, iterate, reduce, subsequence
 - 
Methods inherited from interface net.sf.saxon.om.NodeInfochildren, equals, getGenre, getPublicId, hashCode, isSameNodeInfo, isStreamed, toShortString
 - 
Methods inherited from interface net.sf.saxon.om.SequencemakeRepeatable
 
- 
 
- 
- 
- 
Field Detail- 
USE_DEFAULT_NSpublic static final int USE_DEFAULT_NS Option indicating "use the default element namespace when unprefixed"- See Also:
- Constant Field Values
 
 - 
REQUIRE_TARGET_NSpublic static final int REQUIRE_TARGET_NS Option indicating "no namespace prefix is allowed; the name is in the targetNamespace"- See Also:
- Constant Field Values
 
 - 
REQUIRE_NULL_NSpublic static final int REQUIRE_NULL_NS Option indicating "no namespace prefix is allowed; the name is in the null Namespace"- See Also:
- Constant Field Values
 
 - 
USE_DEFAULT_NS_WITHOUT_IMPORTpublic static final int USE_DEFAULT_NS_WITHOUT_IMPORT Option indicating "use the default element namespace when unprefixed", but without a requirement to have an xs:import- See Also:
- Constant Field Values
 
 - 
NAMESPACE_ANYprotected static final java.lang.String NAMESPACE_ANY - See Also:
- Constant Field Values
 
 - 
NAMESPACE_LOCALprotected static final java.lang.String NAMESPACE_LOCAL - See Also:
- Constant Field Values
 
 - 
NAMESPACE_OTHERprotected static final java.lang.String NAMESPACE_OTHER - See Also:
- Constant Field Values
 
 - 
NAMESPACE_TARGETprotected static final java.lang.String NAMESPACE_TARGET - See Also:
- Constant Field Values
 
 
- 
 - 
Method Detail- 
isTopLevelprotected boolean isTopLevel() Return true if this element is a child of xs:schema or xs:redefine- Returns:
- true if this element is a child of xs:schema or xs:redefine
 
 - 
setSchemaNodeFactorypublic void setSchemaNodeFactory(SchemaNodeFactory factory) Set the nodeFactory used to create this element.- Parameters:
- factory- the schema node factory
 
 - 
getSchemaNodeFactorypublic SchemaNodeFactory getSchemaNodeFactory() Get the nodeFactory used to create this element. This nodeFactory is used to keep track of any errors encountered during construction of the schema document- Returns:
- factory the schema node factory
 
 - 
processAllAttributespublic void processAllAttributes() throws SchemaExceptionProcess the attributes of this element and all its children- Throws:
- SchemaException
 
 - 
prepareAttributespublic abstract void prepareAttributes() throws SchemaExceptionSet the attribute list for the element. This is called to process the attributes (note the distinction from processAttributes in the superclass). Must be supplied in a subclass- Throws:
- SchemaException
 
 - 
allowAttributespublic void allowAttributes(AttributeMap atts, java.lang.String[] allowed) throws SchemaException Check the attributes of an element against a list of allowed attributes. Report an error if any extraneous attribute is present- Parameters:
- atts- the attributes actually present
- allowed- the attributes that are allowed for this element. They must be listed in alphabetical order
- Throws:
- SchemaException
 
 - 
requireAttributepublic void requireAttribute(AttributeMap atts, java.lang.String required) throws SchemaException Indicate that a particular attribute is required- Parameters:
- atts- the attribtue collection
- required- the local name of the required attribute, which must be in the null namespace
- Throws:
- SchemaException
 
 - 
validateSubtreepublic void validateSubtree(SchemaCompiler compiler) throws SchemaException Recursive walk through the schema to validate all nodes- Parameters:
- compiler- used for error reporting
- Throws:
- SchemaException
 
 - 
validateChildrenprotected void validateChildren(SchemaCompiler compiler) throws SchemaException Validate the children of this node, recursively.- Parameters:
- compiler- used for error reporting
- Throws:
- SchemaException- if the subtree is not valid
 
 - 
validatepublic void validate(SchemaCompiler compiler) throws SchemaException Check that the schema element is valid. This is called once for each element, after the entire tree has been built. As well as validation, it can perform first-time initialisation. The default implementation does nothing; it is normally overriden in subclasses.- Parameters:
- compiler- used for error reporting
- Throws:
- SchemaException- if the subtree is not valid
 
 - 
postValidatepublic void postValidate(SchemaCompiler compiler) throws SchemaException Hook to allow additional validation of a parent element immediately after its children have been validated.- Parameters:
- compiler- used for error reporting
- Throws:
- SchemaException- if errors are found
 
 - 
getXSDSchemapublic XSDSchema getXSDSchema() throws SchemaException Get the owning XSDSchema element.- Returns:
- the containing xs:schema element
- Throws:
- SchemaException- if none is found (which means the schema is invalid)
 
 - 
getSchemaprotected SingleNamespaceSchema getSchema() throws SchemaException Get the schema corresponding to the contents of the schema document containing this element- Returns:
- the PreparedSchema object used to assemble the schema components defined in the schema document that contains this element.
- Throws:
- SchemaException- if the containing PreparedSchema cannot be found
 
 - 
getContainingComplexTypeprotected UserComplexType getContainingComplexType() throws SchemaException Get the complexType associated with the containing xs:complexType element- Returns:
- the UserComplexType object representing the containing complex type
- Throws:
- SchemaException- if the element is not contained in an xs:complexType
 
 - 
getContainingSimpleTypeprotected SimpleTypeDefinition getContainingSimpleType() throws SchemaException Get the simpleTypeDefinition associated with the containing xs:simpleType element- Returns:
- the schema component representing the containing simple type
- Throws:
- SchemaException- if not contained in an xs:simpleType
 
 - 
makeNamespaceContextprotected NamespaceResolver makeNamespaceContext() Make a NamespaceContext object representing the list of in-scope namespaces. The NamePool used for numeric codes in the NamespaceContext will be the target name pool.- Returns:
- a copy of the namespace context for this element
 
 - 
checkPermittedTypepublic void checkPermittedType(int fp, java.lang.String name, java.lang.String role) throws SchemaExceptionCheck that a given type is a permitted type- Throws:
- SchemaException
 
 - 
parseBooleanAttributepublic boolean parseBooleanAttribute(java.lang.String name, java.lang.String value) throws SchemaExceptionParse a boolean attribute value- Parameters:
- name- the name of the attribute (for diagnostics)
- value- the string value of the attribute (need not be trimmed)
- Returns:
- the boolean value of the attribute if it is valid
- Throws:
- SchemaException- if the value is not a valid boolean
 
 - 
errorprotected void error(java.lang.String err) throws SchemaExceptionThis method is called for a general error. The location of this message is the current element.- Parameters:
- err- the error message to report
- Throws:
- SchemaException
 
 - 
errorprotected void error(SchemaException exception) throws SchemaException This method is called for a general error. The location of this message is the current element.- Parameters:
- exception- the error message to report
- Throws:
- SchemaException
 
 - 
warningprotected void warning(java.lang.String err) Report a warning- Parameters:
- err- the warning message
 
 - 
getFingerprintprotected int getFingerprint(java.lang.String name, int option) throws SchemaExceptionThis method is called to check that a QName is valid and allocate a fingerprint for the name in the namePool. If the QName isn't valid, the method throws an exception: it is the caller's responsibility to call the error handler and recover from the error. The method makes use of the namespace context information for the schema element.- Parameters:
- name- The QName
- option- The option for handling unprefixed names. Options are to use the default namespace, the target namespace, or the null namespace Note that this method assumes the name, if unprefixed, is in the default namespace: NOT the targetNamespace of the schema.
- Returns:
- a fingerprint
- Throws:
- SchemaException- if the QName is invalid.
 
 - 
getComponentNameprotected StructuredQName getComponentName(java.lang.String name, int option) throws SchemaException This method is called to check that a lexical QName is valid and allocate a nameCode for the name in the namePool. If the QName isn't valid, the method throws an exception: it is the caller's responsibility to call the error handler and recover from the error. The method makes use of the namespace context information for the schema element.- Parameters:
- name- The QName as written in the schema
- option- The option for handling unprefixed names. Options are to use the default namespace- USE_DEFAULT_NS, the target namespace- REQUIRE_TARGET_NS, or the null namespace- REQUIRE_NULL_NS
- Returns:
- an integer name code
- Throws:
- SchemaException- if the QName is invalid.
 
 - 
checkOnlyChildIsAnnotationprotected void checkOnlyChildIsAnnotation() throws SchemaExceptionCheck that the only child element of this element is an (optional and non-repeatable) xs:annotation element- Throws:
- SchemaException
 
 - 
illegalElementprotected void illegalElement(NodeInfo child) throws SchemaException This method is called when an illegal Element is encountered.- Parameters:
- child- The child element whose presence is an error
- Throws:
- SchemaException- thrown if the errorListener decides that it's a fatal error.
 
 - 
duplicateElementprotected void duplicateElement(java.lang.String name) throws SchemaExceptionThis method is called when two occurrences of a child element are found and only one is allowed.- Parameters:
- name- the name of the illegal element
- Throws:
- SchemaException- thrown if the errorListener decides that it's a fatal error.
 
 - 
duplicateprotected void duplicate(java.lang.String category, java.lang.String name) throws SchemaExceptionThis method is called when two objects in the same symbol space within a schema have duplicate names- Parameters:
- category- the name of the first attribute
- name- the name of the second attribute
- Throws:
- SchemaException- thrown if the errorListener decides that it's a fatal error.
 
 - 
mutuallyExclusiveprotected void mutuallyExclusive(java.lang.String name1, java.lang.String name2) throws SchemaExceptionThis method is called when two child elements may not coexist- Parameters:
- name1- the name of the first element
- name2- the name of the second element
- Throws:
- SchemaException- thrown if the errorListener decides that it's a fatal error.
 
 - 
mutuallyExclusiveElementAndAttributeprotected void mutuallyExclusiveElementAndAttribute(java.lang.String elem, java.lang.String att) throws SchemaExceptionThis method is called when an attribute and a child elements may not coexist- Parameters:
- elem- the name of the element
- att- the name of the attribute
- Throws:
- SchemaException- thrown if the errorListener decides that it's a fatal error.
 
 - 
mutuallyExclusiveAttributesprotected void mutuallyExclusiveAttributes(java.lang.String name1, java.lang.String name2) throws SchemaExceptionThis method is called when two attributes may not coexist- Parameters:
- name1- the name of the first attribute
- name2- the name of the second attribute
- Throws:
- SchemaException- thrown if the errorListener decides that it's a fatal error.
 
 - 
checkMutuallyExclusiveAttributesprotected void checkMutuallyExclusiveAttributes(java.lang.String name1, java.lang.String name2) throws SchemaExceptionThis method tests whether two attributes coexist and reports an error if they do- Parameters:
- name1- the local name of the first attribute (must be in the null namespace)
- name2- the local name of the second attribute (must be in the null namespace)
- Throws:
- SchemaException
 
 - 
mustPrecedeprotected void mustPrecede(java.lang.String name1, java.lang.String name2) throws SchemaExceptionThis method is called when two child elements are found in the wrong order.- Parameters:
- name1- the name of the element that should be first
- name2- the name of the element that should be second
- Throws:
- SchemaException- thrown if the errorListener decides that it's a fatal error.
 
 - 
mustBeFirstElementprotected void mustBeFirstElement(java.lang.String name) throws SchemaExceptionThis method is called when a child element is required to be the first child, but is found elsewhere- Parameters:
- name- the name of the illegal element
- Throws:
- SchemaException- thrown if the errorListener decides that it's a fatal error.
 
 - 
indefiniteArticleprotected java.lang.String indefiniteArticle(java.lang.String word, java.lang.String start)Construct an indefinite article in English- Parameters:
- word- The word to follow the article
- start- Typically "a" or "A"
- Returns:
- the indefinite article
 
 - 
invalidAttributeValuepublic void invalidAttributeValue(java.lang.String name, java.lang.String value, java.lang.String message) throws SchemaExceptionThis method is called when an invalid attribute value is found- Parameters:
- name- the name of the attribute
- value- the supplied value of the attribute
- message- additional explanation of why it's wrong. May be null.
- Throws:
- SchemaException- thrown if the errorListener decides that it's a fatal error.
 
 - 
missingAttributepublic void missingAttribute(java.lang.String name) throws SchemaExceptionThis method is called when a required attribute is not found- Parameters:
- name- the name of the attribute
- Throws:
- SchemaException- thrown if the errorListener decides that it's a fatal error.
 
 - 
missingChildElementpublic void missingChildElement(java.lang.String name) throws SchemaExceptionThis method is called when a required child element is not found- Parameters:
- name- the name of the required child element
- Throws:
- SchemaException- thrown if the errorListener decides that it's a fatal error.
 
 - 
parseFinalOrBlockpublic int parseFinalOrBlock(java.lang.String attrName, java.lang.String finalValue, int allowed) throws SchemaExceptionParse a list of blocked or final derivations. Used to process the block, final, blockDefault, and finalDefault attributes.- Parameters:
- attrName- the name of the attribute being parsed
- finalValue- A list of values to be parsed, as a string, for example "extension restriction"
- allowed- The permitted values, as a bit-significant integer. For example the value (DERIVE_BY_EXTENSION | DERIVE_BY_RESTRICTION) allows the values "extension" and "restriction" to appear.
- Returns:
- The final/blocked values, as a bit-significant integer
- Throws:
- SchemaException- if the value of the attribute is invalid
 
 - 
processIdpublic void processId() throws SchemaExceptionProcess an @id attribute on the schema element: if present, check that it is a valid ID, and that it is unique in the schema document- Throws:
- SchemaException- if the id is present and is invalid or is a duplicate
 
 - 
allocateAnonymousTypeCodeprotected NodeName allocateAnonymousTypeCode() Allocate a name to an anonymous type. It's important that the name allocated should be repeatable, because it can be referenced as a type annotation in a SEF document.- Returns:
- the name code of the allocated name
 
 - 
processMaxOccurspublic int processMaxOccurs(java.lang.String attValue) throws SchemaExceptionProcess the value of a maxOccurs attribute on any element where it appears- Parameters:
- attValue- the value of the attribute as written, either "unbounded" or an integer
- Returns:
- the value of the attribute as an integer, or -1 indicating "unbounded"
- Throws:
- SchemaException- if the value is invalid (in which case the error will have been reported). If the value is a very high integer (greater than Integer.MAX_VALUE), the method outputs a warning and treats the value as "unbounded".
 
 - 
processMinOccurspublic int processMinOccurs(java.lang.String attValue) throws SchemaExceptionProcess the value of a minOccurs attribute on any element where it appears- Parameters:
- attValue- the value of the attribute as written, an integer
- Returns:
- the value of the attribute as an integer
- Throws:
- SchemaException- if the value is invalid (in which case the error will have been reported). If the value is a very high integer (greater than Integer.MAX_VALUE), the method outputs a warning and treats the value as Integer.MAX_VALUE.
 
 - 
checkContentModelprotected void checkContentModel(int[][] stateTerms, int[][] stateTargets, boolean allowWildcards) throws SchemaExceptionCheck the content model of an element in the schema. This uses a finite state machine generated into the Java source code by applying an XSLT transformation to the schema component model for the Schema for Schemas.The finite state machine is generated as follows: First process the S4S to create an SCM model, then apply the stylesheet generate-S4S-code in the build directory with type=complexType, for example. The value of the type parameter can be either the name of the type or its ID in the SCM file. - Parameters:
- stateTerms- an array of states, and for each state, an array containing the fingerprints of elements allowed to appear in that state
- stateTargets- an array of states, and for each state, an array containing the destinations of transitions when the corresponding term from stateTerms is encountered
- allowWildcards-
- Throws:
- SchemaException- if the schema being processed does not conform to the required content model
 
 - 
isFinalStateprotected boolean isFinalState(int state) For elements whose content model is parsed using a finite state machine, test whether a given state is a final state. The default implementation of this method is never used; it exists for the benefit of subclasses that do not use this mechanism- Parameters:
- state- the state to be tested
- Returns:
- true if the given state is a final state
 
 - 
processAllowedNamespacesprotected void processAllowedNamespaces(java.lang.String attValue, Wildcard wildcard) throws SchemaExceptionProcess the namespaces attribute of XSDAny or XSDAnyAttribute- Parameters:
- attValue- the value of the attribute
- wildcard- the wildcard object being constructed
- Throws:
- SchemaException- if the attribute is in error
 
 - 
processDisallowedNamespacesprotected void processDisallowedNamespaces(java.lang.String attValue, Wildcard wildcard) throws SchemaExceptionProcess the notNamespaces attribute of XSDAny or XSDAnyAttribute- Parameters:
- attValue- the value of the attribute
- wildcard- the wildcard object being constructed
- Throws:
- SchemaException- if the attribute is in error
 
 - 
processDisallowedQNamesprotected void processDisallowedQNames(java.lang.String attValue, Wildcard wildcard) throws SchemaExceptionProcess the notQNames attribute of XSDAny or XSDAnyAttribute- Parameters:
- attValue- the value of the attribute
- wildcard- the wildcard object being constructed
- Throws:
- SchemaException- if the attribute is in error
 
 - 
checkLocalTargetNamespacepublic void checkLocalTargetNamespace(java.lang.String elementOrAttribute) throws SchemaExceptionFor an element or attribute declaration with a targetNamespace attribute (XSD 1.1), check the highly-paternalistic rules for when this attribute is permitted.- Parameters:
- elementOrAttribute- the string "element" or "attribute" for error messages
- Throws:
- SchemaException- if the rules are not satisfied
 
 
- 
 
-