Class Cursor
- All Implemented Interfaces:
XmlCursor,XmlTokenSource
public final class Cursor extends Object implements XmlCursor
-
Nested Class Summary
Nested classes/interfaces inherited from interface org.apache.xmlbeans.XmlCursor
XmlCursor.ChangeStamp, XmlCursor.TokenType, XmlCursor.XmlBookmark, XmlCursor.XmlMark -
Constructor Summary
-
Method Summary
Modifier and Type Method Description boolean___toNextSibling()void_addToSelection()void_beginElement(String localName)void_beginElement(String localName, String uri)void_beginElement(QName name)void_clearBookmark(Object key)void_clearSelections()int_comparePosition(Cursor other)int_copyChars(int cch, Cursor to)boolean_copyXml(Cursor to)boolean_copyXmlContents(Cursor to)XmlCursor.TokenType_currentTokenType()void_dispose()XmlDocumentProperties_documentProperties()void_dump()XmlCursor_execQuery(String query)XmlCursor_execQuery(String query, XmlOptions options)void_getAllBookmarkRefs(Collection listToFill)void_getAllNamespaces(Map<String,String> addToThis)String_getAttributeText(QName attrName)XmlCursor.XmlBookmark_getBookmark(Object key)String_getChars()int_getChars(char[] buf, int off, int cch)XmlCursor.ChangeStamp_getDocChangeStamp()Node_getDomNode()QName_getName()XmlObject_getObject()int_getSelectionCount()String_getTextValue()int_getTextValue(char[] chars, int offset, int max)boolean_hasNextSelection()boolean_hasNextToken()boolean_hasPrevToken()void_insertAttribute(String localName)void_insertAttribute(String localName, String uri)void_insertAttribute(QName name)void_insertAttributeWithValue(String localName, String value)void_insertAttributeWithValue(String localName, String uri, String value)void_insertAttributeWithValue(QName name, String text)void_insertChars(String text)void_insertComment(String text)void_insertElement(String localName)void_insertElement(String localName, String uri)void_insertElement(QName name)void_insertElementWithText(String localName, String text)void_insertElementWithText(String localName, String uri, String text)void_insertElementWithText(QName name, String text)void_insertNamespace(String prefix, String namespace)void_insertProcInst(String target, String text)boolean_isAnyAttr()boolean_isAtSamePositionAs(Cursor other)boolean_isAttr()boolean_isComment()boolean_isContainer()boolean_isEnd()boolean_isEnddoc()boolean_isFinish()boolean_isLeftOf(Cursor other)boolean_isNamespace()boolean_isProcinst()boolean_isRightOf(Cursor other)boolean_isStart()boolean_isStartdoc()boolean_isText()Object_monitor()int_moveChars(int cch, Cursor to)boolean_moveXml(Cursor to)boolean_moveXmlContents(Cursor to)String_namespaceForPrefix(String prefix)XmlCursor_newCursor()Node_newDomNode()Node_newDomNode(XmlOptions options)InputStream_newInputStream()InputStream_newInputStream(XmlOptions options)Reader_newReader()Reader_newReader(XmlOptions options)XMLStreamReader_newXMLStreamReader()XMLStreamReader_newXMLStreamReader(XmlOptions options)boolean_pop()String_prefixForNamespace(String ns)XmlCursor.TokenType_prevTokenType()void_push()boolean_removeAttribute(QName attrName)int_removeChars(int cch)boolean_removeXml()boolean_removeXmlContents()void_save(File file)void_save(File file, XmlOptions options)void_save(OutputStream os)void_save(OutputStream os, XmlOptions options)void_save(Writer w)void_save(Writer w, XmlOptions options)void_save(ContentHandler ch, LexicalHandler lh)void_save(ContentHandler ch, LexicalHandler lh, XmlOptions options)void_selectPath(String path)void_selectPath(String pathExpr, XmlOptions options)boolean_setAttributeText(QName attrName, String value)void_setBookmark(XmlCursor.XmlBookmark bookmark)void_setName(QName name)void_setTextValue(char[] sourceChars, int offset, int length)void_setTextValue(String text)boolean_toBookmark(XmlCursor.XmlBookmark bookmark)boolean_toChild(int index)boolean_toChild(String local)boolean_toChild(String uri, String local)boolean_toChild(QName name)boolean_toChild(QName name, int index)boolean_toCursor(Cursor other)void_toEndDoc()XmlCursor.TokenType_toEndToken()boolean_toFirstAttribute()boolean_toFirstChild()XmlCursor.TokenType_toFirstContentToken()boolean_toLastAttribute()boolean_toLastChild()boolean_toNextAttribute()XmlCursor.XmlBookmark_toNextBookmark(Object key)int_toNextChar(int maxCharacterCount)boolean_toNextSelection()boolean_toNextSibling(String name)boolean_toNextSibling(String uri, String local)boolean_toNextSibling(QName name)XmlCursor.TokenType_toNextToken()boolean_toParent()boolean_toPrevAttribute()XmlCursor.XmlBookmark_toPrevBookmark(Object key)int_toPrevChar(int maxCharacterCount)boolean_toPrevSibling()XmlCursor.TokenType_toPrevToken()boolean_toSelection(int i)void_toStartDoc()String_xmlText()String_xmlText(XmlOptions options)voidaddToSelection()Appends the current location of the cursor to the selection.voidbeginElement(String localName)Inserts a new element around this cursor, giving the element the specified local name.voidbeginElement(String localName, String uri)Inserts a new element around this cursor, giving the element the specified local name and associating it with the specified namespace.voidbeginElement(QName name)Inserts a new element around this cursor, giving the element the specified qualified name.voidclearBookmark(Object key)Clears the bookmark whose key is specified, if the bookmark exists at this cursor's location.voidclearSelections()Clears this cursor's selection, but does not modify the document.intcomparePosition(XmlCursor xOther)Returns an integer indicating whether this cursor is before, after, or at the same position as the specified cursor.intcopyChars(int cch, XmlCursor xTo)Copies characters to the position immediately after the specified cursor.booleancopyXml(XmlCursor xTo)Copies the XML immediately after this cursor to the location specified by the toHere cursor.booleancopyXmlContents(XmlCursor xTo)Copies the contents of the container (STARTDOC OR START) immediately to the right of the cursor to the location specified by the toHere cursor.XmlCursor.TokenTypecurrentTokenType()Returns the type of the current token.voiddispose()Deallocates resources needed to manage the cursor, rendering this cursor inoperable.XmlDocumentPropertiesdocumentProperties()Returns the XmlDocumentProperties object for the document this token source is associated with.voiddump()Prints to stdout the state of the document in which this token source is positioned.voiddump(PrintStream o)XmlCursorexecQuery(String query)Executes the specified XQuery expression against the XML this cursor is in.XmlCursorexecQuery(String query, XmlOptions options)Executes the specified XQuery expression against the XML this cursor is in, and using the specified options.voidgetAllBookmarkRefs(Collection listToFill)Retrieves all the bookmarks at this location, adding them to the specified collection.voidgetAllNamespaces(Map<String,String> addToThis)Adds to the specified map, all the namespaces in scope at the container where this cursor is positioned.StringgetAttributeText(QName attrName)When at a START or STARTDOC, returns the attribute text for the given attribute.XmlCursor.XmlBookmarkgetBookmark(Object key)Retrieves the bookmark with the specified key at this cursor's location.StringgetChars()Returns characters to the right of the cursor up to the next token.intgetChars(char[] chars, int offset, int cch)Copies characters up to the specified maximum number, counting right from this cursor's location to the character at maxCharacterCount.XmlCursor.ChangeStampgetDocChangeStamp()Returns the current change stamp for the document the current cursor is in.NodegetDomNode()Returns a W3C DOM Node containing the XML represented by this source.QNamegetName()Returns the name of the current token.org.apache.xmlbeans.impl.store.Locale.ChangeListenergetNextChangeListener()XmlObjectgetObject()Returns the strongly-typed XmlObject at the current START, STARTDOC, or ATTR.intgetSelectionCount()Returns the count of the current selection.StringgetTextValue()Gets the text value of the current document, element, attribute, comment, procinst or text token.intgetTextValue(char[] chars, int offset, int cch)Copies the text value of the current document, element, attribute, comment, processing instruction or text token, counting right from this cursor's location up to maxCharacterCount, and copies the returned text into returnedChars.booleanhasNextSelection()Returns whether or not there is a next selection.booleanhasNextToken()True if there is a next token.booleanhasPrevToken()True if there is a previous token.voidinsertAttribute(String localName)Inserts a new attribute immediately before this cursor's location, giving it the specified local name.voidinsertAttribute(String localName, String uri)Inserts a new attribute immediately before this cursor's location, giving it the specified local name and associating it with the specified namespace.voidinsertAttribute(QName name)Inserts a new attribute immediately before this cursor's location, giving it the specified name.voidinsertAttributeWithValue(String name, String value)Inserts a new attribute immediately before this cursor's location, giving it the specified value and name.voidinsertAttributeWithValue(String name, String uri, String value)Inserts an attribute immediately before the cursor's location, giving it the specified name and value, and associating it with the specified namespace.voidinsertAttributeWithValue(QName name, String value)Inserts an attribute immediately before the cursor's location, giving it the specified name and value.voidinsertChars(String text)Inserts the specified text immediately before this cursor's location.voidinsertComment(String text)Inserts an XML comment immediately before the cursor's location, giving it the specified content.voidinsertElement(String localName)Inserts an element immediately before this cursor's location, giving the element the specified local name.voidinsertElement(String localName, String uri)Inserts a new element immediately before this cursor's location, giving the element the specified local name and associating it with specified namespacevoidinsertElement(QName name)Inserts an element immediately before this cursor's location, giving the element the specified qualified name.voidinsertElementWithText(String localName, String text)Inserts a new element immediately before this cursor's location, giving the element the specified local name and content.voidinsertElementWithText(String localName, String uri, String text)Inserts a new element immediately before this cursor's location, giving the element the specified local name, associating it with the specified namespace, and giving it the specified content.voidinsertElementWithText(QName name, String text)Inserts a new element immediately before this cursor's location, giving the element the specified qualified name and content.voidinsertNamespace(String prefix, String namespace)Inserts a namespace declaration immediately before the cursor's location, giving it the specified prefix and URI.voidinsertProcInst(String target, String text)Inserts an XML processing instruction immediately before the cursor's location, giving it the specified target and text.booleanisAnyAttr()True if this token is any attribute.booleanisAtSamePositionAs(XmlCursor xOther)Determines if this cursor is at the same position as the specified cursor.booleanisAttr()True if this token is an ATTR token type, meaning just before an attribute.booleanisComment()True if this token is a COMMENT token type, meaning just before a comment.booleanisContainer()True if this token is a container token.booleanisEnd()True if this token is an END token type, meaning just before an element's end.booleanisEnddoc()True if this token is an ENDDOC token type, meaning at the very end of the document.booleanisFinish()True if this token is a finish token.booleanisInSameDocument(XmlCursor xOther)Determines if the specified cursor is in the same document as this cursor.booleanisLeftOf(XmlCursor xOther)Determines if this cursor is to the left of (or before) the specified cursor.booleanisNamespace()True if this token is a NAMESPACE token type, meaning just before a namespace declaration.booleanisProcinst()True if this token is a PROCINST token type, meaning just before a processing instruction.booleanisRightOf(XmlCursor xOther)Determines if this cursor is to the right of (or after) the specified cursor.booleanisStart()True if this token is a START token type, meaning just before an element's start.booleanisStartdoc()True if the current token is a STARTDOC token type, meaning at the very root of the document.booleanisText()True if the this token is a TEXT token type, meaning just before or inside text.Objectmonitor()Returns the synchronization object for the document.intmoveChars(int cch, XmlCursor xTo)Moves characters immediately after this cursor to the position immediately after the specified cursor.booleanmoveXml(XmlCursor xTo)Moves the XML immediately after this cursor to the location specified by the toHere cursor, shifting XML at that location to the right to make room.booleanmoveXmlContents(XmlCursor xTo)Moves the contents of the container (STARTDOC OR START) immediately after this cursor to the location specified by the toHere cursor.StringnamespaceForPrefix(String prefix)Returns the namespace URI indicated by the given prefix.XmlCursornewCursor()Returns a new XML cursor.static XmlCursornewCursor(org.apache.xmlbeans.impl.store.Xobj x, int p)NodenewDomNode()Returns a W3C DOM Node containing the XML represented by this source.NodenewDomNode(XmlOptions options)Just like newDomNode() but with options.InputStreamnewInputStream()Returns a new stream containing standard XML text, encoded according to the given encoding.InputStreamnewInputStream(XmlOptions options)Just like newInputStream(String encoding) but with options.ReadernewReader()Returns a new character reader containing XML text.ReadernewReader(XmlOptions options)Just like newReader() but with options.XMLStreamReadernewXMLStreamReader()Returns a new XMLStreamReader.XMLStreamReadernewXMLStreamReader(XmlOptions options)Returns a new XMLStreamReader.voidnotifyChange()booleanpop()Restores the cursor location most recently saved with the push() method.StringprefixForNamespace(String namespaceURI)Returns a prefix that can be used to indicate a namespace URI.XmlCursor.TokenTypeprevTokenType()Returns the type of the previous token.voidpush()Saves the current location of this cursor on an internal stack of saved positions (independent of selection).booleanremoveAttribute(QName attrName)When at a START or STARTDOC, removes the attribute with the given name.intremoveChars(int cch)Removes characters up to the specified maximum number, counting right from this cursor's location to the character at maxCharacterCount.booleanremoveXml()Removes the XML that is immediately after this cursor.booleanremoveXmlContents()Removes the contents of the container (STARTDOC OR START) immediately after this cursor.voidsave(File file)Writes the XML represented by this source to the given File.voidsave(File file, XmlOptions options)Writes the XML represented by this source to the given File.voidsave(OutputStream os)Writes the XML represented by this source to the given output stream.voidsave(OutputStream os, XmlOptions options)Writes the XML represented by this source to the given output stream.voidsave(Writer w)Writes the XML represented by this source to the given output.voidsave(Writer w, XmlOptions options)Writes the XML represented by this source to the given output.voidsave(ContentHandler ch, LexicalHandler lh)Writes the XML represented by this source to the given SAX content and lexical handlers.voidsave(ContentHandler ch, LexicalHandler lh, XmlOptions options)Writes the XML represented by this source to the given SAX content and lexical handlers.voidselectPath(String path)Executes the specified XPath expression against the XML that this cursor is in.voidselectPath(String path, XmlOptions options)Executes the specified XPath expression against the XML that this cursor is in.booleansetAttributeText(QName attrName, String value)When at a START or STARTDOC, sets the attribute text for the given attribute.voidsetBookmark(XmlCursor.XmlBookmark bookmark)Sets a bookmark to the document at this cursor's location.voidsetName(QName name)Sets the name of the current token.voidsetNextChangeListener(org.apache.xmlbeans.impl.store.Locale.ChangeListener listener)voidsetTextValue(char[] sourceChars, int offset, int length)Sets the text value of the XML at this cursor's location (if that XML's token type is START, STARTDOC, ATTR, COMMENT or PROCINST) to the contents of the specified character array.voidsetTextValue(String text)Sets the text value of the XML at this cursor's location if that XML's token type is START, STARTDOC, ATTR, COMMENT or PROCINST.booleantoBookmark(XmlCursor.XmlBookmark bookmark)Moves this cursor to the same position as the bookmark.booleantoChild(int index)Moves the cursor to the child element specified by index.booleantoChild(String name)Moves the cursor to the first child element of the specified name in no namespace.booleantoChild(String namespace, String name)Moves the cursor to the first child element of the specified name in the specified namespace.booleantoChild(QName name)Moves the cursor to the first child element of the specified qualified name.booleantoChild(QName name, int index)Moves the cursor to the specified index child element of the specified name, where that element is the .booleantoCursor(XmlCursor xOther)Moves this cursor to the same position as the moveTo cursor.voidtoEndDoc()Moves the cursor to the ENDDOC token, which is the end of the document.XmlCursor.TokenTypetoEndToken()Moves the cursor to the END or ENDDOC token corresponding to the current START or STARTDOC, and returns END or ENDDOC.booleantoFirstAttribute()Moves the cursor to the first attribute of this element, or returns false and does not move the cursor if there are no attributes.booleantoFirstChild()Moves the cursor to the first child element, or returns false and does not move the cursor if there are no element children.XmlCursor.TokenTypetoFirstContentToken()Moves the cursor to the first token in the content of the current START or STARTDOC.booleantoLastAttribute()Moves the cursor to the last attribute of this element, or returns false and does not move the cursor if there are no attributes.booleantoLastChild()Moves the cursor to the last element child, or returns false and does not move the cursor if there are no element children.booleantoNextAttribute()Moves the cursor to the next sibling attribute, or returns false and does not move the cursor if there is no next sibling attribute.XmlCursor.XmlBookmarktoNextBookmark(Object key)Moves this cursor to the location after its current position where a bookmark with the given key exists.inttoNextChar(int cch)Moves the cursor forward by the specified number of characters, and stops at the next non-TEXT token.booleantoNextSelection()Moves this cursor to the next location in the selection, if any.booleantoNextSibling()Moves the cursor to the next sibling element, or returns false and does not move the cursor if there is no next sibling element.booleantoNextSibling(String name)Moves the cursor to the next sibling element of the specified name in no namespace.booleantoNextSibling(String namespace, String name)Moves the cursor to the next sibling element of the specified name in the specified namespace.booleantoNextSibling(QName name)Moves the cursor to the next sibling element of the specified qualified name.XmlCursor.TokenTypetoNextToken()Moves the cursor to the next token.booleantoParent()Moves the cursor to the parent element or STARTDOC, or returns false and does not move the cursor if there is no parent.booleantoPrevAttribute()Moves the cursor to the previous sibling attribute, or returns false and does not move the cursor if there is no previous sibling attribute.XmlCursor.XmlBookmarktoPrevBookmark(Object key)Moves this cursor to the location before its current position where a bookmark with the given key exists.inttoPrevChar(int cch)Moves the cursor backwards by the number of characters given.booleantoPrevSibling()Moves the cursor to the previous sibling element, or returns false and does not move the cursor if there is no previous sibling element.XmlCursor.TokenTypetoPrevToken()Moves the cursor to the previous token.booleantoSelection(int i)Moves this cursor to the specified location in the selection.voidtoStartDoc()Moves the cursor to the STARTDOC token, which is the root of the document.StringxmlText()Returns standard XML text.StringxmlText(XmlOptions options)Just like xmlText() but with options.
-
Constructor Details
-
Method Details
-
dump
-
_dispose
public void _dispose() -
_newCursor
-
_getName
-
_setName
-
_currentTokenType
-
_isStartdoc
public boolean _isStartdoc() -
_isEnddoc
public boolean _isEnddoc() -
_isStart
public boolean _isStart() -
_isEnd
public boolean _isEnd() -
_isText
public boolean _isText() -
_isAttr
public boolean _isAttr() -
_isNamespace
public boolean _isNamespace() -
_isComment
public boolean _isComment() -
_isProcinst
public boolean _isProcinst() -
_isContainer
public boolean _isContainer() -
_isFinish
public boolean _isFinish() -
_isAnyAttr
public boolean _isAnyAttr() -
_toNextToken
-
_toPrevToken
-
_monitor
-
_toParent
public boolean _toParent() -
_getDocChangeStamp
-
_newXMLStreamReader
-
_newDomNode
-
_newInputStream
-
_xmlText
-
_newReader
-
_save
- Throws:
IOException
-
_save
- Throws:
IOException
-
_save
- Throws:
IOException
-
_save
- Throws:
SAXException
-
_documentProperties
-
_newXMLStreamReader
-
_xmlText
-
_newInputStream
-
_newReader
-
_save
- Throws:
SAXException
-
_save
- Throws:
IOException
-
_save
- Throws:
IOException
-
_save
- Throws:
IOException
-
_getDomNode
-
_newDomNode
-
_toCursor
-
_push
public void _push() -
_pop
public boolean _pop() -
notifyChange
public void notifyChange() -
setNextChangeListener
public void setNextChangeListener(org.apache.xmlbeans.impl.store.Locale.ChangeListener listener) -
getNextChangeListener
public org.apache.xmlbeans.impl.store.Locale.ChangeListener getNextChangeListener() -
_selectPath
-
_selectPath
-
_hasNextSelection
public boolean _hasNextSelection() -
_toNextSelection
public boolean _toNextSelection() -
_toSelection
public boolean _toSelection(int i) -
_getSelectionCount
public int _getSelectionCount() -
_addToSelection
public void _addToSelection() -
_clearSelections
public void _clearSelections() -
_namespaceForPrefix
-
_prefixForNamespace
-
_getAllNamespaces
-
_getObject
-
_prevTokenType
-
_hasNextToken
public boolean _hasNextToken() -
_hasPrevToken
public boolean _hasPrevToken() -
_toFirstContentToken
-
_toEndToken
-
_toChild
-
_toChild
-
_toChild
public boolean _toChild(int index) -
_toChild
-
_toChild
-
_toNextChar
public int _toNextChar(int maxCharacterCount) -
_toPrevChar
public int _toPrevChar(int maxCharacterCount) -
_toPrevSibling
public boolean _toPrevSibling() -
_toLastChild
public boolean _toLastChild() -
_toFirstChild
public boolean _toFirstChild() -
_toNextSibling
-
_toNextSibling
-
_toNextSibling
-
_toFirstAttribute
public boolean _toFirstAttribute() -
_toLastAttribute
public boolean _toLastAttribute() -
_toNextAttribute
public boolean _toNextAttribute() -
_toPrevAttribute
public boolean _toPrevAttribute() -
_getAttributeText
-
_setAttributeText
-
_removeAttribute
-
_getTextValue
-
_getTextValue
public int _getTextValue(char[] chars, int offset, int max) -
_setTextValue
-
_setTextValue
public void _setTextValue(char[] sourceChars, int offset, int length) -
_getChars
-
_getChars
public int _getChars(char[] buf, int off, int cch) -
_toStartDoc
public void _toStartDoc() -
_toEndDoc
public void _toEndDoc() -
_comparePosition
-
_isLeftOf
-
_isAtSamePositionAs
-
_isRightOf
-
_execQuery
-
_execQuery
-
_toBookmark
-
_toNextBookmark
-
_toPrevBookmark
-
_setBookmark
-
_getBookmark
-
_clearBookmark
-
_getAllBookmarkRefs
-
_removeXml
public boolean _removeXml() -
_moveXml
-
_copyXml
-
_removeXmlContents
public boolean _removeXmlContents() -
_moveXmlContents
-
_copyXmlContents
-
_removeChars
public int _removeChars(int cch) -
_moveChars
-
_copyChars
-
_insertChars
-
_beginElement
-
_beginElement
-
_beginElement
-
_insertElement
-
_insertElement
-
_insertElement
-
_insertElementWithText
-
_insertElementWithText
-
_insertElementWithText
-
_insertAttribute
-
_insertAttribute
-
_insertAttribute
-
_insertAttributeWithValue
-
_insertAttributeWithValue
-
_insertAttributeWithValue
-
_insertNamespace
-
_insertComment
-
_insertProcInst
-
_dump
public void _dump() -
moveXml
Description copied from interface:XmlCursorMoves the XML immediately after this cursor to the location specified by the toHere cursor, shifting XML at that location to the right to make room. For the TEXT, ATTR, NAMESPACE, COMMENT and PROCINST tokens, a single token is moved. For a start token, the element and all of its contents are moved. For all other tokens, this is a no-op.The bookmarks located in the XML that was moved also move to the new location; the cursors don't move with the content.
-
copyXml
Description copied from interface:XmlCursorCopies the XML immediately after this cursor to the location specified by the toHere cursor. For the TEXT, ATTR, NAMESPACE, COMMENT and PROCINST tokens, a single token is copied. For a start token, the element and all of its contents are copied. For all other tokens, this is a no-op.The cursors and bookmarks located in the XML that was copied are also copied to the new location.
-
moveXmlContents
Description copied from interface:XmlCursorMoves the contents of the container (STARTDOC OR START) immediately after this cursor to the location specified by the toHere cursor. For all other situations, returns false. Does not move attributes or namespaces.- Specified by:
moveXmlContentsin interfaceXmlCursor- Parameters:
xTo- The cursor at the location to which the XML should be moved.- Returns:
- true if anything was moved; otherwise, false.
-
copyXmlContents
Description copied from interface:XmlCursorCopies the contents of the container (STARTDOC OR START) immediately to the right of the cursor to the location specified by the toHere cursor. For all other situations, returns false. Does not copy attributes or namespaces.- Specified by:
copyXmlContentsin interfaceXmlCursor- Parameters:
xTo- The cursor at the location to which the XML should be copied.- Returns:
- true if anything was copied; otherwise, false.
-
moveChars
Description copied from interface:XmlCursorMoves characters immediately after this cursor to the position immediately after the specified cursor. Characters are counted to the right up to the specified maximum number. XML after the destination cursor is shifted to the right to make room. The space remaining from moving the characters collapses up to this cursor. -
copyChars
Description copied from interface:XmlCursorCopies characters to the position immediately after the specified cursor. Characters are counted to the right up to the specified maximum number. XML after the destination cursor is shifted to the right to make room. -
toCursor
Description copied from interface:XmlCursorMoves this cursor to the same position as the moveTo cursor. if the moveTo cursor is in a different document from this cursor, this cursor will not be moved, and false returned. -
isInSameDocument
Description copied from interface:XmlCursorDetermines if the specified cursor is in the same document as this cursor.- Specified by:
isInSameDocumentin interfaceXmlCursor- Parameters:
xOther- The cursor that may be in the same document as this cursor.- Returns:
- true if the specified cursor is in the same document; otherwise, false.
-
comparePosition
Description copied from interface:XmlCursorReturns an integer indicating whether this cursor is before, after, or at the same position as the specified cursor.
a.comparePosition(b) < 0means a is to the left of b.
a.comparePosition(b) == 0means a is at the same position as b.
a.comparePosition(b) > 0means a is to the right of b.
The sort order of cursors in the document is the token order. For example, if cursor "a" is at a START token and the cursor "b" is at a token within the contents of the same element, then a.comparePosition(b) will return -1, meaning that the position of a is before b.
- Specified by:
comparePositionin interfaceXmlCursor- Parameters:
xOther- The cursor whose position should be compared with this cursor.- Returns:
- 1 if this cursor is after the specified cursor; 0 if this cursor is at the same position as the specified cursor; -1 if this cursor is before the specified cursor.
-
isLeftOf
Description copied from interface:XmlCursorDetermines if this cursor is to the left of (or before) the specified cursor. Note that this is the same asa.comparePosition(b) < 0 -
isAtSamePositionAs
Description copied from interface:XmlCursorDetermines if this cursor is at the same position as the specified cursor. Note that this is the same asa.comparePosition(b) == 0- Specified by:
isAtSamePositionAsin interfaceXmlCursor- Parameters:
xOther- The cursor whose position should be compared with this cursor.- Returns:
- true if this cursor is at the same position as the specified cursor; otherwise, false.
-
isRightOf
Description copied from interface:XmlCursorDetermines if this cursor is to the right of (or after) the specified cursor. Note that this is the same asa.comparePosition(b) > 0 -
newCursor
-
dispose
public void dispose()Description copied from interface:XmlCursorDeallocates resources needed to manage the cursor, rendering this cursor inoperable. Because cursors are managed by a mechanism which stores the XML, simply letting a cursor go out of scope and having the garbage collector attempt to reclaim it may not produce desirable performance.
So, explicitly disposing a cursor allows the underlying implementation to release its responsibility of maintaining its position.
After a cursor has been disposed, it may not be used again. It can throw IllegalStateException or NullPointerException if used after disposal.
-
monitor
Description copied from interface:XmlTokenSourceReturns the synchronization object for the document. If concurrent multithreaded access to a document is required, the access should should be protected by synchronizing on this monitor() object. There is one monitor per XML document tree.- Specified by:
monitorin interfaceXmlTokenSource
-
documentProperties
Description copied from interface:XmlTokenSourceReturns the XmlDocumentProperties object for the document this token source is associated with.- Specified by:
documentPropertiesin interfaceXmlTokenSource
-
newCursor
Description copied from interface:XmlTokenSourceReturns a new XML cursor.A cursor provides random access to all the tokens in the XML data, plus the ability to extract strongly-typed XmlObjects for the data. If the data is not read-only, the XML cursor also allows modifications to the data.
Using a cursor for the first time typically forces the XML document into memory.
- Specified by:
newCursorin interfaceXmlTokenSource
-
newXMLStreamReader
Description copied from interface:XmlTokenSourceReturns a new XMLStreamReader.The stream starts at the current begin-tag or begin-document position and ends at the matching end-tag or end-document.
This is a fail-fast stream, so if the underlying data is changed while the stream is being read, the stream throws a ConcurrentModificationException.
- Specified by:
newXMLStreamReaderin interfaceXmlTokenSource
-
newXMLStreamReader
Description copied from interface:XmlTokenSourceReturns a new XMLStreamReader.The stream starts at the current begin-tag or begin-document position and ends at the matching end-tag or end-document.
This is a fail-fast stream, so if the underlying data is changed while the stream is being read, the stream throws a ConcurrentModificationException.
Throws an IllegalStateException if the XmlTokenSource is not positioned at begin-tag or begin-document (e.g., if it is at an attribute).
To specify this Use this method The character encoding to use when converting the character data in the XML to bytess. XmlOptions.setCharacterEncoding(java.lang.String)Prefix-to-namespace mappings that should be assumed when saving this XML. This is useful when the resulting XML will be part of a larger XML document, ensuring that this inner document will take advantage of namespaces defined in the outer document. XmlOptions.setSaveImplicitNamespaces(java.util.Map<java.lang.String, java.lang.String>)Suggested namespace prefixes to use when saving. Used only when a namespace attribute needs to be synthesized. XmlOptions.setSaveSuggestedPrefixes(java.util.Map<java.lang.String, java.lang.String>)That namespace attributes should occur first in elements when the XML is saved. By default, they occur last. XmlOptions.setSaveNamespacesFirst()The XML should be pretty printed when saved. Note that this should only be used for debugging. XmlOptions.setSavePrettyPrint()The number of spaces to use when indenting for pretty printing. The default is 2. XmlOptions.setSavePrettyPrintIndent(int)The additional number of spaces indented from the left for pretty printed XML. XmlOptions.setSavePrettyPrintOffset(int)To minimize the number of namespace attributes generated for the saved XML. Note that this can reduce performance significantly. XmlOptions.setSaveAggressiveNamespaces()To reduce the size of the saved document by allowing the use of the default namespace. Note that this can potentially change the semantic meaning of the XML if unprefixed QNames are present as the value of an attribute or element. XmlOptions.setUseDefaultNamespace()To filter out processing instructions with the specified target name. XmlOptions.setSaveFilterProcinst(java.lang.String)Change the QName of the synthesized root element when saving. This replaces "xml-fragment" with "fragment" in the namespace http://www.openuri.org/fragment XmlOptions.setSaveUseOpenFrag()Saving should begin on the element's contents. XmlOptions.setSaveInner()Saving should begin on the element, rather than its contents. XmlOptions.setSaveOuter()To rename the document element, or to specify the document element for this XML. XmlOptions.setSaveSyntheticDocumentElement(javax.xml.namespace.QName)- Specified by:
newXMLStreamReaderin interfaceXmlTokenSource- Parameters:
options- Any of the described options. Options map may be null.- Returns:
- A new validating XMLStreamReader.
- See Also:
XmlOptions
-
xmlText
Description copied from interface:XmlTokenSourceReturns standard XML text.The text returned represents the document contents starting at the current begin-tag or begin-document and ending at the matching end-tag or end-document. This is same content as newReader, but it is returned as a single string.
Throws an IllegalStateException if the XmlTokenSource is not positioned at begin-tag or begin-document (e.g., if it is at an attribute).
Note that this method does not produce XML with the XML declaration, including the encoding information. To save the XML declaration with the XML, see
XmlTokenSource.save(OutputStream)orXmlTokenSource.save(OutputStream, XmlOptions).- Specified by:
xmlTextin interfaceXmlTokenSource
-
newInputStream
Description copied from interface:XmlTokenSourceReturns a new stream containing standard XML text, encoded according to the given encoding.The byte stream contains contents starting at the current begin-tag or begin-document and ending at the matching end-tag or end-document. The specified encoding is used and also emitted in a PI at the beginning of the stream.
This is a fail-fast stream, so if the underlying data is changed while the stream is being read, the stream throws a ConcurrentModificationException.
Throws an IllegalStateException if the XmlTokenSource is not positioned at begin-tag or begin-document (e.g., if it is at an attribute).
- Specified by:
newInputStreamin interfaceXmlTokenSource
-
newReader
Description copied from interface:XmlTokenSourceReturns a new character reader containing XML text.The contents of the reader represents the document contents starting at the current begin-tag or begin-document and ending at the matching end-tag or end-document. No encoding annotation will be made in the text itself.
This is a fail-fast reader, so if the underlying data is changed while the reader is being read, the reader throws a ConcurrentModificationException.
Throws an IllegalStateException if the XmlTokenSource is not positioned at begin-tag or begin-document (e.g., if it is at an attribute).
- Specified by:
newReaderin interfaceXmlTokenSource
-
newDomNode
Description copied from interface:XmlTokenSourceReturns a W3C DOM Node containing the XML represented by this source. This is a copy of the XML, it is not a live with the underlying store of this token source. If this is the document node, then a Document is returned, else a DocumentFragment is returned.- Specified by:
newDomNodein interfaceXmlTokenSource
-
getDomNode
Description copied from interface:XmlTokenSourceReturns a W3C DOM Node containing the XML represented by this source. This is a live DOM node, not a copy. Any changes made through this node are immediately reflected in the document associated with this token source. Depending on the kind of token this XmlTokenSource represents, an appropriate node will be returned.- Specified by:
getDomNodein interfaceXmlTokenSource
-
save
Description copied from interface:XmlTokenSourceWrites the XML represented by this source to the given SAX content and lexical handlers. Note that this method does not save the XML declaration, including the encoding information. To save the XML declaration with the XML, seeXmlTokenSource.save(OutputStream),XmlTokenSource.save(OutputStream, XmlOptions),XmlTokenSource.save(File)orXmlTokenSource.save(File, XmlOptions).- Specified by:
savein interfaceXmlTokenSource- Throws:
SAXException
-
save
Description copied from interface:XmlTokenSourceWrites the XML represented by this source to the given File. This method will save the XML declaration, including encoding information, with the XML.- Specified by:
savein interfaceXmlTokenSource- Throws:
IOException
-
save
Description copied from interface:XmlTokenSourceWrites the XML represented by this source to the given output stream. This method will save the XML declaration, including encoding information, with the XML.- Specified by:
savein interfaceXmlTokenSource- Throws:
IOException
-
save
Description copied from interface:XmlTokenSourceWrites the XML represented by this source to the given output. Note that this method does not save the XML declaration, including the encoding information. To save the XML declaration with the XML, seeXmlTokenSource.save(OutputStream),XmlTokenSource.save(OutputStream, XmlOptions),XmlTokenSource.save(File)orXmlTokenSource.save(File, XmlOptions).- Specified by:
savein interfaceXmlTokenSource- Throws:
IOException
-
xmlText
Description copied from interface:XmlTokenSourceJust like xmlText() but with options. Options map may be null.Note that this method does not produce XML with the XML declaration, including the encoding information. To save the XML declaration with the XML, see
XmlTokenSource.save(OutputStream)orXmlTokenSource.save(OutputStream, XmlOptions).- Specified by:
xmlTextin interfaceXmlTokenSource- See Also:
XmlOptions
-
newInputStream
Description copied from interface:XmlTokenSourceJust like newInputStream(String encoding) but with options. Options map may be null.- Specified by:
newInputStreamin interfaceXmlTokenSource- See Also:
XmlOptions
-
newReader
Description copied from interface:XmlTokenSourceJust like newReader() but with options. Options map may be null.- Specified by:
newReaderin interfaceXmlTokenSource- See Also:
XmlOptions
-
newDomNode
Description copied from interface:XmlTokenSourceJust like newDomNode() but with options. Options map may be null.- Specified by:
newDomNodein interfaceXmlTokenSource- See Also:
XmlOptions
-
save
Description copied from interface:XmlTokenSourceWrites the XML represented by this source to the given SAX content and lexical handlers. Note that this method does not save the XML declaration, including the encoding information. To save the XML declaration with the XML, seeXmlTokenSource.save(OutputStream),XmlTokenSource.save(OutputStream, XmlOptions),XmlTokenSource.save(File)orXmlTokenSource.save(File, XmlOptions).- Specified by:
savein interfaceXmlTokenSource- Throws:
SAXException
-
save
Description copied from interface:XmlTokenSourceWrites the XML represented by this source to the given File. This method will save the XML declaration, including encoding information, with the XML.- Specified by:
savein interfaceXmlTokenSource- Throws:
IOException
-
save
Description copied from interface:XmlTokenSourceWrites the XML represented by this source to the given output stream. This method will save the XML declaration, including encoding information, with the XML.- Specified by:
savein interfaceXmlTokenSource- Throws:
IOException
-
save
Description copied from interface:XmlTokenSourceWrites the XML represented by this source to the given output. Note that this method does not save the XML declaration, including the encoding information. To save the XML declaration with the XML, seeXmlTokenSource.save(OutputStream),XmlTokenSource.save(OutputStream, XmlOptions),XmlTokenSource.save(File)orXmlTokenSource.save(File, XmlOptions).- Specified by:
savein interfaceXmlTokenSource- Throws:
IOException
-
push
public void push()Description copied from interface:XmlCursorSaves the current location of this cursor on an internal stack of saved positions (independent of selection). This location may be restored later by calling the pop() method. -
pop
public boolean pop()Description copied from interface:XmlCursorRestores the cursor location most recently saved with the push() method. -
selectPath
Description copied from interface:XmlCursorExecutes the specified XPath expression against the XML that this cursor is in. The cursor's position does not change. To navigate to the selections, useXmlCursor.hasNextSelection()andXmlCursor.toNextSelection()(similar toIterator).
The root referred to by the expression should be given as a dot. The following is an example path expression:
cursor.selectPath("./purchase-order/line-item");Note that this method does not support top-level XPath functions.
- Specified by:
selectPathin interfaceXmlCursor- Parameters:
path- The path expression to execute.
-
selectPath
Description copied from interface:XmlCursorExecutes the specified XPath expression against the XML that this cursor is in. The cursor's position does not change. To navigate to the selections, use hasNextSelection and toNextSelection (similar to java.util.Iterator).
The root referred to by the expression should be given as a dot. The following is an example path expression:
cursor.selectPath("./purchase-order/line-item");Note that this method does not support top-level XPath functions.
- Specified by:
selectPathin interfaceXmlCursor- Parameters:
path- The path expression to execute.options- Options for the query. For example, you can call theXmlOptions.setXqueryCurrentNodeVar(String)method to specify a particular name for the query expression variable that indicates the context node.
-
hasNextSelection
public boolean hasNextSelection()Description copied from interface:XmlCursorReturns whether or not there is a next selection.- Specified by:
hasNextSelectionin interfaceXmlCursor- Returns:
- true if there is a next selection; otherwise, false.
-
toNextSelection
public boolean toNextSelection()Description copied from interface:XmlCursorMoves this cursor to the next location in the selection, if any. See theXmlCursor.selectPath(java.lang.String)andXmlCursor.addToSelection()methods.- Specified by:
toNextSelectionin interfaceXmlCursor- Returns:
- true if the cursor moved; otherwise, false.
-
toSelection
public boolean toSelection(int i)Description copied from interface:XmlCursorMoves this cursor to the specified location in the selection. If i is less than zero or greater than or equal to the selection count, this method returns false.See also the selectPath() and addToSelection() methods.
- Specified by:
toSelectionin interfaceXmlCursor- Parameters:
i- The index of the desired location.- Returns:
- true if the cursor was moved; otherwise, false.
-
getSelectionCount
public int getSelectionCount()Description copied from interface:XmlCursorReturns the count of the current selection. See also the selectPath() and addToSelection() methods.You may experience better performance if you use the iteration model using the toNextSelection method, rather than the indexing model using the getSelectionCount and toSelection methods.
- Specified by:
getSelectionCountin interfaceXmlCursor- Returns:
- A number indicating the size of the current selection.
-
addToSelection
public void addToSelection()Description copied from interface:XmlCursorAppends the current location of the cursor to the selection. See also the selectPath() method. You can use this as an alternative to calling the selectPath method when you want to define your own selection.- Specified by:
addToSelectionin interfaceXmlCursor
-
clearSelections
public void clearSelections()Description copied from interface:XmlCursorClears this cursor's selection, but does not modify the document.- Specified by:
clearSelectionsin interfaceXmlCursor
-
toBookmark
Description copied from interface:XmlCursorMoves this cursor to the same position as the bookmark. If the bookmark is in a different document from this cursor or if the bookmark is orphaned, this cursor will not be moved, and false will be returned.- Specified by:
toBookmarkin interfaceXmlCursor- Parameters:
bookmark- The bookmark at the location to which this cursor should be moved.- Returns:
- true if the cursor moved; otherwise, false.
-
toNextBookmark
Description copied from interface:XmlCursorMoves this cursor to the location after its current position where a bookmark with the given key exists. Returns false if no such bookmark exists.- Specified by:
toNextBookmarkin interfaceXmlCursor- Parameters:
key- The key held by the next bookmark at the location to which this cursor should be moved.- Returns:
- The next corresponding bookmark, if it exists; null if there is no next bookmark with the specified key.
-
toPrevBookmark
Description copied from interface:XmlCursorMoves this cursor to the location before its current position where a bookmark with the given key exists. Returns false if no such bookmark exists.- Specified by:
toPrevBookmarkin interfaceXmlCursor- Parameters:
key- The key held by the previous bookmark at the location to which this cursor should be moved.- Returns:
- The previous corresponding bookmark, if it exists; null if there is no previous bookmark with the specified key.
-
getName
Description copied from interface:XmlCursorReturns the name of the current token. Names may be associated with START, ATTR, NAMESPACE or PROCINST. Returns null if there is no name associated with the current token. For START and ATTR, the name returned identifies the name of the element or attribute. For NAMESPACE, the local part of the name is the prefix, while the URI is the namespace defined. For PROCINST, the local part is the target and the uri is "".In the following example,
xmlObjectrepresents an XML instance whose root element is not preceded by any other XML. This code prints the root element name (here, the local name, or name without URI).XmlCursor cursor = xmlObject.newCursor(); cursor.toFirstContentToken(); String elementName = cursor.getName().getLocalPart(); System.out.println(elementName);
-
setName
Description copied from interface:XmlCursorSets the name of the current token. This token can be START, NAMESPACE, ATTR or PROCINST. -
namespaceForPrefix
Description copied from interface:XmlCursorReturns the namespace URI indicated by the given prefix. The current context must be at a START or STARTDOC. Namespace prefix mappings are queried for the mappings defined at the current container first, then parents are queried. The prefix can be "" or null to indicate a search for the default namespace. To conform with the XML spec, the default namespace will return the no-namespace ("") if it is not mapped.
Note that this queries the current state of the document. When the document is persisted, the saving mechanism may synthesize namespaces (ns1, ns2, and so on) for the purposes of persistence. These namepaces are only present in the serialized form, and are not reflected back into the document being saved.
- Specified by:
namespaceForPrefixin interfaceXmlCursor- Parameters:
prefix- The namespace prefix for the requested namespace.- Returns:
- The URI for corresponding to the specified prefix if it exists; otherwise, null.
-
prefixForNamespace
Description copied from interface:XmlCursorReturns a prefix that can be used to indicate a namespace URI. The current context must be at a START or STARTDOC. If there is an existing prefix that indicates the URI in the current context, that prefix may be returned. Otherwise, a new prefix for the URI will be defined by adding an xmlns attribute to the current container or a parent container.Note that this queries the current state of the document. When the document is persisted, the saving mechanism may synthesize namespaces (ns1, ns2, and so on) for the purposes of persistence. These namepaces are only present in the serialized form, and are not reflected back into the document being saved.
- Specified by:
prefixForNamespacein interfaceXmlCursor- Parameters:
namespaceURI- The namespace URI corresponding to the requested prefix.- Returns:
- The prefix corresponding to the specified URI if it exists; otherwise, a newly generated prefix.
-
getAllNamespaces
Description copied from interface:XmlCursorAdds to the specified map, all the namespaces in scope at the container where this cursor is positioned. This method is useful for container tokens only.- Specified by:
getAllNamespacesin interfaceXmlCursor- Parameters:
addToThis- The Map to add the namespaces to.
-
getObject
Description copied from interface:XmlCursorReturns the strongly-typed XmlObject at the current START, STARTDOC, or ATTR.
The strongly-typed object can be cast to the strongly-typed XBean interface corresponding to the XML Schema Type given by result.getSchemaType().
If a more specific type cannot be determined, an XmlObject whose schema type is anyType will be returned.
-
currentTokenType
Description copied from interface:XmlCursorReturns the type of the current token. By definition, the current token is the token immediately to the right of the cursor. If you're in the middle of text, before a character, you get TEXT. You can't dive into the text of an ATTR, COMMENT or PROCINST.
As an alternative, it may be more convenient for you to use one of the methods that test for a particular token type. These include the methods isStart(), isStartdoc(), isText(), isAttr(), and so on. Each returns a boolean value indicating whether the token that follows the cursor is the type in question.
- Specified by:
currentTokenTypein interfaceXmlCursor- Returns:
- The TokenType instance for the token at the cursor's current location.
-
isStartdoc
public boolean isStartdoc()Description copied from interface:XmlCursorTrue if the current token is a STARTDOC token type, meaning at the very root of the document.- Specified by:
isStartdocin interfaceXmlCursor- Returns:
- true if this token is a STARTDOC token type; otherwise, false.
-
isEnddoc
public boolean isEnddoc()Description copied from interface:XmlCursorTrue if this token is an ENDDOC token type, meaning at the very end of the document. -
isStart
public boolean isStart()Description copied from interface:XmlCursorTrue if this token is a START token type, meaning just before an element's start. -
isEnd
public boolean isEnd()Description copied from interface:XmlCursorTrue if this token is an END token type, meaning just before an element's end. -
isText
public boolean isText()Description copied from interface:XmlCursorTrue if the this token is a TEXT token type, meaning just before or inside text. -
isAttr
public boolean isAttr()Description copied from interface:XmlCursorTrue if this token is an ATTR token type, meaning just before an attribute. -
isNamespace
public boolean isNamespace()Description copied from interface:XmlCursorTrue if this token is a NAMESPACE token type, meaning just before a namespace declaration.- Specified by:
isNamespacein interfaceXmlCursor- Returns:
- true if this token is a NAMESPACE token type; otherwise, false.
-
isComment
public boolean isComment()Description copied from interface:XmlCursorTrue if this token is a COMMENT token type, meaning just before a comment. -
isProcinst
public boolean isProcinst()Description copied from interface:XmlCursorTrue if this token is a PROCINST token type, meaning just before a processing instruction.- Specified by:
isProcinstin interfaceXmlCursor- Returns:
- true if this token is a PROCINST token type; otherwise, false.
-
isContainer
public boolean isContainer()Description copied from interface:XmlCursorTrue if this token is a container token. The STARTDOC and START token types are containers. Containers, including documents and elements, have the same content model. In other words, a document and an element may have the same contents. For example, a document may contain attributes or text, without any child elements.- Specified by:
isContainerin interfaceXmlCursor- Returns:
- true if this token is a container token; otherwise, false.
-
isFinish
public boolean isFinish()Description copied from interface:XmlCursorTrue if this token is a finish token. A finish token can be an ENDDOC or END token type. -
isAnyAttr
public boolean isAnyAttr()Description copied from interface:XmlCursorTrue if this token is any attribute. This includes an ATTR token type and the NAMESPACE token type attribute. -
prevTokenType
Description copied from interface:XmlCursorReturns the type of the previous token. By definition, the previous token is the token immediately to the left of the cursor.
If you're in the middle of text, after a character, you get TEXT.
- Specified by:
prevTokenTypein interfaceXmlCursor- Returns:
- The TokenType instance for the token immediately before the token at the cursor's current location.
-
hasNextToken
public boolean hasNextToken()Description copied from interface:XmlCursorTrue if there is a next token. When this is false, as when the cursor is at the ENDDOC token, the toNextToken() method returns NONE and does not move the cursor.- Specified by:
hasNextTokenin interfaceXmlCursor- Returns:
- true if there is a next token; otherwise, false.
-
hasPrevToken
public boolean hasPrevToken()Description copied from interface:XmlCursorTrue if there is a previous token. When this is false, toPrevToken returns NONE and does not move the cursor.- Specified by:
hasPrevTokenin interfaceXmlCursor- Returns:
- true if there is a previous token; otherwise, false.
-
toNextToken
Description copied from interface:XmlCursorMoves the cursor to the next token. When there are no more tokens available, hasNextToken returns false and toNextToken() returns NONE and does not move the cursor. Returns the token type of the token to the right of the cursor upon a successful move.- Specified by:
toNextTokenin interfaceXmlCursor- Returns:
- The token type for the next token if the cursor was moved; otherwise, NONE.
-
toPrevToken
Description copied from interface:XmlCursorMoves the cursor to the previous token. When there is no previous token, returns NONE, otherwise returns the token to the left of the new position of the cursor.- Specified by:
toPrevTokenin interfaceXmlCursor- Returns:
- The token type for the previous token if the cursor was moved; otherwise, NONE.
-
toFirstContentToken
Description copied from interface:XmlCursorMoves the cursor to the first token in the content of the current START or STARTDOC. That is, the first token after all ATTR and NAMESPACE tokens associated with this START.
If the current token is not a START or STARTDOC, the cursor is not moved and NONE is returned. If the current START or STARTDOC has no content, the cursor is moved to the END or ENDDOC token.
- Specified by:
toFirstContentTokenin interfaceXmlCursor- Returns:
- The new current token type.
-
toEndToken
Description copied from interface:XmlCursorMoves the cursor to the END or ENDDOC token corresponding to the current START or STARTDOC, and returns END or ENDDOC.
If the current token is not a START or STARTDOC, the cursor is not moved and NONE is returned.
- Specified by:
toEndTokenin interfaceXmlCursor- Returns:
- The new current token type.
-
toNextChar
public int toNextChar(int cch)Description copied from interface:XmlCursorMoves the cursor forward by the specified number of characters, and stops at the next non-TEXT token. Returns the number of characters actually moved across, which is guaranteed to be less than or equal to maxCharacterCount. If there is no further text, or if there is no text at all, returns zero.
Note this does not dive into attribute values, comment contents, processing instruction contents, etc., but only content text.
You can pass maxCharacterCount < 0 to move over all the text to the right. This has the same effect as toNextToken, but returns the amount of text moved over.
- Specified by:
toNextCharin interfaceXmlCursor- Parameters:
cch- The maximum number of characters by which the cursor should be moved.- Returns:
- The actual number of characters by which the cursor was moved; 0 if the cursor was not moved.
-
toPrevChar
public int toPrevChar(int cch)Description copied from interface:XmlCursorMoves the cursor backwards by the number of characters given. Has similar characteristics to thetoNextCharmethod.- Specified by:
toPrevCharin interfaceXmlCursor- Parameters:
cch- The maximum number of characters by which the cursor should be moved.- Returns:
- The actual number of characters by which the cursor was moved; 0 if the cursor was not moved.
-
___toNextSibling
public boolean ___toNextSibling() -
toNextSibling
public boolean toNextSibling()Description copied from interface:XmlCursorMoves the cursor to the next sibling element, or returns false and does not move the cursor if there is no next sibling element. (By definition the position of an element is the same as the position of its START token.)If the current token is not s START, the cursor will be moved to the next START without moving out of the scope of the current element.
- Specified by:
toNextSiblingin interfaceXmlCursor- Returns:
- true if the cursor was moved; otherwise, false.
-
toPrevSibling
public boolean toPrevSibling()Description copied from interface:XmlCursorMoves the cursor to the previous sibling element, or returns false and does not move the cursor if there is no previous sibling element. (By definition the position of an element is the same as the position of its START token.)- Specified by:
toPrevSiblingin interfaceXmlCursor- Returns:
- true if the cursor was moved; otherwise, false.
-
toParent
public boolean toParent()Description copied from interface:XmlCursorMoves the cursor to the parent element or STARTDOC, or returns false and does not move the cursor if there is no parent.
Works if you're in attributes or content. Returns false only if at STARTDOC. Note that the parent of an END token is the corresponding START token.
-
toFirstChild
public boolean toFirstChild()Description copied from interface:XmlCursorMoves the cursor to the first child element, or returns false and does not move the cursor if there are no element children.
If the cursor is not currently in an element, it moves into the first child element of the next element.
- Specified by:
toFirstChildin interfaceXmlCursor- Returns:
- true if the cursor was moved; otherwise, false.
-
toLastChild
public boolean toLastChild()Description copied from interface:XmlCursorMoves the cursor to the last element child, or returns false and does not move the cursor if there are no element children.- Specified by:
toLastChildin interfaceXmlCursor- Returns:
- true if the cursor was moved; otherwise, false.
-
toChild
Description copied from interface:XmlCursorMoves the cursor to the first child element of the specified name in no namespace. -
toChild
Description copied from interface:XmlCursorMoves the cursor to the first child element of the specified name in the specified namespace. -
toChild
Description copied from interface:XmlCursorMoves the cursor to the first child element of the specified qualified name. -
toChild
public boolean toChild(int index)Description copied from interface:XmlCursorMoves the cursor to the child element specified by index. -
toChild
Description copied from interface:XmlCursorMoves the cursor to the specified index child element of the specified name, where that element is the . -
toNextSibling
Description copied from interface:XmlCursorMoves the cursor to the next sibling element of the specified name in no namespace.- Specified by:
toNextSiblingin interfaceXmlCursor- Parameters:
name- The name of the element to move the cursor to.- Returns:
- true if the cursor was moved; otherwise, false.
-
toNextSibling
Description copied from interface:XmlCursorMoves the cursor to the next sibling element of the specified name in the specified namespace.- Specified by:
toNextSiblingin interfaceXmlCursor- Parameters:
namespace- The namespace URI for the element to move the cursor to.name- The name of the element to move the cursor to.- Returns:
- true if the cursor was moved; otherwise, false.
-
toNextSibling
Description copied from interface:XmlCursorMoves the cursor to the next sibling element of the specified qualified name.- Specified by:
toNextSiblingin interfaceXmlCursor- Parameters:
name- The name of the element to move the cursor to.- Returns:
- true if the cursor was moved; otherwise, false.
-
toFirstAttribute
public boolean toFirstAttribute()Description copied from interface:XmlCursorMoves the cursor to the first attribute of this element, or returns false and does not move the cursor if there are no attributes. The order of attributes is arbitrary, but stable.
If the cursor is on a STARTDOC of a document-fragment, this method will move it to the first top level attribute if one exists.
xmlns attributes (namespace declarations) are not considered attributes by this function.
The cursor must be on a START or STARTDOC (in the case of a document fragment with top level attributes) for this method to succeed.
Example for looping through attributes:
XmlCursor cursor = ... //cursor on START or STARTDOC if (cursor.toFirstAttribute()) { do { // do something using attribute's name and value cursor.getName(); cursor.getTextValue(); } while (cursor.toNextAttribute()); }- Specified by:
toFirstAttributein interfaceXmlCursor- Returns:
- true if the cursor was moved; otherwise, false.
-
toLastAttribute
public boolean toLastAttribute()Description copied from interface:XmlCursorMoves the cursor to the last attribute of this element, or returns false and does not move the cursor if there are no attributes. The order of attributes is arbitrary, but stable.
xmlns attributes (namespace declarations) are not considered attributes by this function.
The cursor must be on a START or STARTDOC for this method to succeed.
- Specified by:
toLastAttributein interfaceXmlCursor- Returns:
- true if the cursor was moved; otherwise, false.
-
toNextAttribute
public boolean toNextAttribute()Description copied from interface:XmlCursorMoves the cursor to the next sibling attribute, or returns false and does not move the cursor if there is no next sibling attribute. The order of attributes is arbitrary, but stable.
xmlns attributes (namespace declarations) are not considered attributes by this function.
The cursor must be on an attribute for this method to succeed.
- Specified by:
toNextAttributein interfaceXmlCursor- Returns:
- true if the cursor was moved; otherwise, false.
- See Also:
XmlCursor.toFirstAttribute()
-
toPrevAttribute
public boolean toPrevAttribute()Description copied from interface:XmlCursorMoves the cursor to the previous sibling attribute, or returns false and does not move the cursor if there is no previous sibling attribute. The order of attributes is arbitrary, but stable.
xmlns attributes (namespace declarations) are not considered attributes by this function.
The cursor must be on an attribute for this method to succeed.
- Specified by:
toPrevAttributein interfaceXmlCursor- Returns:
- true if the cursor was moved; otherwise, false.
-
getAttributeText
Description copied from interface:XmlCursorWhen at a START or STARTDOC, returns the attribute text for the given attribute. When not at a START or STARTDOC or the attribute does not exist, returns null.- Specified by:
getAttributeTextin interfaceXmlCursor- Parameters:
attrName- The name of the attribute whose value is requested.- Returns:
- The attribute's value if it has one; otherwise, null.
-
setAttributeText
Description copied from interface:XmlCursorWhen at a START or STARTDOC, sets the attribute text for the given attribute. When not at a START or STARTDOC returns false. If the attribute does not exist, one is created.- Specified by:
setAttributeTextin interfaceXmlCursor- Parameters:
attrName- The name of the attribute whose value is being set.value- The new value for the attribute.- Returns:
- true if the new value was set; otherwise, false.
-
removeAttribute
Description copied from interface:XmlCursorWhen at a START or STARTDOC, removes the attribute with the given name.- Specified by:
removeAttributein interfaceXmlCursor- Parameters:
attrName- The name of the attribute that should be removed.- Returns:
- true if the attribute was removed; otherwise, false.
-
getTextValue
Description copied from interface:XmlCursorGets the text value of the current document, element, attribute, comment, procinst or text token.
When getting the text value of an element, non-text content such as comments and processing instructions are ignored and text is concatenated. For elements that have nested element children, this returns the concatenated text of all mixed content and the text of all the element children, recursing in first-to-last depthfirst order.
For attributes, including namespaces, this returns the attribute value.
For comments and processing instructions, this returns the text content of the comment or PI, not including the delimiting sequences <!-- -->, <? ?>. For a PI, the name of the PI is also not included.
The value of an empty tag is the empty string.
If the current token is END or ENDDOC, this throws an
IllegalStateException.- Specified by:
getTextValuein interfaceXmlCursor- Returns:
- The text value of the current token if the token's type is START, STARTDOC, TEXT, ATTR, COMMENT, PROCINST, or NAMESPACE; null if the type is NONE.
-
getTextValue
public int getTextValue(char[] chars, int offset, int cch)Description copied from interface:XmlCursorCopies the text value of the current document, element, attribute, comment, processing instruction or text token, counting right from this cursor's location up to maxCharacterCount, and copies the returned text into returnedChars.
When getting the text value of an element, non-text content such as comments and processing instructions are ignored and text is concatenated. For elements that have nested element children, this returns the concatenated text of all mixed content and the text of all the element children, recursing in first-to-last depthfirst order.
For attributes, including namespaces, this returns the attribute value.
For comments and processing instructions, this returns the text contents of the comment or PI, not including the delimiting sequences <!-- -->, <? ?>. For a PI, the text will not include the name of the PI.
If the current token is END or ENDDOC, this throws an
IllegalStateException.
The value of an empty tag is the empty string.
- Specified by:
getTextValuein interfaceXmlCursor- Parameters:
chars- A character array to hold the returned characters.offset- The position within returnedChars to which the first of the returned characters should be copied.cch- The maximum number of characters after this cursor's location to copy. A negative value specifies that all characters should be copied.- Returns:
- The actual number of characters copied; 0 if no characters were copied.
-
setTextValue
Description copied from interface:XmlCursorSets the text value of the XML at this cursor's location if that XML's token type is START, STARTDOC, ATTR, COMMENT or PROCINST.
For elements that have nested children this first removes all the content of the element and replaces it with the given text.
- Specified by:
setTextValuein interfaceXmlCursor- Parameters:
text- The text to use as a new value.
-
setTextValue
public void setTextValue(char[] sourceChars, int offset, int length)Description copied from interface:XmlCursorSets the text value of the XML at this cursor's location (if that XML's token type is START, STARTDOC, ATTR, COMMENT or PROCINST) to the contents of the specified character array.
For elements that have nested children this first removes all the content of the element and replaces it with the given text.
- Specified by:
setTextValuein interfaceXmlCursor- Parameters:
sourceChars- A character array containing the XML's new value.offset- The position within sourceChars from which the first of the source characters should be copied.length- The maximum number of characters to set as the XML's new value.
-
getChars
Description copied from interface:XmlCursorReturns characters to the right of the cursor up to the next token. -
getChars
public int getChars(char[] chars, int offset, int cch)Description copied from interface:XmlCursorCopies characters up to the specified maximum number, counting right from this cursor's location to the character at maxCharacterCount. The returned characters are added to returnedChars, with the first character copied to the offset position. The maxCharacterCount parameter should be less than or equal to the length of returnedChars minus offset. Copies a number of characters, which is either maxCharacterCount or the number of characters up to the next token, whichever is less.- Specified by:
getCharsin interfaceXmlCursor- Parameters:
chars- A character array to hold the returned characters.offset- The position within returnedChars at which the first of the returned characters should be added.cch- The maximum number of characters after this cursor's location to return.- Returns:
- The actual number of characters returned; 0 if no characters were returned or if the current token is not TEXT.
-
toStartDoc
public void toStartDoc()Description copied from interface:XmlCursorMoves the cursor to the STARTDOC token, which is the root of the document.- Specified by:
toStartDocin interfaceXmlCursor
-
toEndDoc
public void toEndDoc()Description copied from interface:XmlCursorMoves the cursor to the ENDDOC token, which is the end of the document. -
execQuery
Description copied from interface:XmlCursorExecutes the specified XQuery expression against the XML this cursor is in.
The query may be a String or a compiled query. You can precompile an XQuery expression using the XmlBeans.compileQuery method.
The root referred to by the expression should be given as a dot. The following is an example path expression:
XmlCursor results = cursor.execQuery("purchase-order/line-item[price <= 20.00]"); -
execQuery
Description copied from interface:XmlCursorExecutes the specified XQuery expression against the XML this cursor is in, and using the specified options.- Specified by:
execQueryin interfaceXmlCursor- Parameters:
query- The XQuery expression to execute.options- Options for the query. For example, you can call theXmlOptions.setXqueryCurrentNodeVar(String)method to specify a particular name for the query expression variable that indicates the context node.
-
getDocChangeStamp
Description copied from interface:XmlCursorReturns the current change stamp for the document the current cursor is in. This change stamp can be queried at a later point in time to find out if the document has changed.- Specified by:
getDocChangeStampin interfaceXmlCursor- Returns:
- The change stamp for the document the current cursor is in.
-
setBookmark
Description copied from interface:XmlCursorSets a bookmark to the document at this cursor's location.The bookmark is attached to the token in the tree immediately after the cursor. If the tree is manipulated to move that object to a different place, the bookmark moves with it. If the tree is manipulated to delete that token from the tree, the bookmark is orphaned. Copy operations do not copy bookmarks.
- Specified by:
setBookmarkin interfaceXmlCursor- Parameters:
bookmark- The bookmark to set.
-
getBookmark
Description copied from interface:XmlCursorRetrieves the bookmark with the specified key at this cursor's location. If there is no bookmark whose key is given by the specified key at the current position, null is returned. If thegetKeymethod is not overridden on the bookmark, then the bookmark's class is used as the key.- Specified by:
getBookmarkin interfaceXmlCursor- Parameters:
key- The key for the bookmark to retrieve.- Returns:
- The requested bookmark; null if there is no bookmark corresponding to the specified key.
-
clearBookmark
Description copied from interface:XmlCursorClears the bookmark whose key is specified, if the bookmark exists at this cursor's location.- Specified by:
clearBookmarkin interfaceXmlCursor- Parameters:
key- The for the bookmark to clear.
-
getAllBookmarkRefs
Description copied from interface:XmlCursorRetrieves all the bookmarks at this location, adding them to the specified collection. Bookmarks held by weak references are added to this collection as Weak referenced objects pointing to the bookmark.- Specified by:
getAllBookmarkRefsin interfaceXmlCursor- Parameters:
listToFill- The collection that will contain bookmarks returned by this method.
-
removeXml
public boolean removeXml()Description copied from interface:XmlCursorRemoves the XML that is immediately after this cursor.For the TEXT, ATTR, NAMESPACE, COMMENT and PROCINST tokens, a single token is removed. For a START token, the corresponding element and all of its contents are removed. For all other tokens, this is a no-op. You cannot remove a STARTDOC.
The cursors located in the XML that was removed all collapse to the same location. All bookmarks in this XML will be orphaned.
-
removeXmlContents
public boolean removeXmlContents()Description copied from interface:XmlCursorRemoves the contents of the container (STARTDOC OR START) immediately after this cursor. For all other situations, returns false. Does not remove attributes or namspaces.- Specified by:
removeXmlContentsin interfaceXmlCursor- Returns:
- true if anything was copied; otherwise, false.
-
removeChars
public int removeChars(int cch)Description copied from interface:XmlCursorRemoves characters up to the specified maximum number, counting right from this cursor's location to the character at maxCharacterCount. The space remaining from removing the characters collapses up to this cursor.- Specified by:
removeCharsin interfaceXmlCursor- Parameters:
cch- The maximum number of characters after this cursor's location to remove.- Returns:
- The actual number of characters removed.
-
insertChars
Description copied from interface:XmlCursorInserts the specified text immediately before this cursor's location.- Specified by:
insertCharsin interfaceXmlCursor- Parameters:
text- The text to insert.
-
insertElement
Description copied from interface:XmlCursorInserts an element immediately before this cursor's location, giving the element the specified qualified name.- Specified by:
insertElementin interfaceXmlCursor- Parameters:
name- The qualified name for the element.
-
insertElement
Description copied from interface:XmlCursorInserts an element immediately before this cursor's location, giving the element the specified local name.- Specified by:
insertElementin interfaceXmlCursor- Parameters:
localName- The local name for the new element.
-
insertElement
Description copied from interface:XmlCursorInserts a new element immediately before this cursor's location, giving the element the specified local name and associating it with specified namespace- Specified by:
insertElementin interfaceXmlCursor- Parameters:
localName- The local name for the new element.uri- The URI for the new element's namespace.
-
beginElement
Description copied from interface:XmlCursorInserts a new element around this cursor, giving the element the specified qualified name. After the element is inserted, this cursor is between its start and end. This cursor can then be used to insert additional XML into the new element.- Specified by:
beginElementin interfaceXmlCursor- Parameters:
name- The qualified name for the new element.
-
beginElement
Description copied from interface:XmlCursorInserts a new element around this cursor, giving the element the specified local name. After the element is inserted, this cursor is between its start and end. This cursor can then be used to insert additional XML into the new element.- Specified by:
beginElementin interfaceXmlCursor- Parameters:
localName- The local name for the new element.
-
beginElement
Description copied from interface:XmlCursorInserts a new element around this cursor, giving the element the specified local name and associating it with the specified namespace. After the element is inserted, this cursor is between its start and end. This cursor can then be used to insert additional XML into the new element.- Specified by:
beginElementin interfaceXmlCursor- Parameters:
localName- The local name for the new element.uri- The URI for the new element's namespace.
-
insertElementWithText
Description copied from interface:XmlCursorInserts a new element immediately before this cursor's location, giving the element the specified qualified name and content.- Specified by:
insertElementWithTextin interfaceXmlCursor- Parameters:
name- The qualified name for the new element.text- The content for the new element.
-
insertElementWithText
Description copied from interface:XmlCursorInserts a new element immediately before this cursor's location, giving the element the specified local name and content.- Specified by:
insertElementWithTextin interfaceXmlCursor- Parameters:
localName- The local name for the new element.text- The content for the new element.
-
insertElementWithText
Description copied from interface:XmlCursorInserts a new element immediately before this cursor's location, giving the element the specified local name, associating it with the specified namespace, and giving it the specified content.- Specified by:
insertElementWithTextin interfaceXmlCursor- Parameters:
localName- The local name for the new element.uri- The URI for the new element's namespace.text- The content for the new element.
-
insertAttribute
Description copied from interface:XmlCursorInserts a new attribute immediately before this cursor's location, giving it the specified local name.- Specified by:
insertAttributein interfaceXmlCursor- Parameters:
localName- The local name for the new attribute.
-
insertAttribute
Description copied from interface:XmlCursorInserts a new attribute immediately before this cursor's location, giving it the specified local name and associating it with the specified namespace.- Specified by:
insertAttributein interfaceXmlCursor- Parameters:
localName- The local name for the new attribute.uri- The URI for the new attribute's namespace.
-
insertAttribute
Description copied from interface:XmlCursorInserts a new attribute immediately before this cursor's location, giving it the specified name.- Specified by:
insertAttributein interfaceXmlCursor- Parameters:
name- The local name for the new attribute.
-
insertAttributeWithValue
Description copied from interface:XmlCursorInserts a new attribute immediately before this cursor's location, giving it the specified value and name.- Specified by:
insertAttributeWithValuein interfaceXmlCursor- Parameters:
name- The local name for the new attribute.value- The value for the new attribute.
-
insertAttributeWithValue
Description copied from interface:XmlCursorInserts an attribute immediately before the cursor's location, giving it the specified name and value, and associating it with the specified namespace.- Specified by:
insertAttributeWithValuein interfaceXmlCursor- Parameters:
name- The name for the new attribute.uri- The URI for the new attribute's namespace.value- The value for the new attribute.
-
insertAttributeWithValue
Description copied from interface:XmlCursorInserts an attribute immediately before the cursor's location, giving it the specified name and value.- Specified by:
insertAttributeWithValuein interfaceXmlCursor- Parameters:
name- The name for the new attribute.value- The value for the new attribute.
-
insertNamespace
Description copied from interface:XmlCursorInserts a namespace declaration immediately before the cursor's location, giving it the specified prefix and URI.- Specified by:
insertNamespacein interfaceXmlCursor- Parameters:
prefix- The prefix for the namespace.namespace- The URI for the namespace.
-
insertComment
Description copied from interface:XmlCursorInserts an XML comment immediately before the cursor's location, giving it the specified content.- Specified by:
insertCommentin interfaceXmlCursor- Parameters:
text- The new comment's content.
-
insertProcInst
Description copied from interface:XmlCursorInserts an XML processing instruction immediately before the cursor's location, giving it the specified target and text.- Specified by:
insertProcInstin interfaceXmlCursor- Parameters:
target- The target for the processing instruction.text- The new processing instruction's text.
-
dump
public void dump()Description copied from interface:XmlTokenSourcePrints to stdout the state of the document in which this token source is positioned. This is very implementation specific and may change at any time. Dump can be useful for debugging purposes. It is very different from the save methods which produce XML text which only approximates the actual state of the document.- Specified by:
dumpin interfaceXmlTokenSource
-