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

com.helger.commons.microdom.IMicroElement Maven / Gradle / Ivy

There is a newer version: 5.0.12
Show newest version
/**
 * Copyright (C) 2014-2015 Philip Helger (www.helger.com)
 * philip[at]helger[dot]com
 *
 * 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 com.helger.commons.microdom;

import java.util.Collection;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.Set;

import javax.annotation.Nonnegative;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;

import com.helger.commons.annotation.ReturnsMutableCopy;
import com.helger.commons.state.EChange;

/**
 * Represents a single element (=tag) of a document.
 *
 * @author Philip Helger
 */
public interface IMicroElement extends IMicroNodeWithChildren
{
  /**
   * @return true if this element has at least one attribute,
   *         false otherwise
   */
  boolean hasAttributes ();

  /**
   * @return true if this element has no attribute,
   *         false if at least one attribute is present.
   */
  boolean hasNoAttributes ();

  /**
   * @return The number of assigned attributes. Always ≥ 0.
   */
  @Nonnegative
  int getAttributeCount ();

  /**
   * Check if this element has an attribute with the specified name.
   *
   * @param sAttrName
   *        The attribute name to check.
   * @return true if such an attribute is present,
   *         false otherwise
   */
  boolean hasAttribute (@Nullable String sAttrName);

  /**
   * Check if this element has an attribute with the specified name.
   *
   * @param sNamespaceURI
   *        Namespace URI to use. May be null.
   * @param sAttrName
   *        The attribute name to check.
   * @return true if such an attribute is present,
   *         false otherwise
   */
  boolean hasAttribute (@Nullable String sNamespaceURI, @Nullable String sAttrName);

  /**
   * Check if this element has an attribute with the specified name.
   *
   * @param aAttrName
   *        The qualified attribute name to check. May be null.
   * @return true if such an attribute is present,
   *         false otherwise
   */
  boolean hasAttribute (@Nullable IMicroQName aAttrName);

  /**
   * Get the attribute object with the specified name.
   *
   * @param sAttrName
   *        The attribute locale name to query. May be null.
   * @return null of no such attribute object exists.
   */
  @Nullable
  IMicroAttribute getAttributeObj (@Nullable String sAttrName);

  /**
   * Get the attribute object with the specified namespace URI and local name.
   *
   * @param sNamespaceURI
   *        Namespace URI to use. May be null.
   * @param sAttrName
   *        The attribute locale name to query. May be null.
   * @return null of no such attribute object exists.
   */
  @Nullable
  IMicroAttribute getAttributeObj (@Nullable String sNamespaceURI, @Nullable String sAttrName);

  /**
   * Get the attribute object with the specified qualified name.
   *
   * @param aAttrName
   *        The qualified attribute name to check. May be null.
   * @return null of no such attribute object exists.
   */
  @Nullable
  IMicroAttribute getAttributeObj (@Nullable IMicroQName aAttrName);

  /**
   * Get the attribute value of the given attribute name. If this element has no
   * such attribute, null is returned.
   *
   * @param sAttrName
   *        The attribute name to retrieve the value of.
   * @return The assigned attribute value or null.
   */
  @Nullable
  String getAttributeValue (@Nullable String sAttrName);

  /**
   * Get the attribute value of the given attribute name. If this element has no
   * such attribute, null is returned.
   *
   * @param sNamespaceURI
   *        Namespace URI to use. May be null.
   * @param sAttrName
   *        The attribute name to retrieve the value of.
   * @return The assigned attribute value or null.
   */
  @Nullable
  String getAttributeValue (@Nullable String sNamespaceURI, @Nullable String sAttrName);

  /**
   * Get the attribute value of the given attribute name. If this element has no
   * such attribute, null is returned.
   *
   * @param aAttrName
   *        The qualified attribute name to retrieve the value of. May be
   *        null.
   * @return The assigned attribute value or null.
   */
  @Nullable
  String getAttributeValue (@Nullable IMicroQName aAttrName);

  /**
   * Get the attribute value of the given attribute name. If this element has no
   * such attribute, null is returned. The attribute value is
   * converted via the {@link com.helger.commons.typeconvert.TypeConverter} to
   * the desired destination class. If no such attribute is present,
   * null is returned.
   *
   * @param 
   *        Destination type
   * @param sAttrName
   *        The attribute name to retrieve the value of.
   * @param aDstClass
   *        The destination class.
   * @return The assigned attribute value or null.
   * @throws ClassCastException
   *         if the value cannot be converted
   */
  @Nullable
   DSTTYPE getAttributeValueWithConversion (@Nullable String sAttrName, @Nonnull Class  aDstClass);

  /**
   * Get the attribute value of the given attribute name. If this element has no
   * such attribute, null is returned. The attribute value is
   * converted via the {@link com.helger.commons.typeconvert.TypeConverter} to
   * the desired destination class. If no such attribute is present,
   * null is returned.
   *
   * @param 
   *        Destination type
   * @param sNamespaceURI
   *        Namespace URI to use. May be null.
   * @param sAttrName
   *        The attribute name to retrieve the value of.
   * @param aDstClass
   *        The destination class.
   * @return The assigned attribute value or null.
   * @throws ClassCastException
   *         if the value cannot be converted
   */
  @Nullable
   DSTTYPE getAttributeValueWithConversion (@Nullable String sNamespaceURI,
                                                     @Nullable String sAttrName,
                                                     @Nonnull Class  aDstClass);

  /**
   * Get the attribute value of the given attribute name. If this element has no
   * such attribute, null is returned. The attribute value is
   * converted via the {@link com.helger.commons.typeconvert.TypeConverter} to
   * the desired destination class. If no such attribute is present,
   * null is returned.
   *
   * @param 
   *        Destination type
   * @param aAttrName
   *        The attribute qualified name to retrieve the value of.
   * @param aDstClass
   *        The destination class.
   * @return The assigned attribute value or null.
   * @throws ClassCastException
   *         if the value cannot be converted
   */
  @Nullable
   DSTTYPE getAttributeValueWithConversion (@Nullable IMicroQName aAttrName,
                                                     @Nonnull Class  aDstClass);

  /**
   * Get a list of all attributes. Is ensured to be not null if
   * {@link #hasAttributes()} returns true.
   *
   * @return May be null.
   */
  @Nullable
  @ReturnsMutableCopy
  List  getAllAttributeObjs ();

  /**
   * Get an iterator over all attributes.
   *
   * @return Never null.
   */
  @Nonnull
  Iterator  getAttributeIterator ();

  /**
   * Get a map of all fully qualified attribute names and values. Is ensured to
   * be not null if {@link #hasAttributes()} returns
   * true.
   *
   * @return May be null.
   */
  @Nullable
  @ReturnsMutableCopy
  Map  getAllQAttributes ();

  /**
   * Get a set of all attribute names. Is ensured to be not null if
   * {@link #hasAttributes()} returns true.
   *
   * @return May be null.
   */
  @Nullable
  @ReturnsMutableCopy
  Set  getAllAttributeNames ();

  /**
   * Get a set of all attribute names. Is ensured to be not null if
   * {@link #hasAttributes()} returns true.
   *
   * @return May be null.
   */
  @Nullable
  @ReturnsMutableCopy
  Set  getAllAttributeQNames ();

  /**
   * Get a set of all attribute values. Is ensured to be not null
   * if {@link #hasAttributes()} returns true.
   *
   * @return May be null.
   */
  @Nullable
  @ReturnsMutableCopy
  Collection  getAllAttributeValues ();

  /**
   * Set an attribute value of this element.
   *
   * @param sAttrName
   *        Name of the attribute. May neither be null nor empty.
   * @param sAttrValue
   *        If the value is null the attribute is removed (if
   *        present)
   * @return this
   */
  @Nonnull
  IMicroElement setAttribute (@Nonnull String sAttrName, @Nullable String sAttrValue);

  /**
   * Set an attribute value of this element.
   *
   * @param sNamespaceURI
   *        Namespace URI to use. May be null.
   * @param sAttrName
   *        Name of the attribute. May neither be null nor empty.
   * @param sAttrValue
   *        If the value is null the attribute is removed (if
   *        present)
   * @return this
   */
  @Nonnull
  IMicroElement setAttribute (@Nullable String sNamespaceURI, @Nonnull String sAttrName, @Nullable String sAttrValue);

  /**
   * Set an attribute value of this element.
   *
   * @param aAttrName
   *        Qualified name of the attribute. May neither be null
   *        nor empty.
   * @param sAttrValue
   *        If the value is null the attribute is removed (if
   *        present)
   * @return this
   */
  @Nonnull
  IMicroElement setAttribute (@Nonnull IMicroQName aAttrName, @Nullable String sAttrValue);

  /**
   * Set an attribute value of this element.
   *
   * @param sAttrName
   *        Name of the attribute. May neither be null nor empty.
   * @param aAttrValueProvider
   *        The attribute value provider. May not be null. If the
   *        contained attribute value is null the attribute is
   *        removed (if present)
   * @return this
   */
  @Nonnull
  IMicroElement setAttribute (@Nonnull String sAttrName, @Nonnull IHasAttributeValue aAttrValueProvider);

  /**
   * Set an attribute value of this element.
   *
   * @param sNamespaceURI
   *        Namespace URI to use. May be null.
   * @param sAttrName
   *        Name of the attribute. May neither be null nor empty.
   * @param aAttrValueProvider
   *        The attribute value provider. May not be null. If the
   *        contained attribute value is null the attribute is
   *        removed (if present)
   * @return this
   */
  @Nonnull
  IMicroElement setAttribute (@Nullable String sNamespaceURI,
                              @Nonnull String sAttrName,
                              @Nonnull IHasAttributeValue aAttrValueProvider);

  /**
   * Set an attribute value of this element.
   *
   * @param aAttrName
   *        Qualified name of the attribute. May neither be null
   *        nor empty.
   * @param aAttrValueProvider
   *        The attribute value provider. May not be null. If the
   *        contained attribute value is null the attribute is
   *        removed (if present)
   * @return this
   */
  @Nonnull
  IMicroElement setAttribute (@Nonnull IMicroQName aAttrName, @Nonnull IHasAttributeValue aAttrValueProvider);

  /**
   * Set an attribute value of this element. This is a shortcut for
   * setAttribute(sAttrName, Boolean.toString (nValue)). That
   * means, that the serialized value of the attribute is either
   * true or false. If you need something else (like
   * "yes" or "no") don't use this method.
   *
   * @param sAttrName
   *        Name of the attribute. May neither be null nor empty.
   * @param bAttrValue
   *        The new value to be set.
   * @return this
   */
  @Nonnull
  IMicroElement setAttribute (@Nonnull String sAttrName, boolean bAttrValue);

  /**
   * Set an attribute value of this element. This is a shortcut for
   * setAttribute(sNamespaceURI, sAttrName, Boolean.toString (nValue))
   * . That means, that the serialized value of the attribute is either
   * true or false. If you need something else (like
   * "yes" or "no") don't use this method.
   *
   * @param sNamespaceURI
   *        Namespace URI to use. May be null.
   * @param sAttrName
   *        Name of the attribute. May neither be null nor empty.
   * @param bAttrValue
   *        The new value to be set.
   * @return this
   */
  @Nonnull
  IMicroElement setAttribute (@Nullable String sNamespaceURI, @Nonnull String sAttrName, boolean bAttrValue);

  /**
   * Set an attribute value of this element. This is a shortcut for
   * setAttribute(aAttrName, Boolean.toString (nValue)). That
   * means, that the serialized value of the attribute is either
   * true or false. If you need something else (like
   * "yes" or "no") don't use this method.
   *
   * @param aAttrName
   *        Qualified name of the attribute. May neither be null
   *        nor empty.
   * @param bAttrValue
   *        The new value to be set.
   * @return this
   */
  @Nonnull
  IMicroElement setAttribute (@Nonnull IMicroQName aAttrName, boolean bAttrValue);

  /**
   * Set an attribute value of this element. This is a shortcut for
   * setAttribute(sAttrName, Integer.toString (nValue)).
   *
   * @param sAttrName
   *        Name of the attribute. May neither be null nor empty.
   * @param nAttrValue
   *        The new value to be set.
   * @return this
   */
  @Nonnull
  IMicroElement setAttribute (@Nonnull String sAttrName, int nAttrValue);

  /**
   * Set an attribute value of this element. This is a shortcut for
   * setAttribute(sNamespaceURI, sAttrName, Integer.toString (nValue))
   * .
   *
   * @param sNamespaceURI
   *        Namespace URI to use. May be null.
   * @param sAttrName
   *        Name of the attribute. May neither be null nor empty.
   * @param nAttrValue
   *        The new value to be set.
   * @return this
   */
  @Nonnull
  IMicroElement setAttribute (@Nullable String sNamespaceURI, @Nonnull String sAttrName, int nAttrValue);

  /**
   * Set an attribute value of this element. This is a shortcut for
   * setAttribute(aAttrName, Integer.toString (nValue)).
   *
   * @param aAttrName
   *        Qualified name of the attribute. May neither be null
   *        nor empty.
   * @param nAttrValue
   *        The new value to be set.
   * @return this
   */
  @Nonnull
  IMicroElement setAttribute (@Nonnull IMicroQName aAttrName, int nAttrValue);

  /**
   * Set an attribute value of this element. This is a shortcut for
   * setAttribute(name, Long.toString (nValue)).
   *
   * @param sAttrName
   *        Name of the attribute. May neither be null nor empty.
   * @param nAttrValue
   *        The new value to be set.
   * @return this
   */
  @Nonnull
  IMicroElement setAttribute (@Nonnull String sAttrName, long nAttrValue);

  /**
   * Set an attribute value of this element. This is a shortcut for
   * setAttribute(name, Long.toString (nValue)).
   *
   * @param sNamespaceURI
   *        Namespace URI to use. May be null.
   * @param sAttrName
   *        Name of the attribute. May neither be null nor empty.
   * @param nAttrValue
   *        The new value to be set.
   * @return this
   */
  @Nonnull
  IMicroElement setAttribute (@Nullable String sNamespaceURI, @Nonnull String sAttrName, long nAttrValue);

  /**
   * Set an attribute value of this element. This is a shortcut for
   * setAttribute(name, Long.toString (nValue)).
   *
   * @param aAttrName
   *        Qualified name of the attribute. May neither be null
   *        nor empty.
   * @param nAttrValue
   *        The new value to be set.
   * @return this
   */
  @Nonnull
  IMicroElement setAttribute (@Nonnull IMicroQName aAttrName, long nAttrValue);

  /**
   * Set an attribute value of this element. If the type of the value is not
   * {@link String}, the {@link com.helger.commons.typeconvert.TypeConverter} is
   * invoked to convert it to a {@link String} object.
   *
   * @param sAttrName
   *        Name of the attribute. May neither be null nor empty.
   * @param aAttrValue
   *        If the value is null the attribute is removed (if
   *        present)
   * @return this
   */
  @Nonnull
  IMicroElement setAttributeWithConversion (@Nonnull String sAttrName, @Nullable Object aAttrValue);

  /**
   * Set an attribute value of this element. If the type of the value is not
   * {@link String}, the {@link com.helger.commons.typeconvert.TypeConverter} is
   * invoked to convert it to a {@link String} object.
   *
   * @param sNamespaceURI
   *        Namespace URI to use. May be null.
   * @param sAttrName
   *        Name of the attribute. May neither be null nor empty.
   * @param aAttrValue
   *        If the value is null the attribute is removed (if
   *        present)
   * @return this
   */
  @Nonnull
  IMicroElement setAttributeWithConversion (@Nullable String sNamespaceURI,
                                            @Nonnull String sAttrName,
                                            @Nullable Object aAttrValue);

  /**
   * Set an attribute value of this element. If the type of the value is not
   * {@link String}, the {@link com.helger.commons.typeconvert.TypeConverter} is
   * invoked to convert it to a {@link String} object.
   *
   * @param aAttrName
   *        Qualified name of the attribute. May neither be null
   *        nor empty.
   * @param aAttrValue
   *        If the value is null the attribute is removed (if
   *        present)
   * @return this
   */
  @Nonnull
  IMicroElement setAttributeWithConversion (@Nonnull IMicroQName aAttrName, @Nullable Object aAttrValue);

  /**
   * Remove the attribute with the given name.
   *
   * @param sAttrName
   *        The name of the attribute to be removed. May be null.
   * @return {@link EChange#CHANGED} if the attribute was removed,
   *         {@link EChange#UNCHANGED} if no such attribute exists at this
   *         element.
   */
  @Nonnull
  EChange removeAttribute (@Nullable String sAttrName);

  /**
   * Remove the attribute with the given name.
   *
   * @param sNamespaceURI
   *        Namespace URI to use. May be null.
   * @param sAttrName
   *        The name of the attribute to be removed. May be null.
   * @return {@link EChange#CHANGED} if the attribute was removed,
   *         {@link EChange#UNCHANGED} if no such attribute exists at this
   *         element.
   */
  @Nonnull
  EChange removeAttribute (@Nullable String sNamespaceURI, @Nullable String sAttrName);

  /**
   * Remove the attribute with the given name.
   *
   * @param aAttrName
   *        The qualified name of the attribute to be removed. May be
   *        null.
   * @return {@link EChange#CHANGED} if the attribute was removed,
   *         {@link EChange#UNCHANGED} if no such attribute exists at this
   *         element.
   */
  @Nonnull
  EChange removeAttribute (@Nullable IMicroQName aAttrName);

  /**
   * Remove all attributes from this element
   *
   * @return {@link EChange}.
   */
  @Nonnull
  EChange removeAllAttributes ();

  // Other API

  /**
   * Get the namespace URI of this element
   *
   * @return May be null if this element has no namespace URI.
   */
  @Nullable
  String getNamespaceURI ();

  /**
   * Set a new namespace URI for this element.
   *
   * @param sNamespaceURI
   *        The namespace URI to be set. May be null or empty to
   *        indicate that the namespace should be removed.
   * @return {@link EChange}
   */
  @Nonnull
  EChange setNamespaceURI (@Nullable String sNamespaceURI);

  /**
   * Check if this element has a specified namespace URI.
   *
   * @return true if this element has a specified namespace URI,
   *         false otherwise
   */
  boolean hasNamespaceURI ();

  /**
   * Check if this element has no namespace URI.
   *
   * @return true if this element has no namespace URI,
   *         false otherwise
   */
  boolean hasNoNamespaceURI ();

  /**
   * Check if this element has the specified namespace URI.
   *
   * @param sNamespaceURI
   *        The namespace URI to check. May not be null.
   * @return true if this element has the specified namespace URI,
   *         false otherwise
   */
  boolean hasNamespaceURI (@Nullable String sNamespaceURI);

  /**
   * Get the local name of the element. Is the same name as returned by
   * {@link #getTagName()} but it is only present, if a namespace URI is
   * present.
   *
   * @return May be null if no namespace is present.
   */
  @Nullable
  String getLocalName ();

  /**
   * Get the name of the tag. It never contains XML schema prefixes or the like.
   * Is the same as {@link #getLocalName()} if a namespace URI is present.
   *
   * @return May not be null.
   */
  @Nonnull
  String getTagName ();

  /**
   * @return The number of all direct child elements. Always ≥ 0.
   */
  @Nonnegative
  int getChildElementCount ();

  /**
   * Get a list of all direct child elements. Text nodes and other other child
   * nodes are not returned with this call. Micro container children are
   * inlined.
   *
   * @return Never be null.
   */
  @Nonnull
  @ReturnsMutableCopy
  List  getAllChildElements ();

  /**
   * Get a list of all direct child elements having the specified tag name.
   * Micro container children are inlined.
   *
   * @param sTagName
   *        The tag name to check. May be null.
   * @return Never be null.
   */
  @Nonnull
  @ReturnsMutableCopy
  List  getAllChildElements (@Nullable String sTagName);

  /**
   * Get a list of all direct child elements having the specified namespace and
   * the specified tag name. Micro container children are inlined.
   *
   * @param sNamespaceURI
   *        The namespace URI to check. May be null.
   * @param sLocalName
   *        The tag name to check. May be null.
   * @return Never be null.
   */
  @Nonnull
  @ReturnsMutableCopy
  List  getAllChildElements (@Nullable String sNamespaceURI, @Nullable String sLocalName);

  /**
   * Recursively get all child elements. Micro container children are inlined.
   *
   * @return A list containing all recursively contained elements. May not be
   *         null but empty.
   */
  @Nonnull
  @ReturnsMutableCopy
  List  getAllChildElementsRecursive ();

  /**
   * Check if this element has at least one child element. Micro container
   * children are also checked.
   *
   * @return true if this element has at least one child element
   */
  boolean hasChildElements ();

  /**
   * Check if this element has at least one child element with the specified tag
   * name. Micro container children are also checked.
   *
   * @param sTagName
   *        The tag name to check. May be null.
   * @return true if this element has at least one child element
   *         with the specified tag name
   */
  boolean hasChildElements (@Nullable String sTagName);

  /**
   * Check if this element has at least one child element with the specified
   * namespace URI and tag name. Micro container children are also checked.
   *
   * @param sNamespaceURI
   *        The namespace URI to check. May be null.
   * @param sLocalName
   *        The tag name to check. May be null.
   * @return true if this element has at least one child element
   *         with the specified namespace URI and tag name
   */
  boolean hasChildElements (@Nullable String sNamespaceURI, @Nullable String sLocalName);

  /**
   * Get the first child element of this element. Micro container children are
   * also checked.
   *
   * @return The first child element or null if this element has no
   *         child element.
   */
  @Nullable
  IMicroElement getFirstChildElement ();

  /**
   * Get the first child element with the given tag name. Micro container
   * children are also checked.
   *
   * @param sTagName
   *        The tag name of the element to search. May be null.
   * @return null if no such child element is present
   */
  @Nullable
  IMicroElement getFirstChildElement (@Nullable String sTagName);

  /**
   * Get the first child element with the given tag name and the given
   * namespace. Micro container children are also checked.
   *
   * @param sNamespaceURI
   *        The namespace URL to search.
   * @param sLocalName
   *        The tag name of the element to search.
   * @return null if no such child element is present
   */
  @Nullable
  IMicroElement getFirstChildElement (@Nullable String sNamespaceURI, @Nullable String sLocalName);

  /**
   * {@inheritDoc}
   */
  @Nonnull
  IMicroElement getClone ();
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy