/* * Copyright 2004-2009 the original author or authors. * * 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.compass.core.util; import java.util.ArrayList; import java.util.List; import org.w3c.dom.Comment; import org.w3c.dom.Element; import org.w3c.dom.EntityReference; import org.w3c.dom.Node; import org.w3c.dom.NodeList; /** * Convenience methods for working with the DOM API, * in particular for working with DOM Nodes and DOM Elements. * * @author kimchy * @see org.w3c.dom.Node * @see org.w3c.dom.Element */ public abstract class DomUtils { public static String getElementAttribute(Element ele, String attributeName) { return getElementAttribute(ele, attributeName, null); } /** * Gets the attribute value from the element. If the attribute is <code>null</code> * or is an empty string, will return the defaultValue. */ public static String getElementAttribute(Element ele, String attributeName, String defaultValue) { String value = ele.getAttribute(attributeName); if (value == null || !StringUtils.hasText(value)) { return defaultValue; } return value; } public static boolean getElementAttributeAsBoolean(Element ele, String attributeName, boolean defaultValue) { String sValue = getElementAttribute(ele, attributeName); if (sValue == null) { return defaultValue; } return Boolean.valueOf(sValue).booleanValue(); } /** * Retrieve all child elements of the given DOM element that match * the given element name. Only look at the direct child level of the * given element; do not go into further depth (in contrast to the * DOM API's <code>getElementsByTagName</code> method). * * @param ele the DOM element to analyze * @param childEleName the child element name to look for * @return a List of child <code>org.w3c.dom.Element</code> instances * @see org.w3c.dom.Element * @see org.w3c.dom.Element#getElementsByTagName */ public static List getChildElementsByTagName(Element ele, String childEleName) { return getChildElementsByTagName(ele, childEleName, false); } /** * Retrieve all child elements of the given DOM element that match * the given element name. Only look at the direct child level of the * given element; do not go into further depth (in contrast to the * DOM API's <code>getElementsByTagName</code> method). * <p/>Can select whether or not to compare against the local name of * the {@link org.w3c.dom.Element} * * @param ele the DOM element to analyze * @param childEleName the child element name to look for * @param localName whether to compare against the local node name * @return a List of child <code>org.w3c.dom.Element</code> instances * @see org.w3c.dom.Element * @see org.w3c.dom.Element#getElementsByTagName */ public static List getChildElementsByTagName(Element ele, String childEleName, boolean localName) { NodeList nl = ele.getChildNodes(); List childEles = new ArrayList(); for (int i = 0; i < nl.getLength(); i++) { Node node = nl.item(i); String name = (localName) ? node.getLocalName() : node.getNodeName(); if (node instanceof Element && childEleName.equals(name)) { childEles.add(node); } } return childEles; } /** * Retruns the trimmed text value of the DOM element. * * @see #getTextValue(org.w3c.dom.Element) */ public static String getTrimmedTextValue(Element valueEle) { return getTextValue(valueEle).trim(); } /** * Extract the text value from the given DOM element, ignoring XML comments. * <p>Appends all CharacterData nodes and EntityReference nodes * into a single String value, excluding Comment nodes. * * @see org.w3c.dom.CharacterData * @see org.w3c.dom.EntityReference * @see org.w3c.dom.Comment */ public static String getTextValue(Element valueEle) { StringBuffer value = new StringBuffer(); NodeList nl = valueEle.getChildNodes(); for (int i = 0; i < nl.getLength(); i++) { Node item = nl.item(i); if ((item instanceof org.w3c.dom.CharacterData && !(item instanceof Comment)) || item instanceof EntityReference) { value.append(item.getNodeValue()); } } return value.toString(); } }