public class XSDSchema extends SchemaElement
SchemaElement.XPathStaticContext
NAMESPACE_ANY, NAMESPACE_LOCAL, NAMESPACE_OTHER, NAMESPACE_TARGET, REQUIRE_NULL_NS, REQUIRE_TARGET_NS, USE_DEFAULT_NS, USE_DEFAULT_NS_WITHOUT_IMPORT
NODE_LETTER
ALL_NAMESPACES, IS_DTD_TYPE, IS_NILLED, LOCAL_NAMESPACES, NO_NAMESPACES
Constructor and Description |
---|
XSDSchema()
Create an XSDSchema object, representing the xs:schema element in a schema document
|
Modifier and Type | Method and Description |
---|---|
protected void |
addChild(NodeImpl node,
int index)
Add a child node to this node.
|
void |
addGlobalParam(GlobalParam param)
Declare a global parameter for XPath expressions in this schema document (Saxon extension)
|
void |
compact(int size)
Compact the space used by this node
|
boolean |
defaultOpenContentAppliesToEmpty()
Ask if the default open content wildcard applies to types that would otherwise
have an EMPTY content model
|
Set<String> |
getAllowedExtensions()
Get the set of extensions allowed in this schema document
|
String |
getAttributeFormDefault()
Returns the attributeFormDefault property of this Schema.
|
int |
getBlockDefault()
Returns the default BlockList for this Schema.
|
AttributeGroupReference |
getDefaultAttributeGroupReference()
Get a reference to the default attribute group
|
String |
getDefaultOpenContentMode()
Get the default open content mode, as a string (interleave or suffix)
|
Wildcard |
getDefaultOpenContentWildcard()
Get the default open content wildcard, if any
|
String |
getElementFormDefault()
Returns the elementFormDefault property of this Schema.
|
int |
getErrorCount()
Get the number of errors detected in this schema document
|
Executable |
getExecutable()
Get the Executable corresponding to this schema document.
|
int |
getFinalDefault()
Returns the default value of "final" for this Schema.
|
NodeImpl |
getFirstChild()
Get the first child node of the element
|
GlobalParam |
getGlobalParam(StructuredQName name)
Get the GlobalParam object representing a named parameter (Saxon extension)
|
Collection<GlobalParam> |
getGlobalParams()
Return the set of global parameters defined in this schema document
|
NodeImpl |
getLastChild()
Get the last child node of the element
|
protected NodeImpl |
getNthChild(int n)
Get the nth child node of the element (numbering from 0)
|
int |
getNumberOfChildren()
Determine how many children the node has
|
protected int |
getRawSequenceNumber() |
SingleNamespaceSchema |
getSchema()
Get the PreparedSchema to which schema components are being added
|
SchemaCompiler |
getSchemaCompiler()
Get the SchemaCompiler in use
|
protected long |
getSequenceNumber()
Get the node sequence number (in document order).
|
String |
getStringValue()
Return the string-value of the node, that is, the concatenation
of the character content of all descendent elements and text nodes.
|
CharSequence |
getStringValueCS()
Get the value of the item as a CharSequence.
|
String |
getTargetNamespace()
Get the target namespace of this schema document.
|
String |
getXPathDefaultNamespace()
Get the value of the defaultXPathDefaultNamespace attribute defined on this element
|
boolean |
hasChildNodes()
Determine if the node has any children.
|
void |
incrementErrorCount()
Increment the number of errors detected in this schema document
|
void |
insertChildren(NodeInfo[] source,
boolean atStart,
boolean inherit)
Insert a sequence of nodes as children of this node.
|
protected void |
insertChildrenAt(NodeInfo[] source,
int index,
boolean inherit)
Insert children before or after a given existing child
|
boolean |
isChameleon()
Determine if this is a chameleon schema document, that is, one with no targetNamespace
of its own, whose effective target namespace (and for many purposes, default namespace)
are set to the targetNamespace of the referring schema document.
|
protected 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.
|
boolean |
isImportedNamespace(String uri)
Determine whether a given URI is that of a namespace that has been imported into this
schema document.
|
protected AxisIterator |
iterateChildren(NodeTest test)
Get an enumeration of the children of this node
|
void |
postValidate(SchemaCompiler compiler)
Process child elements after validation
|
void |
prepareAttributes()
Validate and process the attributes on this element in the schema document
|
protected void |
removeChild(NodeImpl child)
Remove a given child
|
protected void |
replaceChildrenAt(NodeInfo[] source,
int index,
boolean inherit)
Replace child at a given index by new children
|
void |
setAttributeFormDefault(String attributeFormDefault)
Sets the attributeFormDefault property of this Schema.
|
void |
setBlockDefault(int value)
Sets the default Block values for this Schema.
|
protected void |
setChildren(Object children)
Set the children of this node
|
void |
setDefaultOpenContent(Wildcard wildcard,
String mode,
boolean appliesToEmpty)
Set the open content wildcard and mode
|
void |
setElementFormDefault(String elementFormDefault)
Sets the elementFormDefault property of this Schema.
|
void |
setFinalDefault(int value)
Set the default "final" list for this Schema.
|
protected void |
setRawSequenceNumber(int seq) |
void |
setReferrer(SchemaElement referrer)
Set the xs:include, xs:import, or xs:redefine element that caused this schema document to be loaded
|
void |
setSchema(SingleNamespaceSchema schema)
Set the SingleNamespaceSchema to which schema components are being added
|
void |
setSchemaCompiler(SchemaCompiler manager)
Set the SchemaCompiler in use
|
void |
validate(SchemaCompiler compiler)
Validate this schema element, checking all document-level constraints
|
protected void |
validateChildren(SchemaCompiler compiler)
Validate the children of this node, recursively.
|
allocateAnonymousTypeCode, allowAttributes, checkContentModel, checkLocalTargetNamespace, checkMutuallyExclusiveAttributes, checkOnlyChildIsAnnotation, checkPermittedType, duplicate, duplicateElement, error, error, getContainingComplexType, getContainingSimpleType, getFingerprint, getNameCode, getSchemaNodeFactory, getXSDSchema, illegalElement, indefiniteArticle, invalidAttributeValue, isTopLevel, makeNamespaceContext, missingAttribute, missingChildElement, mustBeFirstElement, mustBeLastElement, mustPrecede, mutuallyExclusive, mutuallyExclusiveAttributes, mutuallyExclusiveElementAndAttribute, parseBooleanAttribute, parseFinalOrBlock, processAllAttributes, processAllowedNamespaces, processDisallowedNamespaces, processDisallowedQNames, processId, processMaxOccurs, processMinOccurs, requireAttribute, setSchemaNodeFactory, validateSubtree, warning
addAttribute, addNamespace, copy, delete, fixupInsertedNamespaces, generateId, getAttributeList, getAttributeValue, getAttributeValue, getBaseURI, getColumnNumber, getDeclaredNamespaces, getDocumentRoot, getLineNumber, getNameCode, getNamespaceList, getNodeKind, getRoot, getSchemaType, getSystemId, getTypeAnnotation, getURIForPrefix, gsetAttributeCollection, initialise, isId, isInScopeNamespace, isNilled, iteratePrefixes, removeAttribute, removeTypeAnnotation, rename, replaceStringValue, setAttributeList, setLocation, setNameCode, setNamespaceDeclarations, setNamespaceList, setSystemId, setTypeAnnotation
atomize, compareOrder, comparePosition, equals, getConfiguration, getDisplayName, getDocumentNumber, getFingerprint, getLocalPart, getNamePool, getNextInDocument, getNextSibling, getParent, getPhysicalRoot, getPrefix, getPreviousInDocument, getPreviousSibling, getPublicId, getRawParent, getSiblingPosition, getSuccessorElement, getURI, head, insertSiblings, isDeleted, isIdref, isSameNodeInfo, iterate, iterateAxis, iterateAxis, newBuilder, replace, setRawParent, setSiblingPosition
public XSDSchema()
public SingleNamespaceSchema getSchema()
getSchema
in class SchemaElement
public Executable getExecutable()
public Set<String> getAllowedExtensions()
public void setSchema(SingleNamespaceSchema schema)
schema
- the SingleNamespaceSchema containing the compiled schema componentspublic void setSchemaCompiler(SchemaCompiler manager)
manager
- the schema compilerpublic SchemaCompiler getSchemaCompiler()
public void setReferrer(SchemaElement referrer)
referrer
- the referring xs:include, xs:import, or xs:redefine elementpublic boolean isChameleon()
public void prepareAttributes() throws SchemaException
prepareAttributes
in class SchemaElement
SchemaException
- if any errors are found in the attributespublic boolean isImportedNamespace(String uri)
uri
- the namespace URI ("" for the null namespace)public void validate(SchemaCompiler compiler) throws SchemaException
validate
in class SchemaElement
compiler
- used for reporting errorsSchemaException
- if any XML representation constraints are violatedprotected void validateChildren(SchemaCompiler compiler) throws SchemaException
validateChildren
in class SchemaElement
compiler
- used for error reportingSchemaException
- if the subtree is not validprotected boolean isFinalState(int state)
SchemaElement
isFinalState
in class SchemaElement
state
- the state to be testedpublic void postValidate(SchemaCompiler compiler) throws SchemaException
postValidate
in class SchemaElement
compiler
- used for reporting errorsSchemaException
- if errors are foundpublic String getTargetNamespace()
public String getAttributeFormDefault()
public int getBlockDefault()
public String getElementFormDefault()
public int getFinalDefault()
public Wildcard getDefaultOpenContentWildcard()
public String getDefaultOpenContentMode()
public boolean defaultOpenContentAppliesToEmpty()
public void setAttributeFormDefault(String attributeFormDefault)
attributeFormDefault
- the Form value of the attributeFormDefault
property for this Schema, as a string, "qualified" or "unqualified".
The caller is responsible for validating the value.public void setBlockDefault(int value)
value
- the default Block values to set for this Schema, as
a bit-significant integer.public void setElementFormDefault(String elementFormDefault)
elementFormDefault
- the Form value of the elementFormDefault
property for this Schema.public void setFinalDefault(int value)
value
- the default final values to set for this Schema, as a bit-significant
integerpublic void setDefaultOpenContent(Wildcard wildcard, String mode, boolean appliesToEmpty)
wildcard
- the default open content wildcardmode
- the default open content mode, as a stringappliesToEmpty
- true if the default open content wildcard applies to types that would otherwise
have variety emptypublic String getXPathDefaultNamespace()
public AttributeGroupReference getDefaultAttributeGroupReference()
public int getErrorCount()
public void incrementErrorCount()
public void addGlobalParam(GlobalParam param) throws SchemaException
param
- the details of the parameterSchemaException
- if the variable name is a duplicatepublic GlobalParam getGlobalParam(StructuredQName name)
name
- the parameter namepublic Collection<GlobalParam> getGlobalParams()
protected final long getSequenceNumber()
getSequenceNumber
in class NodeImpl
protected final int getRawSequenceNumber()
protected final void setRawSequenceNumber(int seq)
protected final void setChildren(Object children)
children
- null if there are no children, a single NodeInfo if there is one child, an array of NodeInfo
if there are multiple childrenpublic final boolean hasChildNodes()
hasChildNodes
in interface NodeInfo
hasChildNodes
in class NodeImpl
true
if the node has any children,
false
if the node has no children.public final int getNumberOfChildren()
protected final AxisIterator iterateChildren(NodeTest test)
test
- A NodeTest to be satisfied by the child nodes, or null
if all child node are to be returnedpublic final NodeImpl getFirstChild()
getFirstChild
in interface SteppingNode<NodeImpl>
getFirstChild
in class NodeImpl
public final NodeImpl getLastChild()
getLastChild
in class NodeImpl
protected final NodeImpl getNthChild(int n)
n
- identifies the required childprotected void removeChild(NodeImpl child)
child
- the child to be removedpublic String getStringValue()
Item.getStringValueCS()
public CharSequence getStringValueCS()
NodeImpl
getStringValueCS
in interface Item
getStringValueCS
in class NodeImpl
Item.getStringValue()
protected void addChild(NodeImpl node, int index)
node
- the node to be added as a child of this node. This must be an instance of
NodeImpl
. It will be modified as a result of this call (by setting its
parent property and sibling position)index
- the position where the child is to be addedpublic void insertChildren(NodeInfo[] source, boolean atStart, boolean inherit)
This method takes no action unless the target node is a document node or element node. It also takes no action in respect of any supplied nodes that are not elements, text nodes, comments, or processing instructions.
The supplied nodes will form the new children. Adjacent text nodes will be merged, and zero-length text nodes removed. The supplied nodes may be modified in situ, for example to change their parent property and to add namespace bindings, or they may be copied, at the discretion of the implementation.
insertChildren
in interface MutableNodeInfo
insertChildren
in class NodeImpl
source
- the nodes to be inserted. The implementation determines what implementation classes
of node it will accept; this implementation will accept text, comment, and processing instruction
nodes belonging to any implementation, but elements must be instances of ElementImpl
.
The supplied nodes will be modified in situ, for example
to change their parent property and to add namespace bindings, if they are instances of
ElementImpl
; otherwise they will be copied. If the nodes are copied, then on return
the supplied source array will contain the copy rather than the original.atStart
- true if the new nodes are to be inserted before existing children; false if they are
to be inserted after existing childreninherit
- true if the inserted nodes are to inherit the namespaces of their new parent; false
if such namespaces are to be undeclaredIllegalArgumentException
- if the supplied nodes use a node implementation that this
implementation does not accept.protected void insertChildrenAt(NodeInfo[] source, int index, boolean inherit)
source
- the children to be inserted. We allow any kind of text, comment, or processing instruction
node, but element nodes must be instances of this NodeInfo implementation.index
- the position before which they are to be inserted: 0 indicates insertion before the
first child, 1 insertion before the second child, and so on.inherit
- true if the inserted nodes are to inherit the namespaces that are in-scope for their
new parent; false if such namespaces should be undeclared on the childrenprotected void replaceChildrenAt(NodeInfo[] source, int index, boolean inherit)
source
- the children to be insertedindex
- the position at which they are to be inserted: 0 indicates replacement of the
first child, replacement of the second child, and so on. The effect is undefined if index
is out of rangeinherit
- set to true if the new child elements are to inherit the in-scope namespaces
of their new parentIllegalArgumentException
- if any of the replacement nodes is not an element, text,
comment, or processing instruction nodepublic void compact(int size)
size
- the number of actual childrenCopyright (c) 2004-2014 Saxonica Limited. All rights reserved.