Package com.saxonica.ee.schema
Class PreparedSchema
- java.lang.Object
- 
- com.saxonica.ee.schema.SchemaStructure
- 
- com.saxonica.ee.schema.PreparedSchema
 
 
- 
- All Implemented Interfaces:
- javax.xml.transform.SourceLocator,- NotationSet,- Location,- org.xml.sax.Locator
 - Direct Known Subclasses:
- SingleNamespaceSchema
 
 public class PreparedSchema extends SchemaStructure implements NotationSet A schema is a collection of schema components. It may be derived from a single schema document (an xs:schema element), in which case it contains those components defined in that schema document, the components defined in the included documents (expanded transitively), and the components defined in imported schema documents (not expanded transitively). Alternatively, it may be a collection of schema components derived from multiple independent schema documents.All components in the schema are indexed by name. In addition, elements, attributes, and types are indexed by their integer NamePool fingerprint. Construction of the PreparedSchema is not thread-safe; all creation of new components must happen in a single thread. 
- 
- 
Field SummaryFields Modifier and Type Field Description static intNAMESPACE_KNOWNstatic intNAMESPACE_SEALEDstatic intNAMESPACE_UNDER_CONSTRUCTIONstatic intNAMESPACE_UNKNOWN
 - 
Constructor SummaryConstructors Modifier Constructor Description protectedPreparedSchema()Create a dummy schema definition.PreparedSchema(EnterpriseConfiguration config)Create a new Schema definition
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description voidaddAnonymousType(SchemaType type)Register an anonymous type defined in this schemavoidaddAttributeDecl(AttributeDecl attribute)Adds the given global attribute declaration to this Schema.voidaddAttributeGroup(AttributeGroupDecl attributeGroup)Adds the given attribute group declaration to this Schema.voidaddComponent(UserSchemaComponent obj)Add an object that might contain a forwards reference to be fixed up latervoidaddElementDecl(ElementDecl elementDecl)Adds the given global element declaration to this Schema definitionvoidaddGlobalParam(GlobalParam param)Declare a global parameter for XPath expressions in this schema document (Saxon extension)voidaddGroup(ModelGroupDefinition group)Adds the given group (xs:group) to this Schema.voidaddIdentityConstraint(IdentityConstraint constraint)Add an identity constraintvoidaddNotation(Notation notation)Adds the given Notation declaration to this Schema defintionvoidaddType(SchemaType type)Adds the given type definition to this Schema.voidcopyTo(PreparedSchema destination, SchemaCompiler compiler)Copy the components of this schema to another schemaAttributeDeclgetAttributeDecl(int fingerprint)Get the attribute declaration with a given name if there is one.AttributeDeclgetAttributeDecl(StructuredQName name)Get the attribute declaration with a given name if there is one.AttributeGroupDeclgetAttributeGroup(StructuredQName name)Get the attribute declaration with a given name if there is one.EnterpriseConfigurationgetConfiguration()Get the configurationElementDeclgetElementDecl(int fingerprint)Get the global element declaration with a given fingerprintElementDeclgetElementDecl(StructuredQName name)Get the global element declaration with a given namejava.util.Set<UserComplexType>getExtensionsOfBuiltInType(int fp)Get the set of user-defined complex types that extend a given built-in typeGlobalParamgetGlobalParam(StructuredQName name)Get the GlobalParam object representing a named parameter (Saxon extension)java.util.Collection<GlobalParam>getGlobalParams()Return the set of global parameters defined in this schema documentModelGroupDefinitiongetGroup(StructuredQName name)Get the model group with a given name if there is one.IdentityConstraintgetIdentityConstraint(StructuredQName name)Get the identity constraint whose name has a given fingerprintintgetLocalLicenseId()Get the local license id, identifying any local license in the case where this package was loaded from a compiled package that contained its own embedded licenseNamePoolgetNamePool()Get the NamePool used by this schemaNotationgetNotation(StructuredQName notationName)Get the notation with a given nameSchemaTypegetSchemaType(StructuredQName name)Get the type with a given name if there is one.SimpleTypegetSimpleType(StructuredQName name)Get the simple type with a given name if there is one.java.util.Set<java.lang.String>getTargetNamespaces()Get the set of all target namespaces of components present in this schemaSchemaTypegetType(StructuredQName name)Get type defined in this schema, searching both named and anonymous typesbooleanisDeclaredNotation(java.lang.String uri, java.lang.String local)Ask whether a given notation name is present in this set of notationsjava.util.Iterator<AttributeDecl>iterateAttributeDeclarations()Get an iterator over all the global attribute declarations defined in this schemajava.util.Iterator<AttributeGroupDecl>iterateAttributeGroups()Get an iterator over all the named attribute groups defined in this schemajava.util.Iterator<ElementDecl>iterateElementDeclarations()Get an iterator over all the global element declarations defined in this schema.java.util.Iterator<IdentityConstraint>iterateIdentityConstraints()Get an iterator over all the identity constraints defined in this schema (that is, unique, key, and keyref components).java.util.Iterator<ModelGroupDefinition>iterateModelGroups()Get an iterator over all the named model groups defined in this schemajava.util.Iterator<Notation>iterateNotations()Get an iterator over all the notations defined in this schema.java.util.Iterator<SchemaType>iterateTypes()Get an iterator over all the named simple and complex types defined in this schema.static PreparedSchemamerge(PreparedSchema ps1, PreparedSchema ps2)Merge two PreparedSchemas into one, rejecting any components that are defined in both.voidregisterExtensionOfBuiltInType(int fp, UserComplexType extension)Register a complex type that extends a built-in simple typevoidsetConfiguration(EnterpriseConfiguration config)Set the configurationvoidsetLocalLicenseId(int id)Set the local license id, identifying any local license in the case where this package was loaded from a compiled package that contained its own embedded licensebooleanvalidate(SchemaCompiler compiler)Checks the validity of this Schema definition, and if valid, adds the schema to the cache held by the EnterpriseConfigurationstatic SchemaComponentvalidateReference(ComponentReference ref, SchemaCompiler compiler, boolean fatal)Helper method to validate that a reference to a schema component can be resolved- 
Methods inherited from class com.saxonica.ee.schema.SchemaStructureelaborate, fixup, getColumnNumber, getFixupStatus, getGeneratedId, getLineNumber, getPublicId, getRedefinitionLevel, getSchemaDocumentURI, getSystemId, getValidationStatus, hasSameLocation, isValidationNeeded, lookForCycles, makeXPathExpressionPropertyRecord, saveLocation, setFixupStatus, setGeneratedId, setLineNumber, setLocator, setRedefinitionLevel, setSchemaDocumentURI, setSystemId, setValidationStatus
 
- 
 
- 
- 
- 
Field Detail- 
NAMESPACE_UNKNOWNpublic static final int NAMESPACE_UNKNOWN - See Also:
- Constant Field Values
 
 - 
NAMESPACE_UNDER_CONSTRUCTIONpublic static final int NAMESPACE_UNDER_CONSTRUCTION - See Also:
- Constant Field Values
 
 - 
NAMESPACE_KNOWNpublic static final int NAMESPACE_KNOWN - See Also:
- Constant Field Values
 
 - 
NAMESPACE_SEALEDpublic static final int NAMESPACE_SEALED - See Also:
- Constant Field Values
 
 
- 
 - 
Constructor Detail- 
PreparedSchemaprotected PreparedSchema() Create a dummy schema definition. This constructor is defined only for use by subclasses
 - 
PreparedSchemapublic PreparedSchema(EnterpriseConfiguration config) Create a new Schema definition- Parameters:
- config- The configuration object holding system configuration information
 
 
- 
 - 
Method Detail- 
setConfigurationpublic void setConfiguration(EnterpriseConfiguration config) Set the configuration- Overrides:
- setConfigurationin class- SchemaStructure
- Parameters:
- config- the Saxon configuration
 
 - 
getConfigurationpublic EnterpriseConfiguration getConfiguration() Get the configuration- Overrides:
- getConfigurationin class- SchemaStructure
- Returns:
- the Saxon configuration
 
 - 
setLocalLicenseIdpublic void setLocalLicenseId(int id) Set the local license id, identifying any local license in the case where this package was loaded from a compiled package that contained its own embedded license- Parameters:
- id- identifier used to distinguish this local license
 
 - 
getLocalLicenseIdpublic int getLocalLicenseId() Get the local license id, identifying any local license in the case where this package was loaded from a compiled package that contained its own embedded license- Returns:
- integer identifying the local license, or -1 if there is none
 
 - 
addComponentpublic void addComponent(UserSchemaComponent obj) Add an object that might contain a forwards reference to be fixed up later- Parameters:
- obj- the component to be added. The caller should ensure that the same component is not added twice.
 
 - 
getAttributeDeclpublic AttributeDecl getAttributeDecl(StructuredQName name) Get the attribute declaration with a given name if there is one.- Parameters:
- name- the name of the required attribute declaration
- Returns:
- the attribute declaration if found, or null otherwise
 
 - 
getAttributeDeclpublic AttributeDecl getAttributeDecl(int fingerprint) Get the attribute declaration with a given name if there is one.- Parameters:
- fingerprint- the NamePool fingerprint of the name of the required attribute declaration
- Returns:
- the attribute declaration if found, or null otherwise
 
 - 
iterateAttributeDeclarationspublic java.util.Iterator<AttributeDecl> iterateAttributeDeclarations() Get an iterator over all the global attribute declarations defined in this schema- Returns:
- an iterator over the attribute declarations. Each item returned by
         the iterator will be an instance of AttributeDecl
 
 - 
addAttributeDeclpublic void addAttributeDecl(AttributeDecl attribute) Adds the given global attribute declaration to this Schema. It will overwrite any existing attribute declaration with the same name.- Parameters:
- attribute- the AttributeDecl to add
 
 - 
getAttributeGrouppublic AttributeGroupDecl getAttributeGroup(StructuredQName name) Get the attribute declaration with a given name if there is one.- Parameters:
- name- the name of the required attribute group
- Returns:
- the attribute declaration if found, or null otherwise
 
 - 
iterateAttributeGroupspublic java.util.Iterator<AttributeGroupDecl> iterateAttributeGroups() Get an iterator over all the named attribute groups defined in this schema- Returns:
- an iterator over the attribute groups. Each item returned by
         the iterator will be an instance of AttributeGroupDecl
 
 - 
addAttributeGrouppublic void addAttributeGroup(AttributeGroupDecl attributeGroup) Adds the given attribute group declaration to this Schema. It will overwrite any existing attribute group declaration with the same name, unless the existing attribute has a higher redefinition level.- Parameters:
- attributeGroup- the AttributeDecl to add
 
 - 
getGrouppublic ModelGroupDefinition getGroup(StructuredQName name) Get the model group with a given name if there is one.- Parameters:
- name- the name of the required named model group
- Returns:
- the group if found, or null otherwise
 
 - 
iterateModelGroupspublic java.util.Iterator<ModelGroupDefinition> iterateModelGroups() Get an iterator over all the named model groups defined in this schema- Returns:
- an iterator over the model groups. Each item returned by
         the iterator will be an instance of ModelGroupDefinition
 
 - 
addGrouppublic void addGroup(ModelGroupDefinition group) Adds the given group (xs:group) to this Schema. It will overwrite any existing group with the same name.- Parameters:
- group- the group to add
 
 - 
getSchemaTypepublic SchemaType getSchemaType(StructuredQName name) Get the type with a given name if there is one. This method will also find built-in types.- Parameters:
- name- the name of the required schema type
- Returns:
- the named simple or complex type if found, or null otherwise
 
 - 
getSimpleTypepublic SimpleType getSimpleType(StructuredQName name) Get the simple type with a given name if there is one. This method will also find built-in types.- Parameters:
- name- the name of the required simple type
- Returns:
- the simple type if found, or null otherwise
 
 - 
iterateTypespublic java.util.Iterator<SchemaType> iterateTypes() Get an iterator over all the named simple and complex types defined in this schema. This iterator will not include built-in types or anonymous types.- Returns:
- an iterator over the types. Each item returned by
         the iterator will be an instance of SchemaType
 
 - 
addTypepublic void addType(SchemaType type) Adds the given type definition to this Schema. If another type with this name already exists, it is overwritten, unless it has a higher redefinition level- Parameters:
- type- the type to add to this Schema
 
 - 
addAnonymousTypepublic void addAnonymousType(SchemaType type) Register an anonymous type defined in this schema- Parameters:
- type- the anonymous type to be added
 
 - 
getTypepublic SchemaType getType(StructuredQName name) Get type defined in this schema, searching both named and anonymous types- Parameters:
- name- the name of the required schema type
- Returns:
- the schema type if found, else null
 
 - 
registerExtensionOfBuiltInTypepublic void registerExtensionOfBuiltInType(int fp, UserComplexType extension)Register a complex type that extends a built-in simple type- Parameters:
- fp- the fingerprint of the built-in type
- extension- the complex type that extends the built-in (directly or indirectly)
 
 - 
getExtensionsOfBuiltInTypepublic java.util.Set<UserComplexType> getExtensionsOfBuiltInType(int fp) Get the set of user-defined complex types that extend a given built-in type- Parameters:
- fp- the fingerprint of the built-in type
- Returns:
- the set of user-defined complex types that have been registered as extensions of this built-in type
 
 - 
addElementDeclpublic void addElementDecl(ElementDecl elementDecl) Adds the given global element declaration to this Schema definition- Parameters:
- elementDecl- the ElementDecl to add to this Schema
 
 - 
getElementDeclpublic ElementDecl getElementDecl(StructuredQName name) Get the global element declaration with a given name- Parameters:
- name- the name of the element
- Returns:
- the element declaration, or null if not found.
 
 - 
getElementDeclpublic ElementDecl getElementDecl(int fingerprint) Get the global element declaration with a given fingerprint- Parameters:
- fingerprint- the NamePool fingerprint of the name of the element
- Returns:
- the element declaration, or null if not found.
 
 - 
iterateElementDeclarationspublic java.util.Iterator<ElementDecl> iterateElementDeclarations() Get an iterator over all the global element declarations defined in this schema.- Returns:
- an iterator over the global element declarations. Each item returned by
         the iterator will be an instance of ElementDecl
 
 - 
addNotationpublic void addNotation(Notation notation) Adds the given Notation declaration to this Schema defintion- Parameters:
- notation- the Notation to add to this Schema
 
 - 
getNotationpublic Notation getNotation(StructuredQName notationName) Get the notation with a given name- Parameters:
- notationName- identifies the name of the notation
- Returns:
- the element notation, or null if not found.
 
 - 
iterateNotationspublic java.util.Iterator<Notation> iterateNotations() Get an iterator over all the notations defined in this schema.- Returns:
- an iterator over the notations. Each item returned by
         the iterator will be an instance of Notation
 
 - 
addIdentityConstraintpublic void addIdentityConstraint(IdentityConstraint constraint) Add an identity constraint- Parameters:
- constraint- the identity constraint to be added
 
 - 
getIdentityConstraintpublic IdentityConstraint getIdentityConstraint(StructuredQName name) Get the identity constraint whose name has a given fingerprint- Parameters:
- name- the name of the required constraint
- Returns:
- the identity constraint, or null if there is none with that name
 
 - 
iterateIdentityConstraintspublic java.util.Iterator<IdentityConstraint> iterateIdentityConstraints() Get an iterator over all the identity constraints defined in this schema (that is, unique, key, and keyref components).- Returns:
- an iterator over the identity constraints. Each item returned by
         the iterator will be an instance of IdentityConstraint
 
 - 
getTargetNamespacespublic java.util.Set<java.lang.String> getTargetNamespaces() Get the set of all target namespaces of components present in this schema- Returns:
- the set of all target namespaces for these components
 
 - 
getNamePoolpublic NamePool getNamePool() Get the NamePool used by this schema- Returns:
- the namepool
 
 - 
addGlobalParampublic void addGlobalParam(GlobalParam param) throws SchemaException Declare a global parameter for XPath expressions in this schema document (Saxon extension)- Parameters:
- param- the details of the parameter
- Throws:
- SchemaException
 
 - 
getGlobalParampublic GlobalParam getGlobalParam(StructuredQName name) Get the GlobalParam object representing a named parameter (Saxon extension)- Parameters:
- name- the parameter name
- Returns:
- the GlobalParam object if a parameter with this name exists, else null
 
 - 
getGlobalParamspublic java.util.Collection<GlobalParam> getGlobalParams() Return the set of global parameters defined in this schema document- Returns:
- the set of global parameters
 
 - 
copyTopublic void copyTo(PreparedSchema destination, SchemaCompiler compiler) throws SchemaException Copy the components of this schema to another schema- Parameters:
- destination- the destination of the copy
- compiler- used for error reporting
- Throws:
- SchemaException- if there are name clashes between this schema and the destination schema (that is, the same name used to refer to different components. Components are compared by checking their name and origin, where the origin is the SystemId and line number of the schema document from which they were initially derived)
 
 - 
validatepublic boolean validate(SchemaCompiler compiler) throws SchemaException Checks the validity of this Schema definition, and if valid, adds the schema to the cache held by the EnterpriseConfiguration- Parameters:
- compiler- a SchemaCompiler to which all errors should be reported
- Returns:
- true if validation succeeds, false if it fails
- Throws:
- SchemaException- if the SchemaCompiler decides that an error is fatal
 
 - 
validateReferencepublic static SchemaComponent validateReference(ComponentReference ref, SchemaCompiler compiler, boolean fatal) throws SchemaException Helper method to validate that a reference to a schema component can be resolved- Parameters:
- ref- The Component reference that needs to be resolved
- compiler- used for error reporting
- fatal- True if failure to resolve the reference is an error rather than a warning
- Returns:
- the target of the reference
- Throws:
- SchemaException- if the reference cannot be resolved
 
 - 
mergepublic static PreparedSchema merge(PreparedSchema ps1, PreparedSchema ps2) throws SchemaException Merge two PreparedSchemas into one, rejecting any components that are defined in both.- Parameters:
- ps1- the first PreparedSchema
- ps2- the second PreparedSchema
- Returns:
- the merged PreparedSchema
- Throws:
- SchemaException- if there are inconsistencies between the two schemas, for example different components with the same name
 
 - 
isDeclaredNotationpublic boolean isDeclaredNotation(java.lang.String uri, java.lang.String local)Description copied from interface:NotationSetAsk whether a given notation name is present in this set of notations- Specified by:
- isDeclaredNotationin interface- NotationSet
- Parameters:
- uri- the URI part of the notation name
- local- the local part of the notation name
- Returns:
- true if the notation name is present
 
 
- 
 
-