All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.llorllale.youtrack.api.StringAsDocument Maven / Gradle / Ivy

/*
 * Copyright 2017 George Aristy
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *     http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

package org.llorllale.youtrack.api;

import java.io.IOException;
import java.io.StringReader;
import java.io.UncheckedIOException;
import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException;
import org.w3c.dom.Attr;
import org.w3c.dom.CDATASection;
import org.w3c.dom.Comment;
import org.w3c.dom.DOMConfiguration;
import org.w3c.dom.DOMException;
import org.w3c.dom.DOMImplementation;
import org.w3c.dom.Document;
import org.w3c.dom.DocumentFragment;
import org.w3c.dom.DocumentType;
import org.w3c.dom.Element;
import org.w3c.dom.EntityReference;
import org.w3c.dom.NamedNodeMap;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import org.w3c.dom.ProcessingInstruction;
import org.w3c.dom.Text;
import org.w3c.dom.UserDataHandler;
import org.xml.sax.InputSource;
import org.xml.sax.SAXException;

/**
 * Handy class to encapsulate an XML string as a {@link Document} node.
 * 
 * 

It hides tedious code like: *

 * {@code
 * final Document doc = DocumentBuilderFactory.newInstance()
 *     .newDocumentBuilder()
 *     .parse(new InputSource(new StringReader(xml)));
 * }
 * 
* * @author George Aristy ([email protected]) * @since 1.0.0 */ @SuppressWarnings("checkstyle:MethodCount") final class StringAsDocument implements Document { private final Document base; /** * Ctor. * *

Throws {@link UncheckedIOException} because {@code xml} is expected to be well-formed and * the JDK's DOM infrastructure should be well-configured. * * @param xml the xml string * @throws UncheckedIOException wrapping any {@link ParserConfigurationException}, * {@link SAXException}, {@link IOException} thrown by Java * @since 1.0.0 */ StringAsDocument(String xml) throws UncheckedIOException { try { this.base = DocumentBuilderFactory.newInstance() .newDocumentBuilder() .parse(new InputSource(new StringReader(xml))); } catch(ParserConfigurationException | SAXException | IOException e) { throw new UncheckedIOException(new IOException(e.getMessage(), e)); } } @Override public DocumentType getDoctype() { return this.base.getDoctype(); } @Override public DOMImplementation getImplementation() { return this.base.getImplementation(); } @Override public Element getDocumentElement() { return this.base.getDocumentElement(); } @Override public Element createElement(String tagName) throws DOMException { return this.base.createElement(tagName); } @Override public DocumentFragment createDocumentFragment() { return this.base.createDocumentFragment(); } @Override public Text createTextNode(String data) { return this.base.createTextNode(data); } @Override public Comment createComment(String data) { return this.base.createComment(data); } @Override public CDATASection createCDATASection(String data) throws DOMException { return this.base.createCDATASection(data); } @Override public ProcessingInstruction createProcessingInstruction( String target, String data ) throws DOMException { return this.base.createProcessingInstruction(target, data); } @Override public Attr createAttribute(String name) throws DOMException { return this.base.createAttribute(name); } @Override public EntityReference createEntityReference(String name) throws DOMException { return this.base.createEntityReference(name); } @Override public NodeList getElementsByTagName(String tagname) { return this.base.getElementsByTagName(tagname); } @Override public Node importNode(Node importedNode, boolean deep) throws DOMException { return this.base.importNode(importedNode, deep); } @Override public Element createElementNS(String namespaceUri, String qualifiedName) throws DOMException { return this.base.createElementNS(namespaceUri, qualifiedName); } @Override public Attr createAttributeNS(String namespaceUri, String qualifiedName) throws DOMException { return this.base.createAttributeNS(namespaceUri, qualifiedName); } @Override public NodeList getElementsByTagNameNS(String namespaceUri, String localName) { return this.base.getElementsByTagNameNS(namespaceUri, localName); } @Override public Element getElementById(String elementId) { return this.base.getElementById(elementId); } @Override public String getInputEncoding() { return this.base.getInputEncoding(); } @Override public String getXmlEncoding() { return this.base.getXmlEncoding(); } @Override public boolean getXmlStandalone() { return this.base.getXmlStandalone(); } @Override public void setXmlStandalone(boolean xmlStandalone) throws DOMException { this.base.setXmlStandalone(xmlStandalone); } @Override public String getXmlVersion() { return this.base.getXmlVersion(); } @Override public void setXmlVersion(String xmlVersion) throws DOMException { this.base.setXmlVersion(xmlVersion); } @Override public boolean getStrictErrorChecking() { return this.base.getStrictErrorChecking(); } @Override public void setStrictErrorChecking(boolean strictErrorChecking) { this.base.setStrictErrorChecking(strictErrorChecking); } @Override public String getDocumentURI() { return this.base.getDocumentURI(); } @Override public void setDocumentURI(String documentUri) { this.base.setDocumentURI(documentUri); } @Override public Node adoptNode(Node source) throws DOMException { return this.base.adoptNode(source); } @Override public DOMConfiguration getDomConfig() { return this.base.getDomConfig(); } @Override public void normalizeDocument() { this.base.normalizeDocument(); } @Override public Node renameNode(Node node, String namespaceUri, String qualifiedName) throws DOMException { return this.base.renameNode(node, namespaceUri, qualifiedName); } @Override public String getNodeName() { return this.base.getNodeName(); } @Override public String getNodeValue() throws DOMException { return this.base.getNodeValue(); } @Override public void setNodeValue(String nodeValue) throws DOMException { this.base.setNodeValue(nodeValue); } @Override public short getNodeType() { return this.base.getNodeType(); } @Override public Node getParentNode() { return this.base.getParentNode(); } @Override public NodeList getChildNodes() { return this.base.getChildNodes(); } @Override public Node getFirstChild() { return this.base.getFirstChild(); } @Override public Node getLastChild() { return this.base.getLastChild(); } @Override public Node getPreviousSibling() { return this.base.getPreviousSibling(); } @Override public Node getNextSibling() { return this.base.getNextSibling(); } @Override public NamedNodeMap getAttributes() { return this.base.getAttributes(); } @Override public Document getOwnerDocument() { return this.base.getOwnerDocument(); } @Override public Node insertBefore(Node newChild, Node refChild) throws DOMException { return this.base.insertBefore(newChild, refChild); } @Override public Node replaceChild(Node newChild, Node oldChild) throws DOMException { return this.base.replaceChild(newChild, oldChild); } @Override public Node removeChild(Node oldChild) throws DOMException { return this.base.removeChild(oldChild); } @Override public Node appendChild(Node newChild) throws DOMException { return this.base.appendChild(newChild); } @Override public boolean hasChildNodes() { return this.base.hasChildNodes(); } @Override public Node cloneNode(boolean deep) { return this.base.cloneNode(deep); } @Override public void normalize() { this.base.normalize(); } @Override public boolean isSupported(String feature, String version) { return this.base.isSupported(feature, version); } @Override public String getNamespaceURI() { return this.base.getNamespaceURI(); } @Override public String getPrefix() { return this.base.getPrefix(); } @Override public void setPrefix(String prefix) throws DOMException { this.base.setPrefix(prefix); } @Override public String getLocalName() { return this.base.getLocalName(); } @Override public boolean hasAttributes() { return this.base.hasAttributes(); } @Override public String getBaseURI() { return this.base.getBaseURI(); } @Override public short compareDocumentPosition(Node other) throws DOMException { return this.base.compareDocumentPosition(other); } @Override public String getTextContent() throws DOMException { return this.base.getTextContent(); } @Override public void setTextContent(String textContent) throws DOMException { this.base.setTextContent(textContent); } @Override public boolean isSameNode(Node other) { return this.base.isSameNode(other); } @Override public String lookupPrefix(String namespaceUri) { return this.base.lookupPrefix(namespaceUri); } @Override public boolean isDefaultNamespace(String namespaceUri) { return this.base.isDefaultNamespace(namespaceUri); } @Override public String lookupNamespaceURI(String prefix) { return this.base.lookupNamespaceURI(prefix); } @Override public boolean isEqualNode(Node arg) { return this.base.isEqualNode(arg); } @Override public Object getFeature(String feature, String version) { return this.base.getFeature(feature, version); } @Override public Object setUserData(String key, Object data, UserDataHandler handler) { return this.base.setUserData(key, data, handler); } @Override public Object getUserData(String key) { return this.base.getUserData(key); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy