Package groovy.xml
Class DOMBuilder
java.lang.Object
groovy.lang.GroovyObjectSupport
groovy.util.BuilderSupport
groovy.xml.DOMBuilder
- All Implemented Interfaces:
GroovyObject
public class DOMBuilder extends BuilderSupport
A helper class for creating a W3C DOM tree
-
Constructor Summary
Constructors Constructor Description DOMBuilder(DocumentBuilder documentBuilder)
DOMBuilder(Document document)
-
Method Summary
Modifier and Type Method Description protected void
appendNamespaceAttributes(Element element, Map<Object,Object> attributes)
protected Document
createDocument()
protected Object
createNode(Object name)
protected Object
createNode(Object name, Object value)
protected Object
createNode(Object name, Map attributes)
protected Object
createNode(Object name, Map attributes, Object value)
static DOMBuilder
newInstance()
static DOMBuilder
newInstance(boolean validating, boolean namespaceAware)
static Document
parse(Reader reader)
Creates a DocumentBuilder and uses it to parse the XML text read from the given reader.static Document
parse(Reader reader, boolean validating, boolean namespaceAware)
Creates a DocumentBuilder and uses it to parse the XML text read from the given reader, allowing parser validation and namespace awareness to be controlled.static Document
parse(Reader reader, boolean validating, boolean namespaceAware, boolean allowDocTypeDeclaration)
Creates a DocumentBuilder and uses it to parse the XML text read from the given reader, allowing parser validation, namespace awareness and permission of DOCTYPE declarations to be controlled.Document
parseText(String text)
A helper method to parse the given text as XML.protected void
setParent(Object parent, Object child)
Methods inherited from class groovy.util.BuilderSupport
doInvokeMethod, getCurrent, getName, invokeMethod, invokeMethod, nodeCompleted, postNodeCompletion, setClosureDelegate, setCurrent
Methods inherited from class groovy.lang.GroovyObjectSupport
getMetaClass, setMetaClass
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
Methods inherited from interface groovy.lang.GroovyObject
getProperty, setProperty
-
Constructor Details
-
DOMBuilder
-
DOMBuilder
-
-
Method Details
-
newInstance
- Throws:
ParserConfigurationException
-
newInstance
public static DOMBuilder newInstance(boolean validating, boolean namespaceAware) throws ParserConfigurationException- Throws:
ParserConfigurationException
-
parse
public static Document parse(Reader reader) throws SAXException, IOException, ParserConfigurationExceptionCreates a DocumentBuilder and uses it to parse the XML text read from the given reader. A non-validating, namespace aware parser which does not allow DOCTYPE declarations is used.- Parameters:
reader
- the reader to read the XML text from- Returns:
- the root node of the parsed tree of Nodes
- Throws:
SAXException
- Any SAX exception, possibly wrapping another exception.IOException
- An IO exception from the parser, possibly from a byte stream or character stream supplied by the application.ParserConfigurationException
- if a DocumentBuilder cannot be created which satisfies the configuration requested.- See Also:
parse(Reader, boolean, boolean)
-
parse
public static Document parse(Reader reader, boolean validating, boolean namespaceAware) throws SAXException, IOException, ParserConfigurationExceptionCreates a DocumentBuilder and uses it to parse the XML text read from the given reader, allowing parser validation and namespace awareness to be controlled. Documents are not allowed to contain DOCYTYPE declarations.- Parameters:
reader
- the reader to read the XML text fromvalidating
- whether to validate the XMLnamespaceAware
- whether the parser should be namespace aware- Returns:
- the root node of the parsed tree of Nodes
- Throws:
SAXException
- Any SAX exception, possibly wrapping another exception.IOException
- An IO exception from the parser, possibly from a byte stream or character stream supplied by the application.ParserConfigurationException
- if a DocumentBuilder cannot be created which satisfies the configuration requested.
-
parse
public static Document parse(Reader reader, boolean validating, boolean namespaceAware, boolean allowDocTypeDeclaration) throws SAXException, IOException, ParserConfigurationExceptionCreates a DocumentBuilder and uses it to parse the XML text read from the given reader, allowing parser validation, namespace awareness and permission of DOCTYPE declarations to be controlled.- Parameters:
reader
- the reader to read the XML text fromvalidating
- whether to validate the XMLnamespaceAware
- whether the parser should be namespace awareallowDocTypeDeclaration
- whether the parser should allow DOCTYPE declarations- Returns:
- the root node of the parsed tree of Nodes
- Throws:
SAXException
- Any SAX exception, possibly wrapping another exception.IOException
- An IO exception from the parser, possibly from a byte stream or character stream supplied by the application.ParserConfigurationException
- if a DocumentBuilder cannot be created which satisfies the configuration requested.
-
parseText
public Document parseText(String text) throws SAXException, IOException, ParserConfigurationExceptionA helper method to parse the given text as XML.- Parameters:
text
- the XML text to parse- Returns:
- the root node of the parsed tree of Nodes
- Throws:
SAXException
- Any SAX exception, possibly wrapping another exception.IOException
- An IO exception from the parser, possibly from a byte stream or character stream supplied by the application.ParserConfigurationException
- if a DocumentBuilder cannot be created which satisfies the configuration requested.- See Also:
parse(Reader)
-
setParent
- Specified by:
setParent
in classBuilderSupport
-
createNode
- Specified by:
createNode
in classBuilderSupport
-
createDocument
-
createNode
- Specified by:
createNode
in classBuilderSupport
-
createNode
- Specified by:
createNode
in classBuilderSupport
-
createNode
- Specified by:
createNode
in classBuilderSupport
-
appendNamespaceAttributes
-