org.camunda.spin.xml.tree.SpinXmlTreeElement Maven / Gradle / Ivy
/* 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.camunda.spin.xml.tree;
import org.camunda.spin.SpinList;
import java.io.OutputStream;
import java.io.Writer;
import java.util.Collection;
import java.util.List;
/**
* An element in a tree-oriented XML data format.
*
* @author Sebastian Menski
* @author Daniel Meyer
*
*/
public abstract class SpinXmlTreeElement extends SpinXmlTreeNode {
/**
* Checks whether this element has a attribute with an empty namespace and the given name.
*
* @param attributeName the name of the attribute
* @return true if the element has an attribute with this name under the local namespace, false otherwise
* @throws IllegalArgumentException if the attributeName is null
*/
public abstract boolean hasAttr(String attributeName);
/**
* Returns the wrapped attribute for an empty namespace and the given name.
*
* @param attributeName the name of the attribute
* @return the wrapped {@link SpinXmlTreeAttribute attribute}
* @throws IllegalArgumentException if the attributeName is null
* @throws SpinXmlTreeAttributeException if the attribute is not found
*/
public abstract SpinXmlTreeAttribute attr(String attributeName);
/**
* Sets the attribute value in the local namespace of this element.
*
* @param attributeName the name of the attribute
* @param value the value to set
* @return the wrapped {@link SpinXmlTreeElement element}
* @throws IllegalArgumentException if the attributeName or value is null
*/
public abstract SpinXmlTreeElement attr(String attributeName, String value);
/**
* Removes the attribute with an empty namespace.
*
* @param attributeName the name of the attribute
* @return the wrapped {@link SpinXmlTreeElement element}
* @throws IllegalArgumentException if the attributeName is null
*/
public abstract SpinXmlTreeElement removeAttr(String attributeName);
/**
* Checks whether this element has a attribute with the given namespace and name.
*
* @param namespace the namespace of the attribute
* @param attributeName the name of the attribute
* @return true if the element has an attribute with this name under given namespace, false otherwise
* @throws IllegalArgumentException if the attributeName is null
*/
public abstract boolean hasAttrNs(String namespace, String attributeName);
/**
* Returns the wrapped attribute for the given namespace and name.
*
* @param namespace the namespace of the attribute
* @param attributeName the name of the attribute
* @return the wrapped {@link SpinXmlTreeAttribute attribute}
* @throws IllegalArgumentException if attributeName or value is null
* @throws SpinXmlTreeElementImplementationException if the attribute cannot be set in the underlying implementation
*/
public abstract SpinXmlTreeAttribute attrNs(String namespace, String attributeName);
/**
* Sets the attribute value in the given namespace.
*
* @param namespace the namespace of the attribute
* @param attributeName the name of the attribute
* @param value the value to set
* @return the wrapped {@link SpinXmlTreeElement element}
* @throws IllegalArgumentException if attributeName or value is null
* @throws SpinXmlTreeElementImplementationException if the attribute cannot be set in the underlying implementation
*/
public abstract SpinXmlTreeElement attrNs(String namespace, String attributeName, String value);
/**
* Removes the attribute under the given namespace.
*
* @param namespace the namespace of the attribute
* @param attributeName the name of the attribute
* @return the wrapped {@link SpinXmlTreeElement element}
* @throws IllegalArgumentException if the attributeName is null
*/
public abstract SpinXmlTreeElement removeAttrNs(String namespace, String attributeName);
/**
* Returns all wrapped attributes of this element.
*
* @return the wrapped attributes or an empty list of no attributes are found
*/
public abstract SpinList attrs();
/**
* Returns all wrapped attributes for the given namespace.
*
* @param namespace the namespace of the attributes
* @return the wrapped attributes or an empty list of no attributes are found
*/
public abstract SpinList attrs(String namespace);
/**
* Returns all names of the attributes of this element.
*
* @return the names of the attributes
*/
public abstract List attrNames();
/**
* Returns all names of the attributes in the given namespace.
*
* @return the names of the attributes
*/
public abstract List attrNames(String namespace);
/**
* Returns a single wrapped child element for the given name
* in the local namespace of this element.
*
* @param elementName the element name
* @return the wrapped child {@link SpinXmlTreeElement element}
* @throws IllegalArgumentException if the elementName is null
* @throws SpinXmlTreeElementException if none or more than one child element is found
*/
public abstract SpinXmlTreeElement childElement(String elementName);
/**
* Returns a single wrapped child {@link SpinXmlTreeElement element} for the given namespace
* and name.
*
* @param namespace the namespace of the element
* @param elementName the element name
* @return the wrapped child {@link SpinXmlTreeElement element}
* @throws IllegalArgumentException if the elementName is null
* @throws SpinXmlTreeElementException if none or more than one child element is found
*/
public abstract SpinXmlTreeElement childElement(String namespace, String elementName);
/**
* Returns all child elements of this {@link SpinXmlTreeElement elements}.
*
* @return list of wrapped child {@link SpinXmlTreeElement elements}
*/
public abstract SpinList childElements();
/**
* Returns all child {@link SpinXmlTreeElement elements} with a given name in the local namespace
* of this element.
*
* @param elementName the element name
* @return a collection of wrapped {@link SpinXmlTreeElement elements}
* @throws IllegalArgumentException if the element name is null
* @throws SpinXmlTreeElementException if no child element was found
*/
public abstract SpinList childElements(String elementName);
/**
* Returns all child {@link SpinXmlTreeElement elements} with a given namespace and name.
*
* @param namespace the namespace of the element
* @param elementName the element name
* @return a collection of wrapped {@link SpinXmlTreeElement elements}
* @throws IllegalArgumentException if the element name is null
* @throws SpinXmlTreeElementException if no child element was found
*/
public abstract SpinList childElements(String namespace, String elementName);
/**
* Appends child elements to this {@link SpinXmlTreeElement element}.
*
* @param childElements the child elements to append
* @return the wrapped {@link SpinXmlTreeElement element}
* @throws IllegalArgumentException if the childElements is null or one of them
* @throws SpinXmlTreeElementImplementationException if a child element cannot be appended in the underlying implementation
*/
public abstract SpinXmlTreeElement append(SpinXmlTreeElement... childElements);
/**
* Appends child elements to this {@link SpinXmlTreeElement element}.
*
* @param childElements the child elements to append
* @return the wrapped {@link SpinXmlTreeElement element}
* @throws IllegalArgumentException if the childElements is null or one of them
* @throws SpinXmlTreeElementImplementationException if a child element cannot be appended in the underlying implementation
*/
public abstract SpinXmlTreeElement append(Collection childElements);
/**
* Appends a child element to this element before the existing child element.
*
* @param childElement the child element to append
* @param existingChildElement the child element to append before
* @return the wrapped {@link SpinXmlTreeElement element}
* @throws IllegalArgumentException if the child element or existing child element is null
* @throws SpinXmlTreeElementException if the existing child element is not a child of this element
* @throws SpinXmlTreeElementImplementationException if the new child element cannot be inserted in the underlying implementation
*/
public abstract SpinXmlTreeElement appendBefore(SpinXmlTreeElement childElement, SpinXmlTreeElement existingChildElement);
/**
* Appends a child element to this {@link SpinXmlTreeElement element} after the existing child {@link SpinXmlTreeElement element}.
*
* @param childElement the child element to append
* @param existingChildElement the child element to append after
* @return the wrapped {@link SpinXmlTreeElement element}
* @throws IllegalArgumentException if the child element or existing child element is null
* @throws SpinXmlTreeElementException if the existing child element is not a child of this element
* @throws SpinXmlTreeElementImplementationException if the new child element cannot be inserted in the underlying implementation
*/
public abstract SpinXmlTreeElement appendAfter(SpinXmlTreeElement childElement, SpinXmlTreeElement existingChildElement);
/**
* Removes all child elements from this element.
*
* @param childElements the child elements to remove
* @return the wrapped {@link SpinXmlTreeElement element}
* @throws IllegalArgumentException if child elements is null or any of them
* @throws SpinXmlTreeElementException if one of the child elements does not exist
* @throws SpinXmlTreeElementImplementationException if the child element cannot be removed in the underlying implementation
*/
public abstract SpinXmlTreeElement remove(SpinXmlTreeElement... childElements);
/**
* Removes all child elements from this element.
*
* @param childElements the child elements to remove
* @return the wrapped {@link SpinXmlTreeElement element}
* @throws IllegalArgumentException if child elements is null or any of them
* @throws SpinXmlTreeElementException if one of the child elements does not exist
* @throws SpinXmlTreeElementImplementationException if the child element cannot be removed in the underlying implementation
*/
public abstract SpinXmlTreeElement remove(Collection childElements);
/**
* Replaces this element by an new one.
*
* @param newChildElement the new element
* @return the new wrapped {@link SpinXmlTreeElement element}
* @throws IllegalArgumentException if the new element is null or has the wrong type
* @throws SpinXmlTreeElementException if this element has no parent element
* @throws SpinXmlTreeElementImplementationException if the element cannot be replaced in the underlying implementation
*/
public abstract SpinXmlTreeElement replace(SpinXmlTreeElement newChildElement);
/**
* Replaces an existing child element with a new one.
*
* @param existingChildElement the existing child element to replace
* @param newChildElement the new child element
* @return the wrapped {@link SpinXmlTreeElement element}
* @throws IllegalArgumentException if any of the child elements is null
* @throws SpinXmlTreeElementException if the existing element is not a child element of this
* @throws SpinXmlTreeElementImplementationException if the child cannot be replaced in the underlying implementation
*/
public abstract SpinXmlTreeElement replaceChild(SpinXmlTreeElement existingChildElement, SpinXmlTreeElement newChildElement);
/**
* Creates a XPath query on this element.
*
* @param expression the XPath expression
* @return the XPath query
*/
public abstract SpinXmlTreeXPathQuery xPath(String expression);
/**
* Returns the wrapped XML element as string representation.
*
* @return the string representation
* @throws SpinXmlTreeElementException if the element cannot be transformed or no new transformer can be created
*/
public abstract String toString();
/**
* Returns the wrapped XML element as output stream.
*
* @return the output stream
* @throws SpinXmlTreeElementException if the element cannot be transformed or no new transformer can be created
*/
public abstract OutputStream toStream();
/**
* Writes the wrapped XML element to a existing stream.
*
* @param outputStream the stream to write to
* @return the stream after the object was written
* @throws SpinXmlTreeElementException if the element cannot be transformed or no new transformer can be created
*/
public abstract S writeToStream(S outputStream);
/**
* Writes the wrapped XML element to a existing writer.
*
* @param writer the writer to write to
* @return the Writer after the object was written
* @throws SpinXmlTreeElementException if the element cannot be transformed or no new transformer can be created
*/
public abstract W writeToWriter(W writer);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy