public abstract class DTDParser extends XMLGrammarParser implements XMLDTDHandler, XMLDTDContentModelHandler
Modifier and Type | Field and Description |
---|---|
protected XMLDTDScanner |
fDTDScanner
fDTDScanner
|
fDatatypeValidatorFactory
ENTITY_RESOLVER, ERROR_HANDLER, fConfiguration
CONDITIONAL_IGNORE, CONDITIONAL_INCLUDE
OCCURS_ONE_OR_MORE, OCCURS_ZERO_OR_MORE, OCCURS_ZERO_OR_ONE, SEPARATOR_CHOICE, SEPARATOR_SEQUENCE
Constructor and Description |
---|
DTDParser(SymbolTable symbolTable) |
Modifier and Type | Method and Description |
---|---|
void |
attributeDecl(String elementName,
String attributeName,
String type,
String[] enumeration,
String defaultType,
XMLString defaultValue,
XMLString nonNormalizedDefaultValue,
Augmentations augmentations)
An attribute declaration.
|
void |
childrenElement(String elementName)
A referenced element in a children content model.
|
void |
childrenEndGroup()
The end of a children group.
|
void |
childrenOccurrence(short occurrence)
The occurrence count for a child in a children content model.
|
void |
childrenSeparator(short separator)
The separator between choices or sequences of a children content
model.
|
void |
childrenStartGroup()
The start of a children group.
|
void |
comment(XMLString text,
Augmentations augmentations)
A comment.
|
void |
elementDecl(String name,
String contentModel,
Augmentations augmentations)
An element declaration.
|
void |
endAttlist(Augmentations augmentations)
The end of an attribute list.
|
void |
endConditional(Augmentations augmentations)
The end of a conditional section.
|
void |
endContentModel()
The end of a content model.
|
void |
endDTD(Augmentations augmentations)
The end of the DTD.
|
void |
endEntity(String name,
Augmentations augmentations)
This method notifies the end of an entity.
|
void |
endExternalSubset(Augmentations augmentations)
The end of the external subset.
|
void |
externalEntityDecl(String name,
XMLResourceIdentifier identifier,
Augmentations augmentations)
An external entity declaration.
|
DTDGrammar |
getDTDGrammar()
getDTDGrammar
|
void |
internalEntityDecl(String name,
XMLString text,
XMLString nonNormalizedText,
Augmentations augmentations)
An internal entity declaration.
|
void |
mixedElement(String elementName)
A referenced element in a mixed content model.
|
void |
notationDecl(String name,
XMLResourceIdentifier identifier,
Augmentations augmentations)
A notation declaration
|
void |
processingInstruction(String target,
XMLString data,
Augmentations augmentations)
A processing instruction.
|
void |
startAttlist(String elementName,
Augmentations augmentations)
The start of an attribute list.
|
void |
startConditional(short type,
Augmentations augmentations)
The start of a conditional section.
|
void |
startContentModel(String elementName,
short type)
The start of a content model.
|
void |
startDTD(XMLLocator locator,
Augmentations augmentations)
The start of the DTD.
|
void |
startEntity(String name,
String publicId,
String systemId,
String encoding)
This method notifies of the start of an entity.
|
void |
startExternalSubset(XMLResourceIdentifier identifier,
Augmentations augmentations)
The start of the external subset.
|
void |
textDecl(String version,
String encoding)
Notifies of the presence of a TextDecl line in an entity.
|
void |
unparsedEntityDecl(String name,
XMLResourceIdentifier identifier,
String notation,
Augmentations augmentations)
An unparsed entity declaration.
|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
endParameterEntity, getDTDSource, ignoredCharacters, setDTDSource, startParameterEntity, textDecl
any, element, empty, endContentModel, endGroup, getDTDContentModelSource, occurrence, pcdata, separator, setDTDContentModelSource, startContentModel, startGroup
protected XMLDTDScanner fDTDScanner
public DTDParser(SymbolTable symbolTable)
symbolTable
- public DTDGrammar getDTDGrammar()
public void startEntity(String name, String publicId, String systemId, String encoding) throws XNIException
Note: Since the DTD is an entity, the handler will be notified of the start of the DTD entity by calling the startEntity method with the entity name "[dtd]" before calling the startDTD method.
name
- The name of the entity.publicId
- The public identifier of the entity if the entity
is external, null otherwise.systemId
- The system identifier of the entity if the entity
is external, null otherwise.encoding
- The auto-detected IANA encoding name of the entity
stream. This value will be null in those situations
where the entity encoding is not auto-detected (e.g.
internal parameter entities).XNIException
- Thrown by handler to signal an error.public void textDecl(String version, String encoding) throws XNIException
Note: This method is only called for external parameter entities referenced in the DTD.
version
- The XML version, or null if not specified.encoding
- The IANA encoding name of the entity.XNIException
- Thrown by handler to signal an error.public void startDTD(XMLLocator locator, Augmentations augmentations) throws XNIException
startDTD
in interface XMLDTDHandler
locator
- The document locator, or null if the document
location cannot be reported during the parsing of
the document DTD. However, it is strongly
recommended that a locator be supplied that can
at least report the base system identifier of the
DTD.augmentations
- Additional information that may include infoset
augmentations.XNIException
- Thrown by handler to signal an error.public void comment(XMLString text, Augmentations augmentations) throws XNIException
comment
in interface XMLDTDHandler
text
- The text in the comment.augmentations
- Additional information that may include infoset
augmentations.XNIException
- Thrown by application to signal an error.public void processingInstruction(String target, XMLString data, Augmentations augmentations) throws XNIException
Typically, a processing instruction's data will contain a series of pseudo-attributes. These pseudo-attributes follow the form of element attributes but are not parsed or presented to the application as anything other than text. The application is responsible for parsing the data.
processingInstruction
in interface XMLDTDHandler
target
- The target.data
- The data or null if none specified.augmentations
- Additional information that may include infoset
augmentations.XNIException
- Thrown by handler to signal an error.public void startExternalSubset(XMLResourceIdentifier identifier, Augmentations augmentations) throws XNIException
startExternalSubset
in interface XMLDTDHandler
identifier
- The resource identifier.augmentations
- Additional information that may include infoset
augmentations.XNIException
- Thrown by handler to signal an error.public void endExternalSubset(Augmentations augmentations) throws XNIException
endExternalSubset
in interface XMLDTDHandler
augmentations
- Additional information that may include infoset
augmentations.XNIException
- Thrown by handler to signal an error.public void elementDecl(String name, String contentModel, Augmentations augmentations) throws XNIException
elementDecl
in interface XMLDTDHandler
name
- The name of the element.contentModel
- The element content model.augmentations
- Additional information that may include infoset
augmentations.XNIException
- Thrown by handler to signal an error.public void startAttlist(String elementName, Augmentations augmentations) throws XNIException
startAttlist
in interface XMLDTDHandler
elementName
- The name of the element that this attribute
list is associated with.augmentations
- Additional information that may include infoset
augmentations.XNIException
- Thrown by handler to signal an error.public void attributeDecl(String elementName, String attributeName, String type, String[] enumeration, String defaultType, XMLString defaultValue, XMLString nonNormalizedDefaultValue, Augmentations augmentations) throws XNIException
attributeDecl
in interface XMLDTDHandler
elementName
- The name of the element that this attribute
is associated with.attributeName
- The name of the attribute.type
- The attribute type. This value will be one of
the following: "CDATA", "ENTITY", "ENTITIES",
"ENUMERATION", "ID", "IDREF", "IDREFS",
"NMTOKEN", "NMTOKENS", or "NOTATION".enumeration
- If the type has the value "ENUMERATION", this
array holds the allowed attribute values;
otherwise, this array is null.defaultType
- The attribute default type. This value will be
one of the following: "#FIXED", "#IMPLIED",
"#REQUIRED", or null.defaultValue
- The attribute default value, or null if no
default value is specified.nonNormalizedDefaultValue
- The attribute default value with no normalization
performed, or null if no default value is specified.augmentations
- Additional information that may include infoset
augmentations.XNIException
- Thrown by handler to signal an error.public void endAttlist(Augmentations augmentations) throws XNIException
endAttlist
in interface XMLDTDHandler
augmentations
- Additional information that may include infoset
augmentations.XNIException
- Thrown by handler to signal an error.public void internalEntityDecl(String name, XMLString text, XMLString nonNormalizedText, Augmentations augmentations) throws XNIException
internalEntityDecl
in interface XMLDTDHandler
name
- The name of the entity. Parameter entity names start with
'%', whereas the name of a general entity is just the
entity name.text
- The value of the entity.nonNormalizedText
- The non-normalized value of the entity. This
value contains the same sequence of characters that was in
the internal entity declaration, without any entity
references expanded.augmentations
- Additional information that may include infoset
augmentations.XNIException
- Thrown by handler to signal an error.public void externalEntityDecl(String name, XMLResourceIdentifier identifier, Augmentations augmentations) throws XNIException
externalEntityDecl
in interface XMLDTDHandler
name
- The name of the entity. Parameter entity names start
with '%', whereas the name of a general entity is just
the entity name.identifier
- An object containing all location information
pertinent to this entity.augmentations
- Additional information that may include infoset
augmentations.XNIException
- Thrown by handler to signal an error.public void unparsedEntityDecl(String name, XMLResourceIdentifier identifier, String notation, Augmentations augmentations) throws XNIException
unparsedEntityDecl
in interface XMLDTDHandler
name
- The name of the entity.identifier
- An object containing all location information
pertinent to this entity.notation
- The name of the notation.augmentations
- Additional information that may include infoset
augmentations.XNIException
- Thrown by handler to signal an error.public void notationDecl(String name, XMLResourceIdentifier identifier, Augmentations augmentations) throws XNIException
notationDecl
in interface XMLDTDHandler
name
- The name of the notation.identifier
- An object containing all location information
pertinent to this notation.augmentations
- Additional information that may include infoset
augmentations.XNIException
- Thrown by handler to signal an error.public void startConditional(short type, Augmentations augmentations) throws XNIException
startConditional
in interface XMLDTDHandler
type
- The type of the conditional section. This value will
either be CONDITIONAL_INCLUDE or CONDITIONAL_IGNORE.augmentations
- Additional information that may include infoset
augmentations.XNIException
- Thrown by handler to signal an error.XMLDTDHandler.CONDITIONAL_INCLUDE
,
XMLDTDHandler.CONDITIONAL_IGNORE
public void endConditional(Augmentations augmentations) throws XNIException
endConditional
in interface XMLDTDHandler
augmentations
- Additional information that may include infoset
augmentations.XNIException
- Thrown by handler to signal an error.public void endDTD(Augmentations augmentations) throws XNIException
endDTD
in interface XMLDTDHandler
augmentations
- Additional information that may include infoset
augmentations.XNIException
- Thrown by handler to signal an error.public void endEntity(String name, Augmentations augmentations) throws XNIException
Note: Since the DTD is an entity, the handler will be notified of the end of the DTD entity by calling the endEntity method with the entity name "[dtd]" after calling the endDTD method.
name
- The name of the entity.XNIException
- Thrown by handler to signal an error.public void startContentModel(String elementName, short type) throws XNIException
elementName
- The name of the element.type
- The content model type.XNIException
- Thrown by handler to signal an error.XMLElementDecl.TYPE_EMPTY
,
XMLElementDecl.TYPE_ANY
,
XMLElementDecl.TYPE_MIXED
,
XMLElementDecl.TYPE_CHILDREN
public void mixedElement(String elementName) throws XNIException
Note: This method is only called after a call to the startContentModel method where the type is TYPE_MIXED.
elementName
- The name of the referenced element.XNIException
- Thrown by handler to signal an error.XMLElementDecl.TYPE_MIXED
public void childrenStartGroup() throws XNIException
Note: This method is only called after a call to the startContentModel method where the type is TYPE_CHILDREN.
Note: Children groups can be nested and have associated occurrence counts.
XNIException
- Thrown by handler to signal an error.XMLElementDecl.TYPE_CHILDREN
public void childrenElement(String elementName) throws XNIException
elementName
- The name of the referenced element.XNIException
- Thrown by handler to signal an error.XMLElementDecl.TYPE_CHILDREN
public void childrenSeparator(short separator) throws XNIException
Note: This method is only called after a call to the startContentModel method where the type is TYPE_CHILDREN.
separator
- The type of children separator.XNIException
- Thrown by handler to signal an error.XMLDTDContentModelHandler.SEPARATOR_CHOICE
,
XMLDTDContentModelHandler.SEPARATOR_SEQUENCE
,
XMLElementDecl.TYPE_CHILDREN
public void childrenOccurrence(short occurrence) throws XNIException
Note: This method is only called after a call to the startContentModel method where the type is TYPE_CHILDREN.
occurrence
- The occurrence count for the last children element
or children group.XNIException
- Thrown by handler to signal an error.XMLDTDContentModelHandler.OCCURS_ZERO_OR_ONE
,
XMLDTDContentModelHandler.OCCURS_ZERO_OR_MORE
,
XMLDTDContentModelHandler.OCCURS_ONE_OR_MORE
,
XMLElementDecl.TYPE_CHILDREN
public void childrenEndGroup() throws XNIException
Note: This method is only called after a call to the startContentModel method where the type is TYPE_CHILDREN.
XNIException
XMLElementDecl.TYPE_CHILDREN
public void endContentModel() throws XNIException
XNIException
- Thrown by handler to signal an error.Copyright © 2019 JBoss by Red Hat. All rights reserved.