Mega Code Archive

 
Categories / Java / XML
 

Find Node

/*  * The Apache Software License, Version 1.1  *  * Copyright (c) 2000-2002 The Apache Software Foundation.  All rights  * reserved.  *  * Redistribution and use in source and binary forms, with or without  * modification, are permitted provided that the following conditions  * are met:  *  * 1. Redistributions of source code must retain the above copyright  *    notice, this list of conditions and the following disclaimer.  *  * 2. Redistributions in binary form must reproduce the above copyright  *    notice, this list of conditions and the following disclaimer in  *    the documentation and/or other materials provided with the  *    distribution.  *  * 3. The end-user documentation included with the redistribution, if  *    any, must include the following acknowlegement:  *       "This product includes software developed by the  *        Apache Software Foundation (http://www.apache.org/)."  *    Alternately, this acknowlegement may appear in the software itself,  *    if and wherever such third-party acknowlegements normally appear.  *  * 4. The names "The Jakarta Project", "Ant", and "Apache Software  *    Foundation" must not be used to endorse or promote products derived  *    from this software without prior written permission. For written  *    permission, please contact apache@apache.org.  *  * 5. Products derived from this software may not be called "Apache"  *    nor may "Apache" appear in their names without prior written  *    permission of the Apache Group.  *  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE  * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR  * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF  * SUCH DAMAGE.  *   *  * This software consists of voluntary contributions made by many  * individuals on behalf of the Apache Software Foundation.  For more  * information on the Apache Software Foundation, please see  * <http://www.apache.org/>.  */ import java.io.File; import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import org.w3c.dom.Document; import org.w3c.dom.Element; import org.w3c.dom.NamedNodeMap; import org.w3c.dom.Node; import org.w3c.dom.NodeList; /**  *   * @author Abey Mullassery  *   */ public class Main {   public static Node findNode(       Node root,       String elementName,       boolean deep,       boolean elementsOnly) {       //Check to see if root has any children if not return null       if (!(root.hasChildNodes()))         return null;       //Root has children, so continue searching for them       Node matchingNode = null;       String nodeName = null;       Node child = null;       NodeList childNodes = root.getChildNodes();       int noChildren = childNodes.getLength();       for (int i = 0; i < noChildren; i++) {         if (matchingNode == null) {           child = childNodes.item(i);           nodeName = child.getNodeName();           if ((nodeName != null) & (nodeName.equals(elementName)))             return child;           if (deep)             matchingNode =               findNode(child, elementName, deep, elementsOnly);         } else           break;       }       if (!elementsOnly) {         NamedNodeMap childAttrs = root.getAttributes();         noChildren = childAttrs.getLength();         for (int i = 0; i < noChildren; i++) {           if (matchingNode == null) {             child = childAttrs.item(i);             nodeName = child.getNodeName();             if ((nodeName != null) & (nodeName.equals(elementName)))               return child;           } else             break;         }       }       return matchingNode;     } }