/* * Copyright (C) 2009 The Android Open Source Project * * 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.android.sdklib.internal.repository; import org.w3c.dom.Node; /** * Misc utilities to help extracting elements and attributes out of an XML document. */ class XmlParserUtils { /** * Returns the first child element with the given XML local name. * If xmlLocalName is null, returns the very first child element. */ public static Node getFirstChild(Node node, String xmlLocalName) { String nsUri = node.getNamespaceURI(); for(Node child = node.getFirstChild(); child != null; child = child.getNextSibling()) { if (child.getNodeType() == Node.ELEMENT_NODE && nsUri.equals(child.getNamespaceURI())) { if (xmlLocalName == null || xmlLocalName.equals(child.getLocalName())) { return child; } } } return null; } /** * Retrieves the value of that XML element as a string. * Returns an empty string whether the element is missing or empty, * so you can't tell the difference. * <p/> * Note: use {@link #getOptionalXmlString(Node, String)} if you need to know when the * element is missing versus empty. * * @param node The XML <em>parent</em> node to parse. * @param xmlLocalName The XML local name to find in the parent node. * @return The text content of the element. Returns an empty string whether the element * is missing or empty, so you can't tell the difference. */ public static String getXmlString(Node node, String xmlLocalName) { Node child = getFirstChild(node, xmlLocalName); return child == null ? "" : child.getTextContent(); //$NON-NLS-1$ } /** * Retrieves the value of that XML element as a string. * Returns null when the element is missing, so you can tell between a missing element * and an empty one. * <p/> * Note: use {@link #getXmlString(Node, String)} if you don't need to know when the * element is missing versus empty. * * @param node The XML <em>parent</em> node to parse. * @param xmlLocalName The XML local name to find in the parent node. * @return The text content of the element. Returns null when the element is missing. * Returns an empty string whether the element is present but empty. */ public static String getOptionalXmlString(Node node, String xmlLocalName) { Node child = getFirstChild(node, xmlLocalName); return child == null ? null : child.getTextContent(); //$NON-NLS-1$ } /** * Retrieves the value of that XML element as an integer. * Returns the default value when the element is missing or is not an integer. */ public static int getXmlInt(Node node, String xmlLocalName, int defaultValue) { String s = getXmlString(node, xmlLocalName); try { return Integer.parseInt(s); } catch (NumberFormatException e) { return defaultValue; } } /** * Retrieves the value of that XML element as a long. * Returns the default value when the element is missing or is not an integer. */ public static long getXmlLong(Node node, String xmlLocalName, long defaultValue) { String s = getXmlString(node, xmlLocalName); try { return Long.parseLong(s); } catch (NumberFormatException e) { return defaultValue; } } /** * Retrieve an attribute which value must match one of the given enums using a * case-insensitive name match. * * Returns defaultValue if the attribute does not exist or its value does not match * the given enum values. */ public static Object getEnumAttribute( Node archiveNode, String attrName, Object[] values, Object defaultValue) { Node attr = archiveNode.getAttributes().getNamedItem(attrName); if (attr != null) { String found = attr.getNodeValue(); for (Object value : values) { if (value.toString().equalsIgnoreCase(found)) { return value; } } } return defaultValue; } }