org.apache.axis2.saaj.NodeListImpl Maven / Gradle / Ivy
/*
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you 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.apache.axis2.saaj;
import org.w3c.dom.Node;
import org.w3c.dom.NodeList;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
/**
* The NodeList
interface provides the abstraction of an ordered collection of nodes,
* without defining or constraining how this collection is implemented. NodeList
* objects in the DOM are live. The items in the NodeList
are accessible via an
* integral index, starting from 0.
See also the Document
* Object Model (DOM) Level 2 Core Specification.
*/
public class NodeListImpl implements NodeList {
List mNodes;
public static final NodeList EMPTY_NODELIST = new NodeListImpl(
Collections.EMPTY_LIST);
/** Constructor and Setter is intensionally made package access only. */
NodeListImpl() {
mNodes = new ArrayList();
}
NodeListImpl(List nodes) {
this();
mNodes.addAll(nodes);
}
void addNode(org.w3c.dom.Node node) {
mNodes.add(node);
}
void addNodeList(org.w3c.dom.NodeList nodes) {
for (int i = 0; i < nodes.getLength(); i++) {
mNodes.add(nodes.item(i));
}
}
/**
* Returns the index
th item in the collection. If index
is greater
* than or equal to the number of nodes in the list, this returns null
.
*
* @param index Index into the collection.
* @return The node at the index
th position in the NodeList
, or
* null
if that is not a valid index.
*/
public Node item(int index) {
if (mNodes != null && mNodes.size() > index) {
return (Node)mNodes.get(index);
} else {
return null;
}
}
/**
* The number of nodes in the list. The range of valid child node indices is 0 to
* length-1
inclusive.
*/
public int getLength() {
return mNodes.size();
}
}