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

org.camunda.spin.xml.SpinXmlElement 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;

import java.io.Writer;
import java.util.Collection;
import java.util.List;

import org.camunda.spin.SpinList;

/**
 * An element in a tree-oriented XML data format.
 *
 * @author Sebastian Menski
 * @author Daniel Meyer
 *
 */
public abstract class SpinXmlElement extends SpinXmlNode {

  /**
   * 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 SpinXmlAttribute attribute}
   * @throws IllegalArgumentException if the attributeName is null
   * @throws SpinXmlAttributeException if the attribute is not found
   */
  public abstract SpinXmlAttribute 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 SpinXmlElement element}
   * @throws IllegalArgumentException if the attributeName or value is null
   */
  public abstract SpinXmlElement attr(String attributeName, String value);

  /**
   * Removes the attribute with an empty namespace.
   *
   * @param attributeName the name of the attribute
   * @return the wrapped {@link SpinXmlElement element}
   * @throws IllegalArgumentException if the attributeName is null
   */
  public abstract SpinXmlElement 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 SpinXmlAttribute attribute}
   * @throws IllegalArgumentException if attributeName or value is null
   * @throws SpinXmlElementImplementationException if the attribute cannot be set in the underlying implementation
   */
  public abstract SpinXmlAttribute 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 SpinXmlElement element}
   * @throws IllegalArgumentException if attributeName or value is null
   * @throws SpinXmlElementImplementationException if the attribute cannot be set in the underlying implementation
   */
  public abstract SpinXmlElement 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 SpinXmlElement element}
   * @throws IllegalArgumentException if the attributeName is null
   */
  public abstract SpinXmlElement 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 the text content of an element.
   *
   * @return the text content or an empty string if non exists
   */
  public abstract String textContent();

  /**
   * Sets the text content of an element.
   * @param textContent the text content to set
   * @return the wrapped {@link SpinXmlElement element}
   * @throws IllegalArgumentException if the textContent is null
   */
  public abstract SpinXmlElement textContent(String textContent);

  /**
   * 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 SpinXmlElement element}
   * @throws IllegalArgumentException if the elementName is null
   * @throws SpinXmlElementException if none or more than one child element is found
   */
  public abstract SpinXmlElement childElement(String elementName);

  /**
   * Returns a single wrapped child {@link SpinXmlElement element} for the given namespace
   * and name.
   *
   * @param namespace the namespace of the element
   * @param elementName the element name
   * @return the wrapped child {@link SpinXmlElement element}
   * @throws IllegalArgumentException if the elementName is null
   * @throws SpinXmlElementException if none or more than one child element is found
   */
  public abstract SpinXmlElement childElement(String namespace, String elementName);

  /**
   * Returns all child elements of this {@link SpinXmlElement elements}.
   *
   * @return list of wrapped child {@link SpinXmlElement elements}
   */
  public abstract SpinList childElements();

  /**
   * Returns all child {@link SpinXmlElement elements} with a given name in the local namespace
   * of this element.
   *
   * @param elementName the element name
   * @return a collection of wrapped {@link SpinXmlElement elements}
   * @throws IllegalArgumentException if the element name is null
   * @throws SpinXmlElementException if no child element was found
   */
  public abstract SpinList childElements(String elementName);

  /**
   * Returns all child {@link SpinXmlElement 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 SpinXmlElement elements}
   * @throws IllegalArgumentException if the element name is null
   * @throws SpinXmlElementException if no child element was found
   */
  public abstract SpinList childElements(String namespace, String elementName);

  /**
   * Appends child elements to this {@link SpinXmlElement element}.
   *
   * @param childElements the child elements to append
   * @return the wrapped {@link SpinXmlElement element}
   * @throws IllegalArgumentException if the childElements is null or one of them
   * @throws SpinXmlElementImplementationException if a child element cannot be appended in the underlying implementation
   */
  public abstract SpinXmlElement append(SpinXmlElement... childElements);

  /**
   * Appends child elements to this {@link SpinXmlElement element}.
   *
   * @param childElements the child elements to append
   * @return the wrapped {@link SpinXmlElement element}
   * @throws IllegalArgumentException if the childElements is null or one of them
   * @throws SpinXmlElementImplementationException if a child element cannot be appended in the underlying implementation
   */
  public abstract SpinXmlElement 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 SpinXmlElement element}
   * @throws IllegalArgumentException if the child element or existing child element is null
   * @throws SpinXmlElementException if the existing child element is not a child of this element
   * @throws SpinXmlElementImplementationException if the new child element cannot be inserted in the underlying implementation
   */
  public abstract SpinXmlElement appendBefore(SpinXmlElement childElement, SpinXmlElement existingChildElement);

  /**
   * Appends a child element to this {@link SpinXmlElement element} after the existing child {@link SpinXmlElement element}.
   *
   * @param childElement the child element to append
   * @param existingChildElement the child element to append after
   * @return the wrapped {@link SpinXmlElement element}
   * @throws IllegalArgumentException if the child element or existing child element is null
   * @throws SpinXmlElementException if the existing child element is not a child of this element
   * @throws SpinXmlElementImplementationException if the new child element cannot be inserted in the underlying implementation
   */
  public abstract SpinXmlElement appendAfter(SpinXmlElement childElement, SpinXmlElement existingChildElement);

  /**
   * Removes all child elements from this element.
   *
   * @param childElements the child elements to remove
   * @return the wrapped {@link SpinXmlElement element}
   * @throws IllegalArgumentException if child elements is null or any of them
   * @throws SpinXmlElementException if one of the child elements does not exist
   * @throws SpinXmlElementImplementationException if the child element cannot be removed in the underlying implementation
   */
  public abstract SpinXmlElement remove(SpinXmlElement... childElements);

  /**
   * Removes all child elements from this element.
   *
   * @param childElements the child elements to remove
   * @return the wrapped {@link SpinXmlElement element}
   * @throws IllegalArgumentException if child elements is null or any of them
   * @throws SpinXmlElementException if one of the child elements does not exist
   * @throws SpinXmlElementImplementationException if the child element cannot be removed in the underlying implementation
   */
  public abstract SpinXmlElement remove(Collection childElements);

  /**
   * Replaces this element by an new one.
   *
   * @param newChildElement the new element
   * @return the new wrapped {@link SpinXmlElement element}
   * @throws IllegalArgumentException if the new element is null or has the wrong type
   * @throws SpinXmlElementException if this element has no parent element
   * @throws SpinXmlElementImplementationException if the element cannot be replaced in the underlying implementation
   */
  public abstract SpinXmlElement replace(SpinXmlElement 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 SpinXmlElement element}
   * @throws IllegalArgumentException if any of the child elements is null
   * @throws SpinXmlElementException if the existing element is not a child element of this
   * @throws SpinXmlElementImplementationException if the child cannot be replaced in the underlying implementation
   */
  public abstract SpinXmlElement replaceChild(SpinXmlElement existingChildElement, SpinXmlElement newChildElement);

  /**
   * Creates a XPath query on this element.
   *
   * @param expression the XPath expression
   * @return the XPath query
   */
  public abstract SpinXPathQuery xPath(String expression);

  /**
   * Returns the wrapped XML element as string representation.
   *
   * @return the string representation
   * @throws SpinXmlElementException if the element cannot be transformed or no new transformer can be created
   */
  public abstract String toString();

  /**
   * Writes the wrapped XML element to a existing writer.
   *
   * @param writer the writer to write to
   * @throws SpinXmlElementException if the element cannot be transformed or no new transformer can be created
   */
  public abstract void writeToWriter(Writer writer);
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy