All Downloads are FREE. Search and download functionalities are using the official Maven repository.

edu.harvard.hul.ois.jhove.module.html.HtmlStack Maven / Gradle / Ivy

/**********************************************************************
 * Jhove - JSTOR/Harvard Object Validation Environment
 * Copyright 2004 by JSTOR and the President and Fellows of Harvard College
 **********************************************************************/

package edu.harvard.hul.ois.jhove.module.html;

import java.util.*;

/**
 * A LinkedList dressed up as a stack for processing HTML objects.
 * It knows about certain elements and their history on the stack.
 *
 * @author Gary McGath
 *
 */
public class HtmlStack extends LinkedList {

    /** Elements which get special treatment. */
    private HtmlTagDesc headElement;
    private HtmlTagDesc bodyElement;
    private HtmlTagDesc framesetElement;
    
    private boolean headSeen;
    private boolean bodySeen;
    
    /** Sets the value of the HEAD element for easy comparison */
    protected void setHeadElement (HtmlTagDesc elem)
    {
        headElement = elem;
    }

    /** Sets the value of the HEAD element for easy comparison */
    protected void setBodyElement (HtmlTagDesc elem)
    {
        bodyElement = elem;
    }

    /** Sets the value of the HEAD element for easy comparison */
    protected void setFramesetElement (HtmlTagDesc elem)
    {
        bodyElement = elem;
    }

    /** Pops top element from element stack.  If we ever decide
     * to go to a different stack implementation, it's necessary
     * only to change these methods.  Also, they add some
     * type checking.
     * 
     * Name changed from "pop" to "popp" to avoid a conflict in Java 1.6
     * with the List class.
     *  */
    protected void popp ()
    {
        removeLast ();
    }
    
    /** Pushes an element onto the stack.  This should have
     * its element field set to function properly. */
    protected void push (JHOpenTag tag)
    {
        add (tag);
        HtmlTagDesc element = tag.getElement ();
        if (element == headElement) {
            headSeen = true;
        }
        else if (element == bodyElement) {
            bodySeen = true;
        }
    }

    /** Gets the top of the element stack without popping it. */
    protected JHOpenTag top ()
    {
        return (JHOpenTag) getLast();
    }
    
    /** Searches backwards through the element stack for a
     * match to a given tag.  Return -1 if no match. */
    protected int search (String tag) 
    {
        /* Supposedly this ListIterator setup works
         * for walking backwards. */
        ListIterator liter = listIterator 
                (size());
        int idx = size () - 1;
        while (liter.hasPrevious ()) {
            JHOpenTag stackTag = (JHOpenTag) liter.previous();
            HtmlTagDesc elem = stackTag.getElement ();
            if (elem.matches (tag)) {
                return idx;
            }
            idx--;
        }
        
        /* No match, return -1 */
        return -1;
    }
    
    /** Pops elements from the stack up to and including the
     * one indexed by idx */
    protected void popTo (int idx)
    {
        int npop = size () - idx;
        for (int i = 0; i < npop; i++) {
            removeLast();
        }
    }

    /** Returns true if a HEAD element has been
     *  pushed on the stack. */
    protected boolean isHeadSeen ()
    {
        return headSeen;
    }
    
    /** Returns true if a BODY element has been
     *  pushed on the stack. */
    protected boolean isBodySeen ()
    {
        return bodySeen;
    }
    
    /** Returns true if any element on the stack
     *  prohibits the specified tag. */
    protected boolean excludesTag (String tag) {
        Iterator iter = iterator ();
        while (iter.hasNext ()) {
            JHOpenTag stackTag = (JHOpenTag) iter.next ();
            if (stackTag.getElement ().excludesTag (tag)) {
                return true;
            }
        }
        return false;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy