Modifier and Type | Field and Description |
---|---|
private int | |
private boolean | |
private boolean | fStreamAdvancedByHasNext
the very issue around a long discussion. |
private StreamFilter | |
private XMLStreamReader |
Access | Constructor and Description |
---|---|
public | XMLStreamFilterImpl(XMLStreamReader
the reader to filter reader, StreamFilter the filter to apply to the reader filter)Creates a new instance of XMLStreamFilterImpl, advancing the reader to the next event accepted by the filter, if not already positioned on an accepted event. |
Modifier and Type | Method and Description |
---|---|
public void | close()
Implements javax. Frees any resources associated with this Reader. |
private int | |
private int | |
public int | getAttributeCount()
Implements javax. Returns the count of attributes on this START_ELEMENT, this method is only valid on a START_ELEMENT or ATTRIBUTE. |
public String | getAttributeLocalName(int index)
Implements javax. Returns the localName of the attribute at the provided index |
public QName | getAttributeName(int index)
Implements javax. Returns the qname of the attribute at the provided index |
public String | getAttributeNamespace(int index)
Implements javax. Returns the namespace of the attribute at the provided index |
public String | getAttributePrefix(int index)
Implements javax. Returns the prefix of this attribute at the provided index |
public String | getAttributeType(int index)
Implements javax. Returns the XML type of the attribute at the provided index |
public String | getAttributeValue(int index)
Implements javax. Returns the value of the attribute at the index |
public String | getAttributeValue(String namespaceURI, String localName)
Implements javax. Returns the normalized attribute value of the attribute with the namespace and localName If the namespaceURI is null the namespace is not checked for equality |
public String | getCharacterEncodingScheme()
Implements javax. Returns the character encoding declared on the xml declaration Returns null if none was declared |
public String | getElementText()
Implements javax. Reads the content of a text-only element, an exception is thrown if this is not a text-only element. |
public String | getEncoding()
Implements javax. Return input encoding if known or null if unknown. |
public int | getEventType()
Implements javax. Returns an integer code that indicates the type of the event the cursor is pointing to. |
public String | getLocalName()
Implements javax. Returns the (local) name of the current event. |
public Location | getLocation()
Implements javax. Return the current location of the processor. |
public QName | getName()
Implements javax. Returns a QName for the current START_ELEMENT or END_ELEMENT event |
public NamespaceContext | getNamespaceContext()
Implements javax. Returns a read only namespace context for the current position. |
public int | getNamespaceCount()
Implements javax. Returns the count of namespaces declared on this START_ELEMENT or END_ELEMENT, this method is only valid on a START_ELEMENT, END_ELEMENT or NAMESPACE. |
public String | getNamespacePrefix(int index)
Implements javax. Returns the prefix for the namespace declared at the index. |
public String | getNamespaceURI()
Implements javax. If the current event is a START_ELEMENT or END_ELEMENT this method returns the URI of the prefix or the default namespace. |
public String | getNamespaceURI(int index)
Implements javax. Returns the uri for the namespace declared at the index. |
public String | getNamespaceURI(String prefix)
Implements javax. Return the uri for the given prefix. |
public String | getPIData()
Implements javax. Get the data section of a processing instruction |
public String | getPITarget()
Implements javax. Get the target of a processing instruction |
public String | getPrefix()
Implements javax. Returns the prefix of the current event or null if the event does not have a prefix |
public Object | getProperty(String name)
Implements javax. Get the value of a feature/property from the underlying implementation |
public String | getText()
Implements javax. Returns the current value of the parse event as a string, this returns the string value of a CHARACTERS event, returns the value of a COMMENT, the replacement value for an ENTITY_REFERENCE, the string value of a CDATA section, the string value for a SPACE event, or the String value of the internal subset of the DTD. |
public char[] | getTextCharacters()
Implements javax. Returns an array which contains the characters from this event. |
public int | getTextCharacters(int sourceStart, char[] target, int targetStart, int length)
Implements javax. Gets the text associated with a CHARACTERS, SPACE or CDATA event. |
public int | getTextLength()
Implements javax. Returns the length of the sequence of characters for this Text event within the text character array. |
public int | getTextStart()
Implements javax. Returns the offset into the text character array where the first character (of this text event) is stored. |
public String | getVersion()
Implements javax. Get the xml version declared on the xml declaration Returns null if none was declared |
public boolean | hasName()
Implements javax. returns a boolean indicating whether the current event has a name (is a START_ELEMENT or END_ELEMENT). |
public boolean | hasNext()
Implements javax. Returns true if there are more parsing events and false if there are no more events. |
public boolean | hasText()
Implements javax. Return a boolean indicating whether the current event has text. |
public boolean | isAttributeSpecified(int index)
Implements javax. Returns a boolean which indicates if this attribute was created by default |
public boolean | isCharacters()
Implements javax. Returns true if the cursor points to a character data event |
public boolean | isEndElement()
Implements javax. Returns true if the cursor points to an end tag (otherwise false) |
public boolean | isStandalone()
Implements javax. Get the standalone declaration from the xml declaration |
public boolean | isStartElement()
Implements javax. Returns true if the cursor points to a start tag (otherwise false) |
public boolean | isWhiteSpace()
Implements javax. Returns true if the cursor points to a character data event that consists of all whitespace |
public int | next()
Implements javax. Get next parsing event - a processor may return all contiguous character data in a single chunk, or it may split it into several chunks. |
public int | nextTag()
Implements javax. Skips any white space (isWhiteSpace() returns true), COMMENT, or PROCESSING_INSTRUCTION, until a START_ELEMENT or END_ELEMENT is reached. |
public void | require(int type, String namespaceURI, String localName)
Implements javax. Test if the current event is of the given type and if the namespace and name match the current namespace and name of the current event. |
protected void | |
public boolean | standaloneSet()
Implements javax. Checks if standalone was set in the document |
fCurrentEvent | back to summary |
---|---|
private int fCurrentEvent |
fEventAccepted | back to summary |
---|---|
private boolean fEventAccepted |
fStreamAdvancedByHasNext | back to summary |
---|---|
private boolean fStreamAdvancedByHasNext the very issue around a long discussion. but since we must pass the TCK, we have to allow hasNext() to advance the underlining stream in order to find the next acceptable event |
fStreamFilter | back to summary |
---|---|
private StreamFilter fStreamFilter |
fStreamReader | back to summary |
---|---|
private XMLStreamReader fStreamReader |
XMLStreamFilterImpl | back to summary |
---|---|
public XMLStreamFilterImpl(XMLStreamReader reader, StreamFilter filter) throws XMLStreamException Creates a new instance of XMLStreamFilterImpl, advancing the reader to the next event accepted by the filter, if not already positioned on an accepted event.
|
close | back to summary |
---|---|
public void close() throws XMLStreamException Implements javax. Doc from javax. Frees any resources associated with this Reader. This method does not close the underlying input source.
|
findNextEvent | back to summary |
---|---|
private int findNextEvent() throws XMLStreamException |
findNextTag | back to summary |
---|---|
private int findNextTag() throws XMLStreamException |
getAttributeCount | back to summary |
---|---|
public int getAttributeCount() Implements javax. Doc from javax. Returns the count of attributes on this START_ELEMENT, this method is only valid on a START_ELEMENT or ATTRIBUTE. This count excludes namespace definitions. Attribute indices are zero-based. |
getAttributeLocalName | back to summary |
---|---|
public String getAttributeLocalName(int index) Implements javax. Doc from javax. Returns the localName of the attribute at the provided index |
getAttributeName | back to summary |
---|---|
public QName getAttributeName(int index) Implements javax. Doc from javax. Returns the qname of the attribute at the provided index |
getAttributeNamespace | back to summary |
---|---|
public String getAttributeNamespace(int index) Implements javax. Doc from javax. Returns the namespace of the attribute at the provided index |
getAttributePrefix | back to summary |
---|---|
public String getAttributePrefix(int index) Implements javax. Doc from javax. Returns the prefix of this attribute at the provided index |
getAttributeType | back to summary |
---|---|
public String getAttributeType(int index) Implements javax. Doc from javax. Returns the XML type of the attribute at the provided index |
getAttributeValue | back to summary |
---|---|
public String getAttributeValue(int index) Implements javax. Doc from javax. Returns the value of the attribute at the index |
getAttributeValue | back to summary |
---|---|
public String getAttributeValue(String namespaceURI, String localName) Implements javax. Doc from javax. Returns the normalized attribute value of the attribute with the namespace and localName If the namespaceURI is null the namespace is not checked for equality |
getCharacterEncodingScheme | back to summary |
---|---|
public String getCharacterEncodingScheme() Implements javax. Doc from javax. Returns the character encoding declared on the xml declaration Returns null if none was declared |
getElementText | back to summary |
---|---|
public String getElementText() throws XMLStreamException Implements javax. Doc from javax. Reads the content of a text-only element, an exception is thrown if this is not a text-only element. Regardless of value of javax.xml.stream.isCoalescing this method always returns coalesced content. Precondition the current event is START_ELEMENT.
if(getEventType() != XMLStreamConstants.START_ELEMENT) { throw new XMLStreamException( "parser must be on START_ELEMENT to read next text", getLocation()); } int eventType = next(); StringBuffer content = new StringBuffer(); while(eventType != XMLStreamConstants.END_ELEMENT) { if(eventType == XMLStreamConstants.CHARACTERS || eventType == XMLStreamConstants.CDATA || eventType == XMLStreamConstants.SPACE || eventType == XMLStreamConstants.ENTITY_REFERENCE) { buf.append(getText()); } else if(eventType == XMLStreamConstants.PROCESSING_INSTRUCTION || eventType == XMLStreamConstants.COMMENT) { // skipping } else if(eventType == XMLStreamConstants.END_DOCUMENT) { throw new XMLStreamException( "unexpected end of document when reading element text content", this); } else if(eventType == XMLStreamConstants.START_ELEMENT) { throw new XMLStreamException( "element text content may not contain START_ELEMENT", getLocation()); } else { throw new XMLStreamException( "Unexpected event type "+eventType, getLocation()); } eventType = next(); } return buf.toString();
|
getEncoding | back to summary |
---|---|
public String getEncoding() Implements javax. Doc from javax. Return input encoding if known or null if unknown. |
getEventType | back to summary |
---|---|
public int getEventType() Implements javax. Doc from javax. Returns an integer code that indicates the type of the event the cursor is
pointing to. The initial event type is |
getLocalName | back to summary |
---|---|
public String getLocalName() Implements javax. Doc from javax. Returns the (local) name of the current event. For START_ELEMENT or END_ELEMENT returns the (local) name of the current element. For ENTITY_REFERENCE it returns entity name. The current event must be START_ELEMENT or END_ELEMENT, or ENTITY_REFERENCE |
getLocation | back to summary |
---|---|
public Location getLocation() Implements javax. Doc from javax. Return the current location of the processor. If the Location is unknown the processor should return an implementation of Location that returns -1 for the location and null for the publicId and systemId. The location information is only valid until next() is called. |
getName | back to summary |
---|---|
public QName getName() Implements javax. Doc from javax. Returns a QName for the current START_ELEMENT or END_ELEMENT event |
getNamespaceContext | back to summary |
---|---|
public NamespaceContext getNamespaceContext() Implements javax. Doc from javax. Returns a read only namespace context for the current position. The context is transient and only valid until a call to next() changes the state of the reader. |
getNamespaceCount | back to summary |
---|---|
public int getNamespaceCount() Implements javax. Doc from javax. Returns the count of namespaces declared on this START_ELEMENT or END_ELEMENT, this method is only valid on a START_ELEMENT, END_ELEMENT or NAMESPACE. On an END_ELEMENT the count is of the namespaces that are about to go out of scope. This is the equivalent of the information reported by SAX callback for an end element event. |
getNamespacePrefix | back to summary |
---|---|
public String getNamespacePrefix(int index) Implements javax. Doc from javax. Returns the prefix for the namespace declared at the index. Returns null if this is the default namespace declaration |
getNamespaceURI | back to summary |
---|---|
public String getNamespaceURI() Implements javax. Doc from javax. If the current event is a START_ELEMENT or END_ELEMENT this method returns the URI of the prefix or the default namespace. Returns null if the event does not have a prefix. |
getNamespaceURI | back to summary |
---|---|
public String getNamespaceURI(int index) Implements javax. Doc from javax. Returns the uri for the namespace declared at the index. |
getNamespaceURI | back to summary |
---|---|
public String getNamespaceURI(String prefix) Implements javax. Doc from javax. Return the uri for the given prefix. The uri returned depends on the current state of the processor. Note The 'xml' prefix is bound as defined in Namespaces in XML specification to "http://www.w3.org/XML/1998/namespace". Note The 'xmlns' prefix must be resolved to following namespace http://www.w3.org/2000/xmlns/ |
getPIData | back to summary |
---|---|
public String getPIData() Implements javax. Doc from javax. Get the data section of a processing instruction |
getPITarget | back to summary |
---|---|
public String getPITarget() Implements javax. Doc from javax. Get the target of a processing instruction |
getPrefix | back to summary |
---|---|
public String getPrefix() Implements javax. Doc from javax. Returns the prefix of the current event or null if the event does not have a prefix |
getProperty | back to summary |
---|---|
public Object getProperty(String name) throws IllegalArgumentException Implements javax. Doc from javax. Get the value of a feature/property from the underlying implementation
|
getText | back to summary |
---|---|
public String getText() Implements javax. Doc from javax. Returns the current value of the parse event as a string, this returns the string value of a CHARACTERS event, returns the value of a COMMENT, the replacement value for an ENTITY_REFERENCE, the string value of a CDATA section, the string value for a SPACE event, or the String value of the internal subset of the DTD. If an ENTITY_REFERENCE has been resolved, any character data will be reported as CHARACTERS events. |
getTextCharacters | back to summary |
---|---|
public char[] getTextCharacters() Implements javax. Doc from javax. Returns an array which contains the characters from this event. This array should be treated as read-only and transient. I.e. the array will contain the text characters until the XMLStreamReader moves on to the next event. Attempts to hold onto the character array beyond that time or modify the contents of the array are breaches of the contract for this interface. |
getTextCharacters | back to summary |
---|---|
public int getTextCharacters(int sourceStart, char[] target, int targetStart, int length) throws XMLStreamException Implements javax. Doc from javax. Gets the text associated with a CHARACTERS, SPACE or CDATA event. Text starting a "sourceStart" is copied into "target" starting at "targetStart". Up to "length" characters are copied. The number of characters actually copied is returned. The "sourceStart" argument must be greater or equal to 0 and less than or equal to the number of characters associated with the event. Usually, one requests text starting at a "sourceStart" of 0. If the number of characters actually copied is less than the "length", then there is no more text. Otherwise, subsequent calls need to be made until all text has been retrieved. For example:
XMLStreamException may be thrown if there are any XML errors in the underlying source.
The "targetStart" argument must be greater than or equal to 0 and less than the length of "target",
Length must be greater than 0 and "targetStart + length" must be less than or equal to length of "target".
|
getTextLength | back to summary |
---|---|
public int getTextLength() Implements javax. Doc from javax. Returns the length of the sequence of characters for this Text event within the text character array. |
getTextStart | back to summary |
---|---|
public int getTextStart() Implements javax. Doc from javax. Returns the offset into the text character array where the first character (of this text event) is stored. |
getVersion | back to summary |
---|---|
public String getVersion() Implements javax. Doc from javax. Get the xml version declared on the xml declaration Returns null if none was declared |
hasName | back to summary |
---|---|
public boolean hasName() Implements javax. Doc from javax. returns a boolean indicating whether the current event has a name (is a START_ELEMENT or END_ELEMENT). |
hasNext | back to summary |
---|---|
public boolean hasNext() throws XMLStreamException Implements javax. Doc from javax. Returns true if there are more parsing events and false if there are no more events. This method will return false if the current state of the XMLStreamReader is END_DOCUMENT
|
hasText | back to summary |
---|---|
public boolean hasText() Implements javax. Doc from javax. Return a boolean indicating whether the current event has text. The following events have text: CHARACTERS,DTD ,ENTITY_REFERENCE, COMMENT, SPACE |
isAttributeSpecified | back to summary |
---|---|
public boolean isAttributeSpecified(int index) Implements javax. Doc from javax. Returns a boolean which indicates if this attribute was created by default |
isCharacters | back to summary |
---|---|
public boolean isCharacters() Implements javax. Doc from javax. Returns true if the cursor points to a character data event |
isEndElement | back to summary |
---|---|
public boolean isEndElement() Implements javax. Doc from javax. Returns true if the cursor points to an end tag (otherwise false) |
isStandalone | back to summary |
---|---|
public boolean isStandalone() Implements javax. Doc from javax. Get the standalone declaration from the xml declaration |
isStartElement | back to summary |
---|---|
public boolean isStartElement() Implements javax. Doc from javax. Returns true if the cursor points to a start tag (otherwise false) |
isWhiteSpace | back to summary |
---|---|
public boolean isWhiteSpace() Implements javax. Doc from javax. Returns true if the cursor points to a character data event that consists of all whitespace |
next | back to summary |
---|---|
public int next() throws XMLStreamException Implements javax. Doc from javax. Get next parsing event - a processor may return all contiguous character data in a single chunk, or it may split it into several chunks. If the property javax.xml.stream.isCoalescing is set to true element content must be coalesced and only one CHARACTERS event must be returned for contiguous element content or CDATA Sections. By default entity references must be expanded and reported transparently to the application. An exception will be thrown if an entity reference cannot be expanded. If element content is empty (i.e. content is "") then no CHARACTERS event will be reported. Given the following XML: Note empty element (such as
|
nextTag | back to summary |
---|---|
public int nextTag() throws XMLStreamException Implements javax. Doc from javax. Skips any white space (isWhiteSpace() returns true), COMMENT, or PROCESSING_INSTRUCTION, until a START_ELEMENT or END_ELEMENT is reached. If other than white space characters, COMMENT, PROCESSING_INSTRUCTION, START_ELEMENT, END_ELEMENT are encountered, an exception is thrown. This method should be used when processing element-only content separated by white space. Precondition none
|
require | back to summary |
---|---|
public void require(int type, String namespaceURI, String localName) throws XMLStreamException Implements javax. Doc from javax. Test if the current event is of the given type and if the namespace and name match the current namespace and name of the current event. If the namespaceURI is null it is not checked for equality, if the localName is null it is not checked for equality.
|
setStreamFilter | back to summary |
---|---|
protected void setStreamFilter(StreamFilter sf) |
standaloneSet | back to summary |
---|---|
public boolean standaloneSet() Implements javax. Doc from javax. Checks if standalone was set in the document |