/*
* @(#)DOMNodeListByTagNameImpl.java 1.11 2000/08/16
*
*/
package org.w3c.tidy;
/**
*
* DOMNodeListByTagNameImpl
*
* (c) 1998-2000 (W3C) MIT, INRIA, Keio University
* See Tidy.java for the copyright notice.
* Derived from <a href="http://www.w3.org/People/Raggett/tidy">
* HTML Tidy Release 4 Aug 2000</a>
*
* @author Dave Raggett <dsr@w3.org>
* @author Andy Quick <ac.quick@sympatico.ca> (translation to Java)
* @version 1.4, 1999/09/04 DOM support
* @version 1.5, 1999/10/23 Tidy Release 27 Sep 1999
* @version 1.6, 1999/11/01 Tidy Release 22 Oct 1999
* @version 1.7, 1999/12/06 Tidy Release 30 Nov 1999
* @version 1.8, 2000/01/22 Tidy Release 13 Jan 2000
* @version 1.9, 2000/06/03 Tidy Release 30 Apr 2000
* @version 1.10, 2000/07/22 Tidy Release 8 Jul 2000
* @version 1.11, 2000/08/16 Tidy Release 4 Aug 2000
*/
/**
* <p>The items in the <code>NodeList</code> are accessible via an integral
* index, starting from 0.
*
*/
public class DOMNodeListByTagNameImpl implements org.w3c.dom.NodeList {
private Node first = null;
private String tagName = "*";
private int currIndex = 0;
private int maxIndex = 0;
private Node currNode = null;
protected DOMNodeListByTagNameImpl(Node first, String tagName)
{
this.first = first;
this.tagName = tagName;
}
/**
* @see org.w3c.dom.NodeList#item
*/
public org.w3c.dom.Node item(int index)
{
currIndex = 0;
maxIndex = index;
preTraverse(first);
if (currIndex > maxIndex && currNode != null)
return currNode.getAdapter();
else
return null;
}
/**
* @see org.w3c.dom.NodeList#getLength
*/
public int getLength()
{
currIndex = 0;
maxIndex = Integer.MAX_VALUE;
preTraverse(first);
return currIndex;
}
protected void preTraverse(Node node)
{
if (node == null)
return;
if (node.type == Node.StartTag || node.type == Node.StartEndTag)
{
if (currIndex <= maxIndex &&
(tagName.equals("*") || tagName.equals(node.element)))
{
currIndex += 1;
currNode = node;
}
}
if (currIndex > maxIndex)
return;
node = node.content;
while (node != null)
{
preTraverse(node);
node = node.next;
}
}
}